自动售货机设计_第1页
自动售货机设计_第2页
自动售货机设计_第3页
自动售货机设计_第4页
自动售货机设计_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、自动售货机设计一、实验任务前提:单一商品的设定值是4元,多个商品时就设定值自拟(1)自动售货机的投币口每次可以投入1元、2元、5元,且规定投入1元或2元后不得再投入5元;(2)当投入总值等于设定值时,售货机就自动送出货物;当投入的总值超过设定值时,售货机会显示余额,送出商品并自动找零;(3)编写程序,实现售单一商品的功能。按照以上要求,编写程序,实现售单一商品的功能;二、实验内容2.1设计思路图1:自动售货机RTL实验原理图图2:自动售货机的状态装换图实验原理:本次实验是在状态机的基础上设计一个自动售货机,共分为6个状态,即S0,S1,S2,S3,S4,S5,分别表示此时的金额为0元,1元,2

2、元,3元,4元,5元。在时钟的控制下:当现态为S0(即0元),输出的MONEY为0元,无Y0和Y1信号,故PAYBACK为0元。若此时CIN为1元,则次态为S1(即1元);若此时CIN为2元,则次态为S2(即2元);若此时CIN为5元,则次态为S5(即5元);:当现态为S1(即1元),输出的MONEY为1元,无Y0和Y1信号,故PAYBACK为0元。若此时CIN为1元,则次态为S2(即2元);若此时CIN为2元,则次态为S3(即3元);若此时CIN为5元,则次态为S0(即0元);:当现态为S2(即2元),输出的MONEY为2元,有Y0和Y1信号,故PAYBACK为0元。若此时CIN为1元,则次

3、态为S3(即3元);若此时CIN为2元,则次态为S4(即4元);若此时CIN为5元,则次态为S0(即0元);:当现态为S3(即3元),输出的MONEY为3元,无Y0和Y1信号,故PAYBACK为0元。若此时CIN为1元,则次态为S4(即4元);若此时CIN为2元,则次态为S5(即5元);若此时CIN为5元,则次态为S0(即0元);:当现态为S4(即4元),输出的MONEY为4元,有Y0,无Y1信号,故PAYBACK为0元。次态为S0;:当现态为S5(即5元),输出的MONEY为5元,有Y0和Y1信号,故PAYBACK为1元。次态为S0。2.2实验流程图图3:单一商品时流程图三、实验过程3.1实

4、验代码见附录3.2仿真波形图1单一商品的仿真波形 图4:仿真波形图波形图分析如下:输入金额为0元,则输出总金额为0元,无商品购买成功信号和退币信号,故输出余额也为0元;:输入金额为1元,则此时的输出总金额为1元,无商品购买成功信号和退币信号,故输出的余额也为0元;:输入金额为1元,但是此时有一个清零复位信号,则此时的输出总金额为0元,无商品购买成功信号和退币信号,故输出的余额为0元;:输入金额为1元,则此时的输出总金额为1元,无商品购买成功信号和退币信号,故输出的余额也为0元;:输入金额为2元,在原有的1元的基础上加上现在的2元,则此时的输出总金额为3元,无商品购买成功信号和退币信号,故输出的

5、余额为0元;:输入金额为2元,在原有的3元的基础上加上现在的2元,则此时的输出总金额为5元,有商品输出信号和退币信号,故输出的余额为1元;:输入金额为5元,因为设定的输入1元,2元以后不得在输入5元,故此时输出的总金额为0元,无商品购买成功信号和退币信号,所以此时输出的余额为0元;:输入金额为1元,则此时的输出总金额为1元,无商品购买成功信号和退币信号,故输出的余额也为0元;:输入金额为1元,在原有的1元的基础上加上现在的1元,则此时的输出总金额为2元,无商品购买成功信号和退币信号,故输出的余额也为0元;:输入金额为2元,在原有的2元的基础上加上现在的2元,则此时的输出总金额为4元,有商品购买

6、成功信号,但无退币信号,故此时的余额为0元。3.3硬件实现3.3.1模式选择选择模式1 3.3.2引脚锁定1单一商品四、实验结果4.1硬件实现图片4.1.1单一商品时当CIN=1时,结果及分析见下表一个时钟脉冲来到时,输出总金额为1元,此时没有商品输出,也没有退币两个时钟脉冲来到时,输出总金额为2元,此时没有商品输出,也没有退币三个时钟脉冲来时,输出金额为3元,此时没有商品输出,也没有退币四个时钟脉冲来时,输出金额为4元,此时有商品输出,没有退币当CIN=2时,结果及分析见下表一个时钟脉冲来时,输出的总金额为2元,此时没有商品输出,也没有退币两个时钟脉冲来时,输出的总金额为4元,此时有商品输出

7、,没有退币当CIN=5元时,结果及分析见下表一个时钟脉冲来时,输出的总金额为5元,此时有商品输出,有退币且为1元 五、实验总结刚开始看到这个题目时,我就觉得一头雾水,不知道怎么开始设计这个项目,上网也查阅了很多资料,但收获仍是很少,无从下手,不知如何编写代码去实现项目的要求。后经同学提醒,本次项目是需要使用状态机去实现自动售货的功能,与之前我们上机实验中的“有限状态机的实现”很类似,于是,我便开始边看边想,慢慢地编写代码。在编写代码的时候,出现错误是很正常的,我根据QUARTUS软件平台上的错误提醒一一纠正过来了,编译无误后,开始进行波形仿真,但是出现了问题,代码没有出现编译错误,但是没有实现

