eda洗衣机控制器.pdf

上传人:时光煮雨 文档编号:14383900 上传时间:2022-02-05 格式:PDF 页数:12 大小:784.96KB
返回 下载 相关 举报
eda洗衣机控制器.pdf_第1页
第1页 / 共12页
eda洗衣机控制器.pdf_第2页
第2页 / 共12页
eda洗衣机控制器.pdf_第3页
第3页 / 共12页
亲,该文档总共12页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《eda洗衣机控制器.pdf》由会员分享,可在线阅读,更多相关《eda洗衣机控制器.pdf(12页珍藏版)》请在三一文库上搜索。

1、课程EDA 技术课程设计题目洗衣机控制器专业电子信息工程姓名主要内容、基本要求、主要参考资料等主要内容:设计一个洗衣机控制器,要求洗衣机有正转、反转、暂停三种状态。设定洗衣机的工作时间,要洗衣机在工作时间内完成:定时启动正转 20秒暂停 10秒反转 20秒暂停 10秒定时未到回到 “ 正转 20秒暂停 10秒” ,定时到则停止,同时发出提示音。基本要求:1、设计一个电子定时器,控制洗衣机作如下运转:定时启动正转 20秒暂停 10秒反转 20秒暂停10秒定时未到回到“ 正转 20秒暂停 10秒” ,定时到则停止;2、若定时到,则停机发出音响信号;3、用两个数码管显示洗涤的预置时间(分钟数),按倒

2、计时方式对洗涤过程作计时显示,直到时间到停机;洗涤过程由“ 开始 ” 信号开始;4、三只 LED 灯表示 “ 正转 ” 、“ 反转 ” 、 “ 暂停 ” 三个状态。主要参考资料:1 潘松著 .EDA 技术实用教程(第二版 ). 北京:科学出版社,2005. 2 康华光主编 .电子技术基础模拟部分 . 北京:高教出版社,2006. 3 阎石主编 .数字电子技术基础. 北京:高教出版社,2003. 完成期限2011.3.11 指导教师专业负责人2011年 3 月 7 日一、总体设计思想1.基本原理从课程设计要求来看,要求实现电机的正传、反转、暂停,需要用LED 灯的状态来表示,当显示时间前20 秒

3、正传、暂停10 秒、反转 20 秒、再暂停 10秒,如此一来,周期恰好是60 秒。洗衣机控制器的设计主要是定时器的设计。由一片 FPGA 和外围电路构成了电器控制部分。FPGA 接收键盘的控制命令, 控制洗衣机的进水、排水、水位和洗衣机的工作状态、并控制显示工作状态以及设定直流电机速度、正反转控制、制动控制、起停控制和运动状态控制。对芯片的编程采用模块化的VHDL ( 硬件描述语言 )进行设计,设计分为三层实现,顶层实现整个芯片的功能。顶层和中间层多数是由VHDL 的元件例化语句实现。中间层由无刷直流电机控制、运行模式选择、洗涤模式选择、定时器、显示控制、键盘扫描、水位控制以及对直流电机控制板

4、进行速度设定、正反转控制、启停控制等模块组成,它们分别调用底层模块。从秒脉冲出来的信号,经过一个控制电路后进入秒计数器进行秒计数,进行清零,这时用户置入洗涤时间,并按开始按钮,洗衣机开始工作。当秒计数器变为零的时候,去分钟计数器上面借数;与此同时,从十秒位转化出来的信号进入移位寄存器后, LED 灯表示出电机运转状态;当用户设定的洗涤时间结束后,电路报警并清零;同时电机指示灯熄灭。2.设计框图首先开始启动,按照指令要求先正转20 秒,然后暂停10 秒,接着反转20秒,暂停 10 秒,如果定时时间没有达到依次进行以上操作。倘若定时时间达到就停止以上操作,停止运行。定时启动正转 20s 暂停 10

5、s 反转 20s 暂停 10s 定 时 到停止定时时间未到二、设计步骤和调试过程1、总体设计电路洗衣机控制器电路主要有五大部分组成,包括:减法计数器、 时序控制电路、预置时间和编码电路、数码管显示、译码器组成。2、模块设计和相应模块程序数码管显示实现数码管显示Library iee; Use ieee.std_logic_1164.all; Entity encode is Port( Bcd : in std_logic_vector(3 downto o); A,b,c,d,e,f,g: out std_logic ); End encode; Architecture rtl of en

