12.1电梯控制器——文档记录

《数字逻辑》实验报告

实验名称

项目三 电梯控制器设计

一、实验目的

    设计一个多楼层的电梯控制器系统,并能在开发板上模拟电梯运行状态。可以利用按键作为呼叫按键,数码管显示电梯运行时电梯所在楼层,led灯显示楼层叫梯状态。

二、实验项目内容

本项目设计并完成了1.电梯的模拟逻辑控制

2.将电梯的运行状态显示在数码管上,包含电梯此时的运行状态(上升、下降与暂停)与当前电梯所处楼层;以及LED灯显示楼层叫梯状态

三、实验设计

参考信息楼电梯设计,电梯由内部与外部控制信号驱动,外部控制信号包含上升与下降,本设计中额外增添停止按钮;内部控制信号包含电梯的具体目标楼层。

故取四位拨码开关模拟目的地为不同楼层的信号,由此模拟为高度为4楼的电梯控制器;取三位按键模拟控制电梯上升、下降与暂停运行状态的按键;其中模拟按键需要进行消抖处理。

状态转移图为:

s,u,d分别代表此时电梯

四、实验过程或算法(关键步骤、核心代码注解等)

文件结构

顶层文件串联起对应的模块,消抖模块用于消除按键抖动,lift模块用于实现电梯的运行状态转换与楼层移动,并输出电梯此时的运行状态;show模块在数码管中显示电梯此时运行状态。

顶层文件:

Key表示三个控制电梯运行状态的信号,自高到低位分别为up,down与stop,通过消抖模块消抖后传入电梯模拟模块中;floor_call表示4个不同楼层里的叫楼情况,若呼叫电梯(或目的地为该楼),则相应位上的信号为1.并直接在led灯上显示出来。

按键消抖模块:

思路为设置多个信号记录按键的输入信号,如果在一定的时间内,检测到信号都相同,那么就可以认为按键在这一段时间内保持稳定,也就是稳定,认为可以使用此时记录的信号

信号声明:clk为系统时钟,rst为复位信号,call与call_real分别代表实际按键输入的信号以及最后输出的认为是按键稳定后的信号

此部分负责分频,产生一些短暂的延迟,在这些延迟后进行取样。

此部分设置三个寄存器,用来连续记录,目的就是实现检测输入的值是否稳定

最后输出就是,如果三个寄存器寄存的值都相同,那么就可以认为按键已经稳定

模拟电梯模块:

信号声明:

Clk为时钟信号,reset为复位信号,up,down,stop为电梯控制信号;状态声明中,s表示电梯此时运行状态为停止,u表示此时状态为上升,d表示此时状态为下降(之所以设置为4位是与floor信号统一,为了方便后续数码管显示此时电梯运行状态),floor为位宽为4的信号,采用独热编码,只保留1位为1,表示电梯此时停留在相应位的楼层上。

分频,模拟电梯实际运行速度。

判断是否可上行或下行。

电梯状态转移逻辑:

即复位时调回停止状态;处于停止状态时,根据控制使能信号进行状态变化;处于上升状态时,若当前楼层被呼叫,则进入停止状态,直到相应位上拨码开关关闭,即停止继续呼叫该层才会继续电梯移动,当到达最高层且该层无人呼叫时,则自动进入下降状态,回到第一层的位置;处于下降状态时与上升状态时基本一致,只是当处于最底层(1楼)时,不再进入上升状态,而是保持停止。

楼层转移逻辑:

在dclk分频时钟上升沿触发,即经历一段时间后改变楼层状态;复位时,回归第一楼;移动取决于电梯此时运行状态,采用移位的方式进行操作,可以保持floor寄存器中始终存在一位1。

Show模块:

五、实验过程中遇到的问题及解决情况(主要问题及解决情况)

如何完成电梯控制的逻辑设计?

解决情况:完全解决。

如何在数码管中显示电梯此时的运行状态(包含运行状况与当前楼层)?

解决情况:完全解决。

如何让电梯在闲置时自动进入最底层待机?

解决情况:完全解决。

六、实验结果及分析和(或)源程序调试过程