8、我想要的功能,检查了代码以后我仍然不知道问题出在哪里,于是询问同学,在同学的帮助下,找到了我代码问题所在之处,我编写的代码并不完整,也输出了很多无效状态,在本次设计要求中有,只能输入1元,2元以及5元,不得输入其他面值的钱币,我在编写代码的时候没有考虑到这一点,尽管编译没有错误,但是波形仿真不对,经修正后,得出理想的仿真波形,然后选择合适的模式,进行引脚锁定,锁定结束后开始下载测试,按照我自己设计的按键键8是时钟CLK、键1输入钱币CIN、译码器5为输入的总金额、译码器6为输出的余额,虽说,试验箱上有复位键,但是我仍然设定了一个按键作为我的RESET复位键,D1是商品购买成功的信号,D1如果亮

9、起,则说明已经成功买到商品,反之,则没有买到,由于我所使用的试验箱的D2灯出了问题,当给了高电平以后,却没有如预期一样亮起,故换做D3作为我实验退币的信号灯,当D3亮起时,则说明此时有钱币退出,反之,则没有。经过几天的努力后,成功的完成了本次单一商品的实验,但是多个商品的实现仍然还存在一些问题,这是我的一点小小的遗憾。但总体来说,我的项目设计还算很成功附录1:单一商品的实验代码LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY automatic IS PORT (CLK,RESET:I

10、N STD_LOGIC; CIN:IN STD_LOGIC_VECTOR(2 DOWNTO 0); -输入的总钱数 Y0:OUT STD_LOGIC; -购买成功信号 Y1:OUT STD_LOGIC; -退币信号 MONEY:OUT STD_LOGIC_VECTOR(2 DOWNTO 0); -输入的总金额数 PAYBACK:OUT STD_LOGIC_VECTOR(2 DOWNTO 0); -显示余额END automatic;ARCHITECTURE one OF automatic IS TYPE FSM_ST IS(S0,S1,S2,S3,S4,S5); -定义了S0,S1,S2,S

11、3,S4,S5六个状态 SIGNAL CS,NS:FSM_ST; BEGINREG:PROCESS(CLK,RESET) -一共分为两个进程,分别是REG和COMBEGIN IF RESET=1 THEN CS=S0; -异步清零,清零信号在CLKEVENT AND CLK=1之外 ELSIF CLKEVENT AND CLK=1 THEN CSMONEY=000;Y0=0;Y1=0;PAYBACK=000;-S0状态即为初状态,此时没有输出商品,也没有余额,故也没有商品输出信号,也没有余额输出信号 IF CIN=001 THEN NS=S1; -输入1元则下一状态为S1; ELSIF CIN

12、=010 THEN NS=S2; -输入2元则下一状态为S2; ELSIF CIN=101 THEN NS=S5; -输入5元则下一状态为S5 ELSE NSMONEY=001;Y0=0;Y1=0;PAYBACK=000;-S1状态:输入总金额为1元,余额为0元,没有商品输出信号,没有余额输出信号 IF CIN=001 THEN NS=S2; -输入1元则下一状态为S2; ELSIF CIN=010 THEN NS=S3; -输入2元则下一状态为S3; ELSIF CIN=101 THEN NS=S0; -输入5元则下一状态为S0; ELSE NSMONEY=010;Y0=0;Y1=0;PAY

13、BACK=000;-S2状态:输入总金额为2元,余额为0元,没有商品输出信号,没有余额输出信号 IF CIN=001 THEN NS=S3; -输入1元则下一状态为S3; ELSIF CIN=010 THEN NS=S4; -输入2元则下一状态为S4; ELSIF CIN=101 THEN NS=S0; -输入5元则下一状态为S0; ELSE NSMONEY=011;Y0=0;Y1=0;PAYBACK=000;-S3状态:输入总金额为3元,余额为0元,没有商品输出信号,没有余额输出信号 IF CIN=001 THEN NS=S4; -输入1元则下一状态为S4; ELSIF CIN=010 TH

14、EN NS=S5; -输入2元则下一状态为S5; ELSIF CIN=101 THEN NS=S0; -输入5元则下一状态为S0; ELSE NSMONEY=100;Y0=1;Y1=0;PAYBACK=000;-S4状态:输入总金额为4元,余额为0元,有商品输出信号,没有余额输出信号 IF CIN=001 THEN NS=S1; -输入1元则下一状态为S1; ELSIF CIN=010 THEN NS=S2; -输入2元则下一状态为S2; ELSIF CIN=101 THEN NS=S5; -输入5元则下一状态为S5; ELSE NSMONEY=101;Y0=1;Y1=1;PAYBACK=001;-S1状态:输入总金额为5元,余额为1元,没有商品输出信号,没有余额输出信

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论