拔河游戏机——ABLE-HDL语言实现

兹于2016年12月,应《数字逻辑》课程设计的要求,本人在老师指导下用ABLE-HDL语言实现了拔河游戏机的功能。



拔河游戏机



1、题目描述

    拔河游戏机用7个发光二极管排列成一行,开机后只有中间一个发亮,以此作为拔河的中心线,游戏双方各持一个按键,迅速地、不断地按动产生脉冲,谁按得快,亮点向谁方向移动,每按一次,亮点移动一次。任一方终端二极管发亮时这一方获胜,此时双方按键被锁住,只有经复位后才使亮点恢复到中心线。



2、参考资料清单及元器件清单

《数字逻辑》 (第六版立体化教材 科学出版社)

GALl6V8                                                            2片

GAL编程器系统                                                 1套

TDS-2数字系统综合实验平台                        1台

导线                                                                    若干

ispExpert软件


3、总体设计方案

    由设计内容可知,首先需要设计一个十进制的可逆计数器,用于对双方按钮的次数计数,并将游戏过程的状态进行输出。设计中还需要一个脉冲与方向产生器用于产生脉冲信号与亮点移动方向的判断,通过可编辑波形发生器设定1KHz频率的信号。其次,显视控制部分设计要求在发光二极管上显示游戏状态,左方每按一次,亮点向左边移动一次;右方每按一次,亮点向右边移动一次。还需设置一个清零端,用于复位。再者,运用ABLE-HDL语言对各个模块进行程序编码,然后将所编码的程序烧录GAL16V8中。最后,将烧录好的芯片在实验箱组装起来,就可得到符合要求的拔河游戏机。


3.1 功能和逻辑需求分析

可逆计数器:当有脉冲信号与方向信号过来时,计数器开始判断亮点移动方向,并进行计数。当有向左移动的信号(dir=1)过来时,即计数器上的方向输入端为1,则将计数器按2→4→8→16→32→64→64的方向进行计数;当有向右移动的信号(dir=0)过来时,即计数器上的方向输入端为0,则将计数器按32→16→8→4→2→1→1的方向进行计数。
 
脉冲与信号发生器:用可编辑信号发生器设定1KHz的频率的脉冲连续输入窄脉冲到脉冲与方向信号产生器,同时将左键key1和右键key2也接入脉冲与方向信号产生器。然后设置两个状态机,一个状态机S1是左键的,另一个状态机S2是右键的。当按左键时将产生一个脉冲信号,开始进行S1的状态循环s0→s1→s2→s3→s0&#

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值