6、code is Signal temp:std_logic_vector(6 downto 0); Begin Table Bcd = temp; 0000= 1111110; 0001= 01100000010= 11011010011= 11110010100= 01100110101= 10110110110= 10111110111= 11100001000= 11111111001= 1111011 End table; a=temp(6);b=temp(5);c=temp(4);d=temp(3);e=temp(2);f=temp(1); g=temp(0); end rtl;时序

7、电路Library ieee; Use ieee.std_logic_1164.all; Use ieee.std_logic_unsigned.all Entity shixu is Port(cp,en,rd:in std_logic; Q1,q2:out std_logic); End shixu; Architecture rtl of shixu is Begin Process(cp) Variable wash_time:integer range 0 to 19; Variable wash_time:integer range 0 to 9; Variable state:s

8、td_logic; Variable wash_time:integer :=21; Variable wash_time:integer :=9; Begin If(en= 0)wash_time:= 19;wait_time:=9;state:=0; End if;if(en=0)then wash_time:=21;Q1=0;Q20) Then wash_time:=20;state:=not state; End if; end if; end if; If(wash_time=0)then Q1=0;Q2=0;else if (state=0) Then Q1= 1;Q2=0; el

9、se Q1= 0;Q2=1; End if; end if; Else Q10 and start=1) then time_second:=time_second-1; else time_second:=59; end if; if(start=0) then time_remain0) then time_remain(3 downto 0)=time_remain(3 downto 0)-start; time_remain(3 downto 0)0) then time_remain(7 downto 4) =time_remain(7 downto 4)-start; time_r

10、emain(7 downto 4)=time_remain(7 downto 4)-1; time_remain(3 downto 0)=1001;time_second:=59;end if; end if; else if (time_second=0 and time_second=1) if(time_remain=0)then time_is_up=0;else time_is_up=1; time_second:=time_second-1;end if;end if;end if; end if;end process; end rtl; 译码器library ieee; use

11、 ieee.std_logic_1164.all; entity decoder is port( Q1,Q2: in std_logic; REV,RUN,PAUSE: out std_logic );end decoder; architecture rtl of decoder is signal choose:std_logic_vector(1 downto 0); begin choose(1)=q1;choose(0)REV=0;RUN=0;PAUSEREV=0;RUN=1;PAUSEREV=1;RUN=0;PAUSEREV=0;RUN=0;PAUSE=0; end case;

12、end process; REV=Q2;RUN=Q1;PAUSE=not(Q1 OR Q2); end rtl; 3、仿真及仿真结果分析仿真信号图如下:仿真图4、实验调试结果洗衣机接通电源,按load 设置洗涤时间按start 、rd 置为高电平洗衣机开始工作,当时钟第一个上升沿到达时run(正转功能)为高电平维持20s 以后变为低电平而 pause (暂停功能) 随着时钟上升沿的到来变为高电平维持10s变为低电平,然后 rev(反转功能)开始随着时钟上升沿的到来变为高电平工作维持20s 后变为低电平,再停止pause 置高,接下来电路一直重复上述工作,知道定时器计数结束。电路设计完成以后,按

13、照预定设计,输入相应数据,三只LED灯按照设定时间规律间断性亮起,表示 “ 正转” 、“ 反转” 、“ 暂停” 三个状态。数码管也显示输入时间并按减数计时产生相应的数字显示,直到到达预定时间停止工作显示零,实验设计达到预期效果。三、结论及心得体会通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正地更好去理解知识,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,可以说得是困难重重,这毕竟是我第一次做有关于EDA 方面的设计,难免会遇到过各种各样的问题,首先是程序编写上有很多难点,其次

14、是软件的使用以及仿真是存在的操作失误等等,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。此次课程设计,学到了很多课内学不到的东西,比如独立思考解决问题,出现差错的随机应变。让我能够对以前学过的知识进行一遍复习并且更深一步的了解。参考资料1 潘松著 .EDA 技术实用教程 (第二版 ). 北京:科学出版社 ,2005. 2 章彬宏 .EDA 应用技术 .北京:北京理工大学出版社,2006 3 罗中华杨戈.EDA 与可编程实验教程 .重庆:重庆大学出版社,2005 4 刘艳萍李志军 高振斌 EDA 实用技术及应用 .北京:国防工业出版社 .2005 5 周立功EDA 实验与实践 .沈阳

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1