生成电路图为:

最终实现效果为,

图示为呼叫楼层(或目的)楼层为3楼与4楼,此时电梯运行状态为U即向上UP,当到达三楼时保持S停止状态,直至三楼的拨码关闭并控制电梯继续向上才会运动。

R2为复位开关, V17~W17从左至右为叫楼(或目的地)楼层信号;数码管最左侧显示当前电梯运行状况,为D(0)时,表示为DOWN,即下降,为U时,表示为UP,为S(5)时,表示为STOP;最右侧显示为当前电梯所在楼层。按钮自上至下表示为UP,STOP,DOWN等控制信号。

当电梯到达所在楼层后,需要将该楼层的拨码开关关闭,以停止对该楼层的持续呼叫;之后按按钮对电梯进行继续控制,当达到最高层后自动进入下降状态,若无继续呼叫,则最终停留在最底层。

楼层间的转换大约需要1~2秒。

七、小组分工情况说明

本实验全部由贾轲20220669完成

                                     

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/211208.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

太良心了!微软面向初学者,开源机器学习、数据科学、AI、LLM

大家好,推荐几个质量上乘且完全免费的微软开源课程,由粉丝小伙伴梳理,分享给大家。 文末可以加我们粉丝群 面向初学者的机器学习课程 ML for beginners banner 地址:https://microsoft.github.io/ML-For-Beginners/#/ 学习经典…

[Linux] Web基础知识与http协议

一、HTML 1.1 HTML 的概念 HTML被称为超文本标记语言。 它是规范和标准. 它通过标记符号来标记网页中出现的各个部分。网页文件本身就是一种文本文件。 通过向文本文件添加标记,您可以告诉浏览器如何显示其中的内容。 HTML命令可以描述文本、图形、动画、声音、表格…

讲解把一个文件夹里面的内容复制到另一个文件夹中的操作

🎊专栏【Java小练习】 🍔喜欢的诗句:天行健,君子以自强不息。 🎆音乐分享【如愿】 🎄欢迎并且感谢大家指出小吉的问题🥰 文章目录 🍔需求⭐思路✨代码✨效果 🎄如果要复制…

Vue3:表格单元格内容由:图标+具体内容 构成

一、背景 在Vue3项目中,想让单元格的内容是由 :图标具体内容组成的,类似以下效果: 二、图标 Element-Plus 可以在Element-Plus里面找是否有符合需求的图标iconfont 如果Element-Plus里面没有符合需求的,也可以在这…

MySQL 数据库操作指南:LIMIT,OFFSET 和 JOIN 的使用

