病房呼叫系统控制器的FPGA实现(共26页)_第1页
病房呼叫系统控制器的FPGA实现(共26页)_第2页
病房呼叫系统控制器的FPGA实现(共26页)_第3页
病房呼叫系统控制器的FPGA实现(共26页)_第4页
病房呼叫系统控制器的FPGA实现(共26页)_第5页
已阅读5页,还剩22页未读 继续免费阅读

下载本文档

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

文档简介

1、精选优质文档-倾情为你奉上病房呼叫系统控制器的FPGA实现摘 要病房呼叫系统控制器,是为患者与医护人员构建的一座连接桥梁,是患者在医护人员远离病房时向医护人员发出求救信号的一种新型的仪器。在比较了各种设计方法的基础上,最终采用模块化设计、VHDL语言与原理图相结合的方法来完成这次设计,从而实现病房呼叫系统控制器的功能。 本次设计通过运用硬件描述语言VHDL设计病房呼叫系统控制器,开始介绍了病房呼叫系统控制器的研究内容、创新点、设计原理、基本组成与功能的具体实现。然后将病房呼叫系统控制器分成各个功能模块,通过编写各个模块代码程序并编译仿真验证其功能,并将达到设计要求的各个模块连接在一起,完成我们

2、的顶层文件设计。通过在试验箱上测试,发现完全符合我们的设计要求。关键词:病房呼叫;系统;现场可编程门阵列;模块;超高速集成电路硬件描述语言Implementation of Ward Calling System Controller Based on FPGAAbstractWard calling system controller, is for patients and medical staff to build a bridge to connect, is patients to medical staff in medical staff from the ward sent

3、a distress signal a new type of instrument. In comparison of the various design methods, on the basis of using modular design, VHDL language and the method of combining the principle diagram to finish the design, so as to realize the function of ward calling system controller.The design by using VHD

4、L hardware description language design ward calling system controller, began to introduce the research content of the ward calling system controller, innovative, design principle, basic composition and function of the specific implementation. Then ward calling system controller is divided into vario

5、us functional modules, each module by writing code and compile the simulation verify its function, and will meet the design requirements of various modules together, do we design the top of the file. Through the test in the test chamber, found fully meet our design requirements.Keywords: Ward callin

6、g, system, FPGA, Modules, VHDL专心-专注-专业目 录1 引言1.1 设计背景随着科学技术的发展人类社会迎来了信息时代的到来,信息时代依托电子工业、计算机技术的快速发展,电子工业的发展以EDA技术为核心1。EDA技术经过20多年的发展,设计方法已经基本成形,能满足日常生活中的大部分设计要求,为人类生活创造便利2。它集中了各大编程语言典型的优点,形成了其特有的由底层到顶层进行模块化设计的方法,为这次设计提供了技术上的支持。1.2 QUARTUS II与VHDL语言简介QUARTUS II是的综合性CPLD/FPGA开发,支持原理图、VHDL、VerilogHDL等多种

7、设计输入形式,可以通过加载第三方工具来完成设计,应用面较为广泛3。因QUARTUS II自带的仿真功能,它可以提前进行系统设计,加载到试验箱上进行验证,逐步调试改进,使设计的系统满足日常生活需要,再投入生产,推广上市4。而VHDL作为一门硬件描述语言,语言本身相对其它编程语言而言,相对简单一些,容易上手;它的库文件相当强大,并且调用时几乎不会消耗资源;它与数字电路联系比较密切,建立在数字电路的基础上,能轻松的完成各类复杂电路的设计。2 病房呼叫系统控制器的设计2.1 研究目的随着经济的不断发展,人们越来越忙碌,对健康逐渐忽视,疾病也悄悄来临,病号也越来越多,传统的病房呼叫系统由于效率低,处理慢

8、,许多病人也不能够得到及时、有效的治疗,使得病情越来越严重,医生处理起来容易错乱5。对于医院也会有经济效益损失,并伴有一定安全隐患。在FPGA的基础上,开发出病房呼叫系统控制器,能够有效提高患者就诊速率,让人们有病及时可医。开发一款新型的病房呼叫系统就显得极为迫切!2.2 论文研究内容及创新点本设计由锁存器、数据选择器、显示器等部分组成,考虑到系统的功能较复杂,所以采用分块设计的模式6。先设计好底层各模块,再到顶层进行综合,然后在实验箱上进行病房呼叫系统控制器的模拟验证。通过VHDL语言完成模块文件设计,然后将各模块整合起来实现系统功能7。用VHDL语言设计创新点如下:1.可以通过仿真来模拟现

