eda编程9人表决器程序详解是什么?

eda编程9人表决器程序详解是什么?,第1张

eda编程9人表决器程序详解://本程序用VERILOG HDL语言实现,描述9人表决器。

module biaojueqi(vote,ledr,ledg,dis_out)

input [8:0] vote

reg [6:0] dis_out

integer i,sum//sum表示赞同的人数

for(i=0i<=8i=i+1)

if(vote[i]) sum<=sum+1

end

always @(sum) //结果由dis_out显示在数码管

case (sum)

0: dis_out[6:0]<=7'b1111110

1: dis_out[6:0]<=7'b0110000

2: dis_out[6:0]<=7'b1101101

3: dis_out[6:0]<=7'b1111001

4: dis_out[6:0]<=7'b0110011

5: dis_out[6:0]<=7'b1011011

6: dis_out[6:0]<=7'b1011111

7: dis_out[6:0]<=7'b1110000

8: dis_out[6:0]<=7'b1111111

9: dis_out[6:0]<=7'b1111011

endmodule

内容简介

本书从实际应用的角度出发,全面系统地介绍了EDA技术和硬件描述语言VHDL,将VHDL的基础知识、编程技巧、实用方法与实际工程开发技术在EDA软件设计平台上很好地结合起来,使读者能够通过本书的学习迅速了解并掌握EDA技术的基本理论和工程开发实用技术。

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.

总体设计

总体设计只需要将时钟电路、复位电路、按键电路、数码管电路等组合起来,

综合使用时钟使能的同步设计技术、按键处理技术、扫描显示技术、“分分:秒

秒”计数器设计技术及冒号点的处理技术即可。

LIBRARYIEEE

USEIEEE.STD_LOGIC_1164.ALL

USEIEEE.STD_LOGIC_ARITH.ALL

USEIEEE.STD_LOGIC_UNSIGNED.ALL--库,程序包的使用

ENTITYSRAM IS--实体描述(SRAM为实体名)

GENERIC(WIDTH:INTEGER:=8--类属表(integer是整型,WIDTH为常数名)

DEPTH:INTEGER:=128--类比上一句即可

ADDER:INTEGER:=3)

PORT(DATAIN:IN STD_LOGIC_VECTOR(7 DOWNTO0)--端口说明,IN为端口类型,输入只读

DATAOUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)--OUT输出,只写

CLOCK:IN STD_LOGIC--STD_LOGIC是数据类型,为标准位单值

WE,RE:IN STD_LOGIC--WE和RE为输入端口,可输入标准位单值

SIGNAL WADD:IN STD_LOGIC_VECTOR(2DOWNTO 0)--标准位位矢量,3个信号元素

SIGNAL RADD:IN STD_LOGIC_VECTOR(2 DOWNTO 0))

ENDENTITY SRAM--结束实体描述

ARCHITECTUREART OF SRAM IS--结构体描述(ART是结构体名)

TYPE MEM IS ARRAY(0 TO 127) OF STD_LOGIC_VECTOR(7 DOWNTO 0)--元素说明

SIGNAL RAMTMP:MEM--TYPE数据类型,SIGNAL信号

BEGIN--下面为功能描述

PROCESS(CLOCK)--进程,CLOCK为敏感信号,敏感信号的变化会激活进程

BEGIN

IF (CLOCK'EVENT AND CLOCK='1') THEN--时钟信号上升沿

IF(WE='1')THEN

RAMTMP(CONV_INTEGER(WADD))<=DATAIN --如果we为1,将DATAIN的值赋给RAMTMP(CONV_INTEGER(WADD))

END IF

END IF

ENDPROCESS

PROCESS(CLOCK)--可类比上一个进程

BEGIN

IF(CLOCK'EVENTAND CLOCK='1')THEN

IF (RE='1') THEN

DATAOUT<=RAMTMP(CONV_INTEGER(RADD))

END IF

ENDIF

ENDPROCESS

ENDARCHITECTURE ART


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12133327.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存