限制结果 您可以通过使用"LIMIT"语句来限制查询返回的记录数量。以下是一个示例,获取您自己的Python服务器中"customers"表中的前5条记录: import mysql.connectormydb mysql.connector.connect(host"localhost",user&…

Proteus仿真--基于NM24C08的EEPROM仿真设计

本文介绍基于NM24C08的EEPROM仿真设计(完整仿真源文件及代码见文末链接) 其中NM24C08是标准的2线总线接口的串行EEPROM,开机画面在LCD12864上显示 仿真图如下 仿真运行视频 Proteus仿真--基于NM24C08的EEPROM仿真设计 附完整Proteus仿真资料…

零一万物模型折腾笔记:官方 Yi-34B 模型基础使用

当争议和流量都消失后,或许现在是个合适的时间点,来抛开情绪、客观的聊聊这个 34B 模型本身,尤其是实践应用相关的一些细节。来近距离看看这个模型在各种实际使用场景中的真实表现和对硬件的性能要求。 或许,这会对也想在本地私有…

Docker本地部署Drupal内容管理框架并实现公网远程访问

文章目录 前言1. Docker安装Drupal2. 本地局域网访问3 . Linux 安装cpolar4. 配置Drupal公网访问地址5. 公网远程访问Drupal6. 固定Drupal 公网地址7. 结语 前言 Dupal是一个强大的CMS,适用于各种不同的网站项目,从小型个人博客到大型企业级门户网站。它…

bat脚本之findstr

findstr 是 Windows 操作系统中用于文本搜索的命令,它可以在文件中查找指定的字符串或正则表达式,并输出匹配的行或行号。findstr 命令可以在命令提示符下直接使用,也可以在批处理脚本中嵌套使用。 以下是 findstr 命令的基本语法&#xff1…

使用条件格式突出显示单元格数据-sdk

使用条件格式突出显示单元格数据 2023 年 12 月 6 日 根据数据值将视觉提示应用于特定单元格、行或列,从而更轻松地识别模式和趋势。 网格中的条件格式允许用户根据单元格或范围包含的数据将视觉样式应用于单元格或范围。它通过以数据驱动的方式突出显示关键值、异常…

【基于Python的二手车数据可视化平台的设计与实现】

基于Python的二手车数据可视化平台的设计与实现 前言数据获取与处理网络爬虫数据存储 可视化平台的设计与实现Flask框架数据可视化 创新点结语 前言 随着社会的不断发展,二手车市场也逐渐成为一个备受关注的领域。为了更好地为二手车的买家和卖家提供信息&#xff…

Python 实现全连接攻击-1

实现或讨论如何实现网络攻击,包括全连接攻击(一种形式的拒绝服务攻击),是不合适的,也违反了伦理和法律规定。无论是学术研究、安全测试还是其他目的,未经授权对网络或系统进行攻击都是非法和不道德的。 如…

计算和传输背后的时空观

吞吐和速度(率)经常被混淆,当提到 100Gbps 网卡时,“它很快” 的意义可能只是 “它很多” 100Gbps 指 1s 内发送的比特数为 100G,如果在这 1s 内塞入更多比特,以下是两种方式: 显然,上面是更多&#xff…

安全防御–

安全防御 ASPF技术## FTP协议主机之间传输文件是IP网络的一个重要功能,如今人们可以方便地使用网页、邮箱进行文件传输。然而在互联网早期,Web(World Wide Web,万维网)还未出现,操作系统使用命令行的时代&a…

iOS分段控件UISegmentedControl使用

在故事板中添加UISegmentedControl 具体添加步聚如下: 选择Xcode的View菜单下的Show Library (或者Shift+Common+L) 打开控件库如下 在控件库中输入seg搜索控件,在出现Segmented Control后,将其拖到View Controller Scene中 到这里,添加分段控件UI已完成, 接下来将控件与变量…

shell的变量

Linux 系统中 shell 变量的使用 文章目录 (1)简介(2)变量分类(3)变量赋值(4)变量命名(5)变量引用(6)变量清除(7&#xff0…

基于JavaWeb+SSM+Vue马拉松报名系统微信小程序的设计和实现

基于JavaWebSSMVue马拉松报名系统微信小程序的设计和实现 源码获取入口Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 Lun文目录 1系统概述 1 1.1 研究背景 1 1.2研究目的 1 1.3系统设计思想 1 2相关技术 2 2.…

WPF仿网易云搭建笔记(0):项目搭建

文章目录 前言项目地址项目Nuget包搭建项目初始化项目架构App.xaml引入MateralDesign资源包 项目初步分析将标题栏去掉DockPanel初步布局 资源字典举例 结尾 前言 最近在找工作,发现没有任何的WPF可以拿的出手的工作经验,打算仿照网易云搭建一个WPF版本…

Numpy 实现基尼指数算法的决策树

基尼系数实现决策树 基尼指数 Gini ⁡ ( D ) 1 − ∑ k 1 K ( ∣ C k ∣ ∣ D ∣ ) 2 \operatorname{Gini}(D)1-\sum_{k1}^{K}\left(\frac{\left|C_{k}\right|}{|D|}\right)^{2} Gini(D)1−k1∑K​(∣D∣∣Ck​∣​)2 特征 A A A条件下集合 D D D的基尼指数: Gi…

使用ssm框架进行mapper或者service单纯测试时报错问题处理

问题 使用注解方式配置好ssm后,无法在测试中单独测试mapper层和service层。效果如下: 解决 关闭配置类中的EnableWebMvc 再次运行,即可完成测试。