本文主要是介绍拔河游戏机——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&#
这篇关于拔河游戏机——ABLE-HDL语言实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!