9、实仪器,不需要在设计时就开始做出成品实物;2.语言运用灵活,可在各种进程间相互调用,设计思路清晰;3.通过数字电路设计就可实现仪器功能,不同于传统的单片机设计;4.支持多人的并行设计,适合团队合作,分工设计。3 病房呼叫系统控制器的实现3.1 设计原理 在优先级顺序为1-8的病房里分别设置一个呼叫医护人员的按钮,在试验箱上用8个拨位开关来模拟,拨位开关指示灯亮表示病房患者有求助信号,拨位开关指示灯灭表示病房患者无求助信号。在医护人员的办公室里设置1-8个对患者产生应答的开关按钮,在试验箱上也用8个拨位开关来模拟,拨位开关指示灯亮表示医护人员无应答信号,拨位开关指示灯灭表示医护人员有应答信号。病

10、房和医护室里都有LED提示灯,有应答后,灯灭,提示患者有医护人员即将来病房,提示之后的医护人员,有医护人员已经去相应的病房,在试验箱上用8个连续的LED灯表示。在显示时,要按照优先级1-8号病房的顺序进行显示,并且显示该病房患者自发出求助信号的等待时间。在该时间为1-9秒时,喇叭发出持续9秒的提示声;等时间过完3分钟后,在3分1-9秒喇叭再次发出持续9秒的提示声,以达到提醒医护人员的作用,完成这次设计。3.2 病房呼叫系统控制器的原理图 图3-1 病房呼叫系统原理图病房呼叫系统控制器原理图如图3-1所示,通过各功能模块系统的组合形成整体结构原理,完成整个控制器的功能实现。3.3 模块的划分1.

11、锁存器模块,通过对病房患者的呼出信号与医护人员的应答信号作对比,得出无应答的病房状态并存储下来; 2.数据选择器模块,在无应答的病房状态中,按顺序1-8选出优先级更高的病房号;3.时间选择器模块,根据无应答且优先级高的病房号来确定相对应的时间显示,并制造一个用来计时的控制端; 4.计时器模块,接收到计时的控制信号,开始计时; 5.显示器模块,用来控制数码管显示病房号和时间; 6.连接器模块,连接计时器和蜂鸣器,使喇叭能根据时间来发声; 7.蜂鸣器模块,模拟现实中的喇叭,以发出警告声。 3.4 系统各功能模块的实现3.4.1 锁存器模块 图3-2 锁存器模块该模块要满足对8个病房呼出与应答信号的

12、判定,设置8位的输入信号sin7.0,当每一位上产生高电平时,由低位到高位分别代表1-8号病房患者发出了求助信号。类似的设置了8位代表医护人员应答的信号rest7.0,但是它每一位上的电平为低时,代表应答信息。由这两路输入每一位相互判定,就可得到每个病房无应答的存储信息,并将其与LED灯相连,当无医护人员应答时,LED灯亮,应答后灭,完成锁存器的设计。3.4.2 数据选择器模块图3-3 数据选择器模块当不同病房的患者都发出求助信号时 ,数据选择器接收由锁存器传输过来的存储值,即sout17.0,它哪一位为高,由低位到高位分别代表1-8号病房无医护人员应答。再根据由低位到高位的顺序,设置优先级输

13、出,从而可以判定当前需要显示的病房号(这里用到BCD码相关知识)9。且使该模块产生两路输出,均为当前显示的病房号。分别传输给时间选择器模块和显示模块,达到对时间选择和显示的目的8。进而达到对病房号进行优先选择的功能,完成对数据选择器的设计。3.4.3 时间选择器模块复位是用来模拟应答信号的,要使复位起作用,它需要和锁存器及时间选择器都相连,以达到在病房产生呼叫信号且无应答时,能够控制时间显示,在有应答时,停止计时。时间选择器要能够控制时间显示的是病房患者等待救护的时间,因此将它加到计时模块的前面,以实现这一功能。锁存器将其存储的无应答信号通过数据选择器,产生一个对当前显示的病房号的独立的复位信

14、号,还产生了一个控制计时器对当前最高优先级且无应答的病房号进行计时的启动端,因此实现了时间选择的目的。图3-4 时间选择器模块3.4.4 计时器模块图3-5 计时器模块设计要求计时用四个数码管显示当前最高优先级病房的等待时间,时间精确到秒,所以时间采用的是以秒进位。由于有求助信号sp=1,也即计时的控制端。当sp=1,计时器开始工作,实验箱中的时钟频率可设置为4Hz,所以每出现四个上升沿时,时间立刻加计1s。左边的两个数码管分别代表分的十位和个位,右边两个数码管分别代表秒的十位和个位。 3.4.5 显示器模块图3-6 显示器模块该模块要显示最高优先级且无医护人员应答的病房号及该病房等待医护人员

