1数字系统设计大作业题目:电梯控制器姓名:温庆学号:031241214班级:0312412指导老师:黄双林2目录摘要..............................................................3正文...............................................................41设计目的及要求....................................................42设计原理..........................................................42.1设计实现原理...............................................42.2项目分块及其实现方案.........................................62.3电梯控制器的流程图...........................................73设计内容..........................................................83.1基本状态设计.................................................83.2模块设计.....................................................93.3波形仿真....................................................10总结与致谢........................................................14参考文献..........................................................15附录..............................................................163摘要电梯作为垂直方向的交通工具,在高层建筑和公共场所已成为不可或缺的设备。中国是全球最大的电梯市场,也具有最强的电梯生产能力,但由于缺乏自主知识产权和核心技术,自主品牌占市场的份额很少。因此要加大对电梯技术的创新和发展,提升电梯的性能,就需要引进更好的技术,电梯控制器就是很好的装置,大力开发控制器是很必要的。电梯的微机化控制主要有以下几种形式:PLC控制;单片机控制;单板机控制;单微机控制;多微机控制;人工智能控制。本次课程设计采用了EDA技术进行操作EDA技术打破了软件和硬件间的壁垒,使计算机的软件技术与硬件实现、设计效率与产品性能合二为一,它代表了电子设计技术和应用技术的发展方向。本设计采用VerilogHDL语言的编程技术,源程序Altera公司的QuartusII软件仿真。关键字:EDA技术;VerilogHDL语言;QuartusII软件4正文1设计目的及要求1、进一步巩固理论知识,培养所学理论知识的在实际中的应用能力;掌握EDA设计的一般方法;熟悉一种EDA软件,掌握一般EDA系统的调试方法;利用EDA软件设计一个电子技术综合问题,培养VerilogHDL编程、书写技术报告的能力。为以后进行工程实际问题的研究打下设计基础。2、设计一个6层电梯控制器电路,用数码管显示电梯所在楼层号,电梯初始状态为第一楼层;每楼层电梯外都有上、下楼请求开关,电梯内设有乘客到达楼层的请求开关、电梯所处楼层、上升模式及下降模式的指示;电梯每2秒升降一层,到达有停站请求的楼层后,经4秒电梯门打开,开门指示灯亮,开门4秒后,指示灯灭,关门,关门时间3秒,电梯继续运行。可以通过快速关门和关门中断信号控制;能记忆电梯内外的请求信号,当电梯处于上升模式时,只响应比电梯所在位置高的楼请求信号,直到最后一个上楼请求执行完毕,再进入下降模式。2设计原理2.1设计实现原理根据系统设计要求,并考虑到系统的可检验性,整个系统的输入输出接口设计如图1所示:系统工作用2Hz基准时钟信号CLKIN,楼层上升请求键UPIN,楼层下降请求键DOWNIN,楼层选择键入键ST_CH,提前关门输入键CLOSE,延迟关门输入键DELAY,电梯运行的开关键RUN_STOP,电梯运行或停止指示键LAMP,电梯运行或等待时间指示键RUN_WAIT,电梯所在楼层指示数码管ST_OUT,楼层选择指示数码管DIRECT。5图1.电梯控制器DTKZQ的输入输出接口图各输入端口的功能如下:CLKIN:基准时钟信号,为系统提供2Hz的时钟脉冲,上升沿有效;UPIN:电梯上升请求键。由用户向电梯控制器发出上升请求。高电平有效;DOWNIN:电梯下降请求键,由用户向电梯控制器发出下降请求。高电平有效;ST_CH[2..0]:楼层选择键入键,结合DIRECT完成楼层选择的键入,高电平有效;CLOSE:提前关门输入键。可实现无等待时间的提前关门操作,高电平有效;DELAY:延迟关门输入键。可实现有等待时间的延迟关门操作,高电平有效;RUN_STOP:电梯运行或停止开关键。可实现由管理员控制电梯的运行或停止,高电平有效。一下为输出端口:LAMP:电梯运行或等待指示键,指示电梯的运行或等待状况。高电平有效;RUN_WAIT:电梯运行或等待时间指示键,指示电梯运行状况或等待时间的长短,高电平有效;ST_OUT:电梯所在楼层指示数码管,只是电梯当前所在的楼层数。即1~6层,高电平有效;DIRECT:楼层选择指示数码管,指示用户所要选择的楼层数,高电平有效。DTKZQCLKINLAMPUPINDOWNINST_CH[1]RU_WAITCLOSEST_OUTDELAYDIRECTRUN_STOP62.2项目分块及其实现方案电梯的控制状态包括运行状态﹑停止状态及等待状态,其中运行状态又包含向上状态和向下状态。主要动作有开、关门,乘客可通过键入开、关门按键,呼唤按键,指定楼层按钮等来控制电梯的行与停。据此,整个电梯控制器DTLZQ应包括如下几个组成部分:①时序输出及楼选计数器;②电梯服务请求处理器;③电梯升降控制器;④上升及下降寄存器;⑤电梯次态生成器。该电梯控制器设计的关键是确定上升及下降寄存器的置位与复位。整个系统的内部组成结构图2所示。图2.电梯控制器的内部组成结构图电梯服务请求处理器时序输出及楼选计数器(DIR)DRECTCLKINUOINDOWNINST_CH电梯升降控制器(LIFTOR)DELAY电梯次态生成器(LADD)上升请求寄存器(UR)下降请求寄存器(DR)CLOSERUN_STOPLAMPRUN_WAITST_OUT7图3.电梯控制器系统框图2.3电梯控制器的流程图图4总流程图时钟CLK请求信号输入模块楼层请求超载超载关门中断提前关门清楚报警控制模块输出显示模块请求信号显示运行状态显示所在楼层显示门控制信号超载报警外部按键请求信号寄存器状态寄存器内部软件执行机构外部硬件执行机构初始化判定电梯运行方向是否有请求?等待电梯运行楼层检测目标层与本层是否同层?是否目标层?否否是是否是8图5电梯控制主流程图3设计内容3.1基本状态设计1、采用信号并置处理很多输入信号的方式:always@(call_up_1orcall_up_2orcall_up_3orcall_up_4orcall_up_5)up_all={1'b0,call_up_5,call_up_4,call_up_3,call_up_2,call_up_1};//将各下降请求信号实时地合并(1楼为底层,无下降请求,考虑到通用性,将第1位填零)always@(call_down_2orcall_down_3orcall_down_4orcall_down_5orcall_down_6)down_all={call_down_6,call_down_5,call_down_4,call_down_3,call_down_2,1'b0};//将各停靠请求信号实时地合并always@(request_1orrequest_2orrequest_3orrequest_4orrequest_5orrequest_6)request_all={request_6,request_5,request_4,request_3,request_2,request_1};2、通过参数定义把信号并置的方法和有限状态机联系起来parameterWAIT=7'b0000001,UP=7'b0000010,DOWN=7'b0000100,UPSTOP=7'b0001000,DOWNSTOP=7'b0010000,OPENDOOR=7'b0100000,电梯停止开门关门是否停止运行?停止是否9CLOSEDOOR=7'b1000000;//定义楼层的符号常量parameterFLOOR1=6'b000001,FLOOR2=6'b000010,FLOOR3=6'b000100,FLOOR4=6'b001000,FLOOR5=6'b010000,FLOOR6=6'b100000;parameterTRUE=1'b1,FALSE=1'b0;//定义门打开和门关闭的符号常量parameterOPEN=1'b1,CLOSED=1'b0;//定义电梯上升,下降和静止的符号常量parameterUPFLAG=2'b01,DNFLAG=2'b10,STATIC=2'b00;3、采用了七个状态实现了有限状态机图6.状态转换图黑线:WAITTOUPTOUPSTOPTOOPENDOORTOCLOSEDOORTOWAIT粉红线:WAITTODOWNTODOWNSTOPTOOPENDOORTOCLOSEDOORTOWAIT3.2模块设计1、电梯主控制器模块elevator_controller:此段智能电梯控制器由三个重要部分组成的。WAITUPUPSTOPDOWNOPENDOORDOWNSTOPCLOSEDOOR10(a)信号并置部分,完成对5路向上请求、5路向下请求、6路内部请求的信号并置,化繁为简。(b)三段式有限状态机部分。在有请求的情况下,电梯控制器还要根据电梯的当前状态和当前的楼层去判断电梯的下一步该如何运作。(c)计数器部分。完成电梯的开门、关门的时间管理。Parameter...Value...cp_50Mclkresetforbidcall_up_1call_up_2call_up_3call_up_4call_up_5call_down_2call_down_3call_down_4call_down_5call_down_6request_1request_2request_3request_4request_5request_6out[6..0]LiftState[6..0]over_alarmcount_out[6..0]count[2..0]elevator_controllerinst3图7.电梯主控模块2、分频模块frequence_div:这段分频器完成对50Mhz的1分频操作。采用传统的“一半就翻转”的计数技巧。cp_50Mcp_1frequence_divinst2图8.分频模块3、数码管译码模块3.3波形仿真1、当电梯处于初始状态时,电梯在高层有向下的请求时:11图92、当电梯停在6楼处于等待状态时,在1楼和2楼同时有向上的请求时:图10123、当电梯停在1楼处于等待状态时,在6楼和5楼同时有向下的请求时:图114、当电梯停在6楼时,有在5楼的向下的请求时,电梯应该先到五楼,电梯内部请求到1楼,如果电梯在下降的过程中,有在2楼的向上的请求时,电梯应该先相应内部请求,然后相应外部请求:图12135、电梯的强制运行按钮forbid:图1314总结与致谢通过本次课程设计进一步熟悉QuartusII软件的使用和操作方法,以及硬件实现时的下载方法与运行方法