设计一个秒表,数码管 00,01--60,00,每秒走一个数,用verilog语言。
1. “分分:秒秒”计数器设计
我们要实现“分分:秒秒”显示的电子秒表,需要设计计数频率为1Hz 的
计数器。因为“分分:秒秒”的结构对应有4个十进制数字(个位的秒,十位的
秒,个位的分,十位的分),如果采用统一计数再分别求出“分分:秒秒” 对应
的4个十进制数字进行译码显示,则求解对应的4个十进制数字的过程难于用硬
件实现。在此,我们将每个显示的值分别进行计数,即分别针对个位的秒、十位
的秒、个位的分、十位的分设计对应的计数器,其中个位的秒计数频率为1Hz,
其从0到9计数,当从9回到0时,向前进一位,使得十位的秒进行计数加1。
35
十位的秒从0到5计数,当从5回到0时,向前进一位,使得个位的分进行计数
加1。个位的分从0到9计数,当从9回到0 时,向前进一位,使得十位的分进
行计数加1。十位的分则从0 到5计数,计数到5时,又回到0。
2. 扫描显示技术
因为4位数码管的段控制输入是复用的,要分别显示不同的计数数值,需要
使用动态扫描显示技术,其电路结构如图61 所示。首先,以扫描显示的频率进
行2比特宽的模4计数,然后由其值从4个数码管的待显示值输入中选择对应的
一个经译码后连接到公共的段控制输入端,同时将计数值经2到4译码后输出到
对应数码管位的公共端,点亮对应的数码管。虽然各数码管位是轮流显示,每个
数码管位上的数字是断续的显示,只要扫描的频率够快,由于人眼的视觉残余效
应,就可以看到各数码管位上稳定的数字显示值。这和我们使用的电视、显示器
的显示原理是一样的。参考液晶显示器的刷新频率,经验证,在每秒钟扫描60
帧的时候,各数码管位上即能得到稳定的数字显示,此时,对应计数时钟的等效
频率为240Hz。我们可以参考实验四的图47,再做一个等效分频计数器,通过
产生的后级时钟使能信号将20MHz的时钟等效分频到240Hz。
图 61 扫描显示电路结构
3. 冒号点的处理
数码管中间的时间分隔冒号点(对应为左边第2个数码管位的DP点)每秒
钟闪烁一次,其频率为1Hz,只需要输出1Hz,占空比为50%的周期信号即可。
其他数码管位的点号不需要显示,对应的DP 点输出低电平无效信号即可。这4
个信号 所示的显示切换计数值进行4 选1 选择后接到数码管上公共的
DP控制端。
在实验四中,我们为了得到1Hz的主功能计数频率,前面利用precnt
进行了等效分频计数,其一个完整的计数周期即为1s,对应产生的使能信号en
频率即为1Hz,但我们在此不能直接使用en 的信号,因为其占空比只有
1/20000000,肉眼无法看到其闪烁的效果。为得到占空比为50%的1Hz信号,我
们可以通过对precnt 的计数值进行比较得出,只需要在precnt 计数周期内一半的
时间输出1,一半的时间输出0 即可,例如,当precnt>25'd9999999 时输出0,
否则输出1,此时即可得到占空比为50%的1Hz信号。
4. 总体设计
总体设计只需要将时钟电路、复位电路、按键电路、数码管电路等组合起来,
综合使用时钟使能的同步设计技术、按键处理技术、扫描显示技术、“分分:秒
秒”计数器设计技术及冒号点的处理技术即可。
定时器0.01秒刷新,数码管动态显示。用一个变量存当前时间的数据,点开始键打开定时器,暂停关闭定时器就行了。
1. “分分:秒秒”计数器设计我们要实现“分分:秒秒”显示的电子秒表,需要设计计数频率为1Hz 的
计数器。因为“分分:秒秒”的结构对应有4个十进制数字(个位的秒,十位的
秒,个位的分,十位的分),如果采用统一计数再分别求出“分分:秒秒” 对应
的4个十进制数字进行译码显示,则求解对应的4个十进制数字的过程难于用硬
件实现。在此,我们将每个显示的值分别进行计数,即分别针对个位的秒、十位
的秒、个位的分、十位的分设计对应的计数器,其中个位的秒计数频率为1Hz,
其从0到9计数,当从9回到0时,向前进一位,使得十位的秒进行计数加1。
35
十位的秒从0到5计数,当从5回到0时,向前进一位,使得个位的分进行计数
加1。个位的分从0到9计数,当从9回到0 时,向前进一位,使得十位的分进
行计数加1。十位的分则从0 到5计数,计数到5时,又回到0。
2. 扫描显示技术
因为4位数码管的段控制输入是复用的,要分别显示不同的计数数值,需要
使用动态扫描显示技术,其电路结构如图61 所示。首先,以扫描显示的频率进
行2比特宽的模4计数,然后由其值从4个数码管的待显示值输入中选择对应的
一个经译码后连接到公共的段控制输入端,同时将计数值经2到4译码后输出到
对应数码管位的公共端,点亮对应的数码管。虽然各数码管位是轮流显示,每个
数码管位上的数字是断续的显示,只要扫描的频率够快,由于人眼的视觉残余效
应,就可以看到各数码管位上稳定的数字显示值。这和我们使用的电视、显示器
的显示原理是一样的。参考液晶显示器的刷新频率,经验证,在每秒钟扫描60
帧的时候,各数码管位上即能得到稳定的数字显示,此时,对应计数时钟的等效
频率为240Hz。我们可以参考实验四的图47,再做一个等效分频计数器,通过
产生的后级时钟使能信号将20MHz的时钟等效分频到240Hz。
图 61 扫描显示电路结构
3. 冒号点的处理
数码管中间的时间分隔冒号点(对应为左边第2个数码管位的DP点)每秒
钟闪烁一次,其频率为1Hz,只需要输出1Hz,占空比为50%的周期信号即可。
其他数码管位的点号不需要显示,对应的DP 点输出低电平无效信号即可。这4
个信号 所示的显示切换计数值进行4 选1 选择后接到数码管上公共的
DP控制端。
在实验四中,我们为了得到1Hz的主功能计数频率,前面利用precnt
进行了等效分频计数,其一个完整的计数周期即为1s,对应产生的使能信号en
频率即为1Hz,但我们在此不能直接使用en 的信号,因为其占空比只有
1/20000000,肉眼无法看到其闪烁的效果。为得到占空比为50%的1Hz信号,我
们可以通过对precnt 的计数值进行比较得出,只需要在precnt 计数周期内一半的
时间输出1,一半的时间输出0 即可,例如,当precnt>25'd9999999 时输出0,
否则输出1,此时即可得到占空比为50%的1Hz信号。
4. 总体设计
总体设计只需要将时钟电路、复位电路、按键电路、数码管电路等组合起来,
综合使用时钟使能的同步设计技术、按键处理技术、扫描显示技术、“分分:秒
秒”计数器设计技术及冒号点的处理技术即可。
设计一个秒表,数码管 00,01--60,00,每秒走一个数,用verilog语言。
行2比特宽的模4计数,然后由其值从4个数码管的待显示值输入中选择对应的 一个经译码后连接到公共的段控制输入端,同时将计数值经2到4译码后输出到 对应数码管位的公共端,点亮对应的数码管。虽然各数码管位是轮流显示,每个 数码管位上的数字是断续的显示,只要扫描的频率够快,由于人眼的视觉残余效...
设计一个单片机秒表,该秒表可显示0.0到59.9秒的时间
P3接字码,P2接位码。没有加按键功能。include <reg51.h> define uchar unsigned char define uint unsigned int \/\/数码管字型表,对应0,1,2,3,4,5,6,7,8,9\/\/ uchar Table[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};uint Data[2]={0,0};data Buffe...
秒表,用动态数码管显示,范围从0000~9999,可暂停,可复位。要求用MC51...
msecond equ 51h second1 equ 52h second2 equ 53h second3 equ 54h second4 equ 55h org 00h ljmp start org 03h ljmp int_ex0 org 0bh ljmp int_t0 org 013h ljmp int_ex1 org 01bh ljmp int_t1 org 0100h start: mov tmod,#12h m...
用数码管设计一个秒表,使之显示从0~60(用内部定时器),数码管段码由P2...
TMOD=0x01; \/\/使用定时器T0 TH0=(65536-46083)\/256; \/\/将定时器计时时间设定为46083×1.085微秒 \/\/=50000微秒=50毫秒 TL0=(65536-46083)%256;EA=1; \/\/开启总中断 ET0=1; \/\/定时器T0中断允许 TR0=1; \/\/启动定时器T0开始运行 int_time=0; \/\/中断次数初始化 second...
数码管秒表 00-99计时 求电路图 和程序
TMOD=0x01;TH0=(65535-50000)\/256;TL0=(65535-50000)%256;EA=1;ET0=1;while(1){ ss=b\/10;sg=b%10;gs=a\/10;gg=a%10;P0=0;P0=table[gg];P2=0xfe;delay(5);P2=0xff;P0=table[gs];P2=0xfd;delay(5);P2=0xff;P0=0;P0=table[sg];P2=0xf7;delay(5);P2=0xff;P0=table...
秒表设计
\/\/12M晶振。6位共阴数码管,P0 段码,P2.0~P2.5 位控 \/\/显示 00.00.00 最小为0.01s ,include <reg51.h> define uchar unsigned char define uint unsigned int sbit P20=P2^0;sbit P21=P2^1;sbit P22=P2^2;sbit P23=P2^3;sbit P24=P2^4;sbit P25=P2^5;sbit P07=P0^7;sb...
要设计一个电子秒表,从00.00到99.99,4位数码管显示 2个按键 开始\/暂停...
定时器0.01秒刷新,数码管动态显示。用一个变量存当前时间的数据,点开始键打开定时器,暂停关闭定时器就行了。
单片机AT89C51芯片完成简易秒表的设计(三个8字数码管从0~999秒)设置一...
设计一个简易秒表,使用单片机AT89C51,配备三个8位数码管来显示0至999秒的时间。该秒表包括一个启动按钮和一个复位按钮,操作简洁,功能强大。程序开始部分包含了必要的头文件,并定义了用于数码管显示的数据变量。数码管采用BCD码进行编码,方便处理。此外,还定义了用于计时和按键检测的变量。主函数初始化...
利用51单片机,4个数码管设计一个计时器,要求在数码管上显示的数据从0开...
共阳数码管中断程序:include<reg52.h> define uint unsigned int define uchar unsigned char uchar code table[]= { 0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x83,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};uint num,a;uchar bai,shi,ge;void init();void delay(uint);void ...
51单片机设计一个秒表,用两个数码管(任意相邻的两个)显示。
ORG001BH LJMPT1INT LEDDEQU30H LEDCEQU 36H SECCEQU 37H TCNTEQU 3AH ORG 0030H ;--- TABLE: ; 共阴极数码管显示代码表 DB 0FCH;"0"00H DB 60H;"1"01H DB 0DAH;"2"02H DB 0F2H;"3"03H DB 66H;"4"04H DB 0B6H;"5"05H DB 0BEH;"6"06H DB 0E0H;"7"07H DB 0...