15、来临的时间。为了实现这一功能,将试验箱上的第8个数码管用来显示病房号, 第5、4和2、1个数码管用来分别显示时间的分和秒,第3个数码管显示一横杠,方便读出当前的等待时间10。一共用到6个数码管,clk1接65536Hz,配合ledcs2.0实现位选,使6个数码管能够同时显示。disp6.0为段选信号,使得数码管能以10进制数在数码管上显示。3.4.6 连接器模块图3-7 连接器模块在由底层到顶层进行电路设计时,为了使蜂鸣器模块根据时间来发出警告声,加入了一个连接模块,喇叭通过该模块判定具体时间而发声。连接模块接收到时间模块的时间信息后,将所有时间信息整合,作为输出加到蜂鸣器作为输入,从而控制喇

16、叭发声。其中,连接器输出端的高四位和次高四位分别代表秒的个位和十位,中四位和低四位分别代表分的个位和十位。3.4.7 蜂鸣器模块图3-8 蜂鸣器模块因无应答,当前产生呼叫信号且最高优先级的病房在计时后开始发出9秒的提示声以及灯亮3分钟后进行持续9秒的警告声,蜂鸣器模块是根据时间来发出警告声的,所以它必须通过连接器才能根据时间来发出警告声。当bcd15.0的高四位为0001相当于时间过去1秒,为0010相当于时间过去2秒,同理可得其它时间。在时间为19秒时试验箱上的喇叭开始发出警告声,给喇叭两个不同的频率,声音强弱交替,来模拟急救声。(clk2、clk3交替输出,持续9秒,若输出为低电平,无法达

17、到警告的条件,声音太小)。 在时间为9秒到3分钟这个时间段时,喇叭休息。在时间为3分零1-9秒时,喇叭发出持续9秒的报警声。4 病房呼叫系统控制器的仿真及分析4.1 锁存器图4-1 锁存器波形图波形分析:如图4-1所示,sin7.0代表相应病房的呼叫信号,高电平代表病房有呼叫信号,低电平代表没有呼叫信号;rest7.0代表呼叫信号对应的应答信号,低电平代表对应病房的呼叫信号有应答,高电平代表对应病房的呼叫信号没有应答;sout17.0、sout27.0每位上若存在高电平,对应的是该病房没有应答。当2号和3号病房有呼叫时,由于有应答,所以sout11,sout22在rest1、rest2复位后,

18、会输出复位后的波形,也即图中复位后的波形。而5号病房发出呼叫信号(即sin4=1),因为没有应答,所以sout14在发出呼叫信号的那一刻,一直会是高电平。4.2 数据选择器图4-2 数据选择器波形图波形分析:如图4-2所示,sout1、sout3、sout5分别对应2、4、6号病房,数据选择器是对无应答的病房根据1至8的优先级进行选择的,you1、you2指的是无医护人员应答并且优先级最高的病房号,因此输出的结果为2,即2号病房。4.3 时间选择器波形分析:如图4-3所示,rest7.0代表呼叫信号对应的应答信号,you1代表当前无医护人员应答的最高优先级病房号,为了进行波形仿真,这里的输入端

19、设置的和锁存器及数据选择器的输出端一致,you1当前值2,输出lj为下一个模块提供复位输入,输出zq为下一个模块提供计时控制端。图4-3 时间选择器波形图4.4 计时器图4-4 计时器波形图波形分析:如图4-4所示,仿真波形中用的是4分频,之所以用四分频,是为了在实验当中可以通过适当改变频率,以加快实验进度,方便采集实验数据。该图中4个脉冲周期为1秒,每次采集到4个上升沿,时间秒的个位加1,每60秒分的个位加1,以此类推。在正常试验中,clk取4Hz,模拟现实中的1秒。此图是在计时器的启动输入端为高电平,且复位高电平(复位未工作)的情况下,也即无医护人员应答,计时器开始计时,直到病房有相应的应

20、答,开始对下一个最高优先级的病房进行计时。4.5 显示器图4-5 显示器波形图波形分析:如图4-5所示,试验箱中所用的是共阴极七段数码管,观察图中ledcs2.0的变化,当ledcs2.0=111时(第8个数码管),数码管显示,对应的就是2,即2号病房,与当前最高等待应答的病房号是一样的。第六个和第七个数码管未显示,即这两个数码管灭,因此输出为。当前等待时间为0,没有作任何设置 ,因此第1、2、4、5个数码管显示的都是零。第3个数码管显示的是,即一横杠。4.6 连接器波形分析:如图4-6所示,当second13.0、second23.0、minitue13.0、minitue23.0分别为00

