




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
东北石油大学课程设计课 程 EDA技术课程设计题 目 洗衣机控制器 院 系 电子科学学院 专业班级 电子信息工程 学生姓名 学生学号 指导教师 2014年3月7日东北石油大学课程设计任务书课程EDA技术课程设计 题目洗衣机控制器 专业 学号 主要容、基本要求、主要参考资料等主要容:设计一个洗衣机控制器,要求洗衣机有正转、反转、暂停三种状态。设定洗衣机的工作时间,要洗衣机在工作时间完成:定时启动T正转20秒T暂停10秒T反转20秒T暂停10秒T定时未到回到“正转20秒T暂停10秒T ",定时到则停止,同时发出提示音。基本要求:1、 设计一个电子定时器,控制洗衣机作如下运转:定时启动T正转20秒T暂停10秒T反转20秒T暂停10秒T定时未到回到“正转20秒T暂停10秒T ",定时到则停止;2、 若定时到,则停机发出音响信号;3、 用两个数码管显示洗涤的预置时间(分钟数),按倒计时方式对洗涤过程作计时显示,直到时间到停机;洗涤过程由“开始”信号开始;4、 三只LED灯表示“正转”、“反转”、“暂停”三个状态。主要参考资料:松著.EDA技术实用教程(第二版).:科学,2005.康华光主编.电子技术基础模拟部分.:高教,2006.阎石主编.数字电子技术基础.:高教,2003.完成期限 指导教师 专业负责人 2014年3月3日一、设计思想1.基本原理洗衣机控制器的设计主要是定时器的设计。由一片FPGA和外围电路构成了电器控制部分。FPGA接收键盘的控制命令,控制洗衣机的进水、排水、水位和洗衣机的工作状态、并控制显示工作状态以及设定直流电机速度、正反转控制、制动控制、起停控制和运动状态控制。对芯片的编程采用模块化的VHDL(硬件描述语言)进行设计,设计分为三层实现,顶层实现整个芯片的功能。顶层和中间层多数是由VHDL的元件例化语句实现。中间层由无刷直流电机控制、运行模式选择、洗涤模式选择、定时器、显示控制、键盘扫描、水位控制以及对直流电机控制板进行速度设定、正反转控制、启停控制等模块组成,它们分别调用底层模块。2.设计框图图1设计框图用两位数码管预置洗涤时间(分钟数),洗涤过程在送入预置时间后开始运转,洗涤中按倒计时方式对洗涤过程作计时显示,用LED表示电动机的正、反转,如果定时时间到,则停机并发出音响信号。二、设计步骤和调试过程1、模块设计和相应模块代码洗衣机控制器电路主要有五大部分组成,包括:减法计数器、时序控制电路、预置时间和编码电路、数码管显示、译码器组成。(1)预设时间和编码电路:本模块将输入的四位时间信号编码成八位二进制数输出到减法计数器电路。libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entitysettimeisport(load:instd_logic;time_input:instd_logic_vector(3downto0);time_set:outstd_logic_vector(7downto0));endsettime;architecturesettimeofsettimeissignalp1:std_logic_vector(7downto0);beginprocess(load)beginif(load'eventandload='1')thencasetime_inputiswhen"0000"=>pl〈二"00000000";when"0001"=>pl〈二"00000001";when"0010"=>p1〈二"00000010";when"0011"=>p1<="00000011";when"0100"=>p1<="00000100";when"0101"=>p1<="00000101";when"0110"=>p1<="00000110";when"0111"=>p1<="00000111";when"1000"=>p1<="00001000";when"1001"=>p1<="00001001";whenothers二〉p1〈二"00000000";endcase;endif;endprocesstime_set<二p1;endsettime;tpMmitaBTm Dgn 丄皿帀 bfilnrri 749m: ftari! End图2预设时间和编码仿真用K1、K2、K3、K4给time_input输入一个二进制数0111,让load有效,输出time_set为00000111。减法计数器模块:由于洗衣机有工作时间,必须要一模块来控制它的工作时间围,当洗衣机开始工作后,减法计数器即会实现减数功能,直到时间减到零,洗衣机便停止工作。当出现系统运行结束信号time_over时,蜂鸣器报警洗衣机工作结束。libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entitycounterisport(clk,start:instd_logic;time_set:instd_logic_vector(7downto0);time_remain:bufferstd_logic_vector(7downto0);time_over:bufferstd_logic);endcounter;architecturecounterofcounterisbeginprocess(clk)variabletime_second:integerrange0to59:=59;beginif(clk'eventandclk='1')thenif(start='0')thenif(time_remain(7downto0)=0)thentime_remain<=time_set;elsetime_remain(7downto4)<=time_remain(3downto0);time_remain(3downto0)<=time_set(3downto0);endif;time_second:=59;time_over<='1';elseif(time_over='1')thenif(time_second=0andtime_remain(7downto0)=0)thentime_over<='0';elseif(time_second=0)thenif(time_remain(3downto0)=0)thentime_remain(7downto4)<=time_remain(7downto4)-1;time_remain(3downto0)<="1001";time_second:=59;elsetime_remain(7downto4)<=time_remain(7downto4);time_remain(3downto0)<=time_remain(3downto0)-1;time_second:=59;endif;elsetime_second:=time_second-1;endif;endif;endif;endif;endif;endprocess;
endcounter;(3)数码管显示模块:根据课程设计要求,必须将洗衣机的工作状态及工endcounter;(3)数码管显示模块:根据课程设计要求,必须将洗衣机的工作状态及工作时间在数码管和指示灯上显示出来,此模块是用来控制洗衣机的工作状态及工作的频率,并把工作状态及工作时间显示出来。a,b,c,d,e,f,g分别对应数码管的七段,minute和second分别位选两个数码管,显示十位和个位。libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entityshowtimeisport(time_remain:instd_logic_vector(7downto0);clk:instd_logic;minute,second:outstd_logic;a,b,c,d,e,f,g:outstd_logic);endshowtime;architectureshowtimeofshowtimeissignaltemp:std_logic_vector(6downto0);signalbcd:std_logic_vector(3downto0);signalchoose:std_logic;beginprocess(clk)beginif(clk'eventandclk='1')thenchoose<=notchoose;if(choose='1')then
minute<='0';second<='1';bcd<=time_remain(7downto4);elseminute<='1';second<='0';bcd<=time_remain(3downto0);endif;endif;endprocess;process(bcd)
casebediswhen"0000"=>temp<="1111110";when"0001"=>temp<="0110000";when"0010"=>temp<="1101101";when"0011"=>temp<="1111001";when"0100"=>temp<="0110011";when"0101"=>temp<="1011011";when"0110"=>temp<="1011111";when"0111"=>temp<="1110000";when"1000"=>temp<="1111111";when"1001"=>temp<="1111011";whenothers=>temp<="1111011";e<=temp(2);endcase;e<=temp(2);a<=temp(6);b<=temp(5);c<=temp(4);d<=temp(3)f<=temp(1);g<=temp(0)endprocessendshowtime图4数码管模块仿真(4)时序电路模块:接收运行起止信号,安排电机运行状态并编码输出libraryieee;useieee.std_logic_1164.all;useieee.std_logic_unsigned.all;entityanalyseisport(clk,start,time_over:instd_logic;
out_1,out_2:outstd_logic );endanalyse;architectureanalyseofanalyseisbeginprocess(clk)variablestate:std_logic;variablewash_time:integer:=0;variablewait_time:integer:=0;if(clk'eventandclk='1')thenif(start='0')thenwash_time:=0;wait_time:=0;state:='0';out_1<='0';out_2<='0';elseif(time_over='1')thenif(wash_time=20)thenif(wait_time=10)thenwash_time:=0;state:=notstate;elsewait_time:=wait_time+1;endif;elsewash_time:=wash_time+1;
wait_time:=0;endif;endif;if(wash_time=20)thenout_l〈二'0';out_2〈二'0';elseif(state='0')thenout_1<='1';out_2<='0';elseout_1<='0';out_2<='1';endif;endif;endif;endif;endprocess;endanalyse;■I755raSuit1M.Ikl=沏endprocess;endanalyse;■I755raSuit1M.Ikl=沏L-341fl d*SB W.pm 240pm 3BDau KDQm. m 如灯口匸 ■»□曰x 13?C11. 3m EDnn. BHDDklJajinnr『1th0□.--■AQAbaJKlirert图5时序电路模块仿真:(5)译码器模块:接收电机运行状态信号,译码后实时控制电机的正传、反转和暂停。libraryieee;useieee.std_logic_1164.all;entitymoveisport(out_1,out_2:instd_logic;REV,RUN,PAUSE:bufferstd_logic);endmove;architecturemoveofmoveissignalchoose:std_logic_vector(1downto0);beginchoose(1)<=out_1;choose(0)<=out_2;process(choose)begincasechooseiswhen"00"=>REV<='0';RUN<='0';PAUSE<='1';when"10"=>REV<='0';RUN<='1';PAUSE<='0';when"01"=>REV<='1';RUN<='0';PAUSE<='0';whenothers=>REV<='0';RUN<='0';PAUSE<='0';endcase;REV<=out_2;RUN<=out_1;PAUSE<=not(out_1orout_2);endprocess;endmove;图6译码器模块仿真:2、仿真及仿真结果分析当预置号时间,启动start,数码管显示预置时间,电机开始以正转=>暂停二〉反转二〉暂停为周期进行循环,一个周期正好费时一分钟,一个周期结束,数码管显示减一,依次循环,直至数码管显示时间为零,洗衣结束。EmL<sgaajw.l^lAFTFIEauaiuL<sgaajw.l^lAFTFIEnnnnnnjmnnRftnjmFirwwuwiAnnnflfliwnjMinnnffiuMuiinmnfuimmnwvwwinjmumuinnnnnjuinnjuinjuimnniUUZUXruuuurLirLrLrLJjnJtrLjnjiJijriruuTiJTJTULrLrLnLruiJUT_r_rurrLi_rLn_ri-Lr_rL~vr^-LrLn^_rm_n_rLrLrL7T_HJT_n_rLrLi LrLrLr_rUWWUUVUWVj"eUWLrLSrVi_rmPVvWLrLrLrL5rL严■ LrLrLrLrLrLrLrLrLrLrLTLn[•ill1isR9
■SV[•ill1isR9
■SV-i*rw4jTRnj^njuiJU^rirLrLn"LrvmjvirLrirLrLruuvirLrLrLnjirLriEirLrLrLrLrLrLruuuw.rinjirLrLrLrunrwLrLrLrvLrurLrLrLrLrLrLrLrurLrLrLrLrwwwuuirLrLrLrLrLrLrLrLrLjijnji■J…L图7总体仿真3、实验调试结果电路设计完成以后,按照预定设计,输入相应数据,三只LED灯按照设定时间规律间斷性亮起,数码管也显示输入时间并按减数计时产生相应的数字显示,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 松江区绩效管理办法
- 反洗钱渠道管理办法
- 新销售管理办法来了
- 水道镇河道管理办法
- 汽车直播间管理办法
- 台球房灯光管理办法
- 新客户导入管理办法
- 室内装修管理办法版
- 四川省工程管理办法
- 学校专业部管理办法
- 西北工业大学固定资产验收报告
- 六年级下册综合实践活动教学设计-我们的毕业季 全国通用
- 【课件】Unit+2Reading+for+writing+课件人教版(2019)选择性必修第四册
- 大学英语六级词汇表(全)含音标
- 历年农商行考试真题及答案(DOC)
- 2014红星美凯龙建材品类系列知识培训:卫浴篇
- 卫生部手术分级目录(2023年1月份修订)
- GB/T 9576-2013橡胶和塑料软管及软管组合件选择、贮存、使用和维护指南
- 神经康复学教学大纲
- 煤矿用防爆电气设备防爆检查标准培训课件
- 护士注册健康体检表下载【可直接打印版本】
评论
0/150
提交评论