21、10、0101、0000、0000时,jishi15.0输出00000;当second13.0、second23.0、minitue13.0、minitue23.0分别为0011、0001、0100、0000时,jishi15.0输出00000,以此类推,从而达到将时间模块与蜂鸣器模块连在一起的效果。图4-6 连接器波形图4.7 蜂鸣器图4-7 蜂鸣器波形图波形分析:如图4-7所示,在当前等待时间为1-9秒时,蜂鸣器工作;在当前等待时间为10秒到3分钟时,蜂鸣器不工作;在当前等待时间为3分钟零1秒到9秒时,蜂鸣器工作。警告时间持续9秒,用强弱交替的声音来模拟救护车的急救信号,在实验验证时,警告

22、声相当理想。这里在仿真时,当前等待时间的第10秒至3分钟之间没有加入到输入端,这一段蜂鸣器没有工作,为了截图和波形分析方便,因此将这一段省略。4.8 整体仿真图4-8 整体仿真波形图波形分析:如图4-8所示,当sin2为高电平,sin7.0的其他位均为低电平且当前呼叫信号无医护人员应答时,第8个数码管对应的是,因为数码管是共阴极的,所以结果为3,即当前等待应答的病房号为3号病房。在等待时间为1-9秒时,蜂鸣器发出警告声;在医护人员应答后,病房号不再显示。5 锁定管脚及硬件实现5.1 锁定管脚图在验证病房呼叫系统控制器的功能之前,需要清楚实验箱与各个信号之间的对应关系,参照资料得出本设计中各引脚

23、的对应情况,如图5-1、5-2。图5-1 系统输入锁定管脚图图5-2 系统输出锁定管脚图5.2 硬件实现如图5-3所示,当6号病房有呼叫信号时,6号病房对应的LED灯亮,因无应答信号,数码管开始计时,图中已经计时到1分47秒,数码管显示病房号为6。如图5-4所示,当6号病房有呼叫信号时,6号病房对应的LED灯亮,此时3号病房也有呼叫信号,因3号病房优先级更高,所以数码管显示病房号是3。因无应答信号,数码管开始计时,图中已经计时到26秒。如图5-5所示,因3号病房有医护人员应答,3号病房对应的LED灯灭,开始显示下一个最高优先级的无应答的病房号,从而数码管显示的病房号是6,图中已经计时到27秒。

24、1号病房8号病房等待时间病房号 病房呼叫信号1-8 病房应答信号1-8图5-3 实验箱现象病房号8号病房1号病房等待时间 病房呼叫信号1-8 病房应答信号1-8图5-4 实验箱现象8号病房1号病房等待时间病房号 病房呼叫信号1-8 病房应答信号1-8图5-5 实验箱现象下载完成后,将第一全局时钟CLK1的跳线器接:4Hz(作为秒脉冲信号),将第二全局时钟CLK2的跳线器接65536Hz(作为位选信号),将第三全局时钟CLK3的跳线器接1024Hz(用来驱动喇叭),用拨位开关模拟控制病房的呼叫、应答。观察数码管上数据的变化看是否符合设计标准。在试验箱上第1-2个数码管显示等待时间的秒位,第3个数

25、码管显示一横杠,第4-5个数码管显示等待时间的分位,第6-7个数码管不显示,第8个数码管显示病房号。6 设计总结一开始设计病房呼叫系统控制器并不知道从何入手,对VHDL这门语言也不是很了解,虽然之前有学过,但是时间过去较长,已经不是很会使用了。于是我开始又重新学习这门语言,由于自己之前有些编程基础,学起来比较快。再加上自己学过的一些数字电路的基础知识,开始设计思路就慢慢清晰了。在15天高强度的工作后,设计基本完成。通过对每一模块的仿真和下载,测试是否满足设计要求。在病房呼叫系统控制器的7个模块中,重点在于锁存器模块(suocunqi),数据选择器模块(shuju),时间选择器模块(shijia

26、n),计时器模块(time)、显示器模块(display)、连接器模块(lianjie)、蜂鸣器模块(fengming)。至此,病房呼叫系统控制器的设计已全部完成,能按预期的效果进行模拟病房的呼叫、应答、警告等功能,由数码管显示病房号、等待时间。在等待时间里,等待医护人员应答,应答后,开始下一个最高优先级病房等待时间计时。为了使警告声音达到最好的效果,经过多次频率调试,蜂鸣器的频率设置为1024Hz,并且接入强弱交替的频率,用来模拟医院的救护声。但是该设计是有缺陷的,在多个病房患者发出呼叫信息时,且无应答的情况下,当最高优先级的病房有应答,再显示此时最高优先级的病房时,等待时间是从零开始计时的,并没有做更深层次的挖掘。以目前所学的知识,要使设计更完美,预计所用时间至少是现在的2倍,时间不允许,没有继续深入。也进行过深层次的设计,短期内无法完成,因而中

温馨提示

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

评论

0/150

提交评论