基于单片机控制的超声波测距报警系统设计.doc
《基于单片机控制的超声波测距报警系统设计.doc》由会员分享,可在线阅读,更多相关《基于单片机控制的超声波测距报警系统设计.doc(17页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、上海师范大学天华学院?现代通信技术?专业课程设计题 目基于单片机控制的超声波测距报警系统设计系 部:电子与信息工程系专业班级:学生姓名:学 号:小组成员:指导教师:时 间:完成日期 目录第一章 绪论11.1 课题设计背景与目的11.2 课题设计任务及要求11.3 课题设计的主要内容2第2章 系统硬件设计32.1 测距原理32.2 设计思路及原理框图32.3 设计方案3第3章 各模块介绍53.1 单片机AT89S5253.2 引脚及其功能53.2 单片机最小系统73.2 超声波发射模块73.3 超声波接收模块83.4 显示模块9第4章 系统软件设计104.1 主程序设计104.2 超声波发射子程
2、序114.3 超声波接收中断程序11第5章 调试及性能分析125.1 调试125.2 性能分析12第六章 结束语12参考文献13附录14附录1 元件清单及实物图14附录2 系统原理图15附录3 程序15第一章 绪论1.1 课题设计背景与目的 超声波测距【1】作为一种传统且实用的非接触测量方法,与激光、无线电测距方法相比,不易受外界光及电磁场等因素的影响,结构简单,本钱低,在恶劣环境下也有一定的适应能力,因此在工业控制、建筑测量、机器人避障等方面都得到了广泛应用。而且由于超声波指向性强,能量消耗缓慢,在介质中传播距离远,利用超声波检测距离,设计方便,计算处理简单,并在测量精度方面也能到达工业要求
3、。通过本次设计掌握超声波测距系统【2】硬件设计方法与软件编写方法,了解设计过程中所涉及的芯片结构、控制原理、硬件及编程等方面知识,加深对现代通信技术课程知识点的理解,提高在应用知识、设计、调试等方面的能力。1.2 课题设计任务及要求任务:1、设计最小化单片机系统并进行焊接和调试2、设计并编程,实现超声波测距报警【3】功能要求:1、数码管能实时显示障碍物与超声波模块的距离信息。单位为cm,精确到小数点后1位。2、系统具备测距启动/复位功能。3、当测试距离小于10cm或大于50cm时报警,并用蜂鸣器时间长短来区别。1.3 课题设计的主要内容本课题设计的主要内容包括硬件设计和软件设计两局部。通过对超
4、声波测距可行性进行理论分析的根底上,利用计算机、电子技术及超声波在介质中的传播特性,制作出超声波测距的硬件局部,并编写相应的软件程序,进行调试与运行。其中在硬件设计方面,针对超声波在传播时呈指数衰减的特性,采取最大限度提高驱动能力、对回波进行多级放大等方法,扩大测量范围。在软件设计方面,采用模块化程序设计设想,将软件分为超声波驱动和数据处理2大模块,而每个模块又由假设干小模块组成,使其软件结构简单清晰,利于调试与修改。第2章 系统硬件设计超声波测距硬件主要包括STC89C52单片机最小系统、超声波发射/接收模块、显示模块、报警模块等。2.1 测距原理超声波是指频率高于20KHz的机械波,其测距
5、方法有多种,如相位检测法、声波幅值检测法和往返时间检测法等。相位检测法虽然精度高,但检测范围有限,声波幅值检测法那么易受反射波影响。故本文采用超声波往返时间检测,其原理是检测出从超声波发射器发出的超声波经传播介质发送到接收器所需的时间,再与传播介质中的声速相乘,得到声波传输的距离。而它的一半即为所测距离。2.2 设计思路及原理框图单片机【4】首先发出40KHz信号,经放大后通过超声波发射器输出,然后超声波接收器将接收到的超声波信号经放大器放大,用锁相环电路进行检波处理,启动单片机中断程序,测得时间T,再由系统软件对其进行计算、判别,最后将相应的计算结果送至LED数码管进行显示。图2.1 超声波
6、测距原理框图2.3 设计方案采用AT89S52【5】单片机作为主控制器,选用高精度的晶振,以获得稳定的时钟频率,减少测量误差。用P1.0端口输出40KHz方波信号,并利用外中断0口检测超声波接收电路输出的返回信号。LED显示电路采用3位共阳数码管,段选接P0口的8位,位选接P2口的高三位。超声波测距器的系统框图如下:图2.2 超声波测距报警系统框图发射超声波脉冲计数器工作延时2ms停止计数,计算距离是否有回波结束YN开始系统初始化数据显示距离50cm蜂鸣器报警YN图2.3 超声波测距报警系统流程图第3章 各模块介绍3.1 单片机AT89S52AT89S52是一种低功耗、高性能CMOS 8位微控
7、制器【6】,具有8k字节Flash,256字节RAM,32位I/O口线,看门狗定时器,2个数据指针,3个16位定时器/计数器,1个6向量2级中断结构,全双工串行口,片内晶振及时钟电路。使用Atmel公司高密度非易失性存储器技术制造,与工业80C51产品指令和引脚完全兼容,片内置通用8位CPU及Flash存储单元,使其为众多嵌入式控制应用系统提供高灵活、高效率的解决方案。3.2 引脚及其功能如图3.1为AT89S52引脚图。图3.1 AT89S52引脚图1、VCC:电源 GND:地2、P0口:8位漏极开路的双向I/O口。作为输出口,每位能驱动8个TTL逻辑电平。对P0端口写“1时,引脚用作高阻抗
8、输入。当访问外部程序和数据存储器时,P0口那么作为低8位地址/数据复用,在这种模式下,它具有内部上拉电阻。在flash编程时,P0口用来接收指令字节。在程序校验时,那么需要外部上拉电阻来输出指令字节。3、P1口:具有内部上拉电阻的8位双向I/O口。P1输出缓冲器能驱动4个TTL逻辑电平。对P1端口写“1时,内部上拉电阻把端口拉高,作为输入口使用。在输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流。在flash编程和校验时,P1口接收低8位地址字节。引脚号第二功能:P1.0 T2:定时器/计数器T2的外部计数输入,时钟输出P1.1 T2EX:定时器/计数器T2的捕捉/重载触发信号和方向
9、控制P1.5 MOSI、P1.6 MISO、P1.7 SCK:系统编程用4、P2口:具有内部上拉电阻的8位双向I/O口。P2输出缓冲器能驱动4个TTL逻辑电平。对P2端口写“1时,内部上拉电阻把端口拉高,作为输入口使用。在输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流。在访问外部程序存储器或用16位地址读取外部数据存储器时,P2口送出高8位地址。在使用8位地址访问外部数据存储器时,P2口输出锁存器内容。在flash编程和校验时,P2口接收高8位地址字节和一些控制信号。5、P3口:具有内部上拉电阻的8位双向I/O口。P3输出缓冲器能驱动4个TTL逻辑电平。对P3端口写“1时,内部上拉
10、电阻把端口拉高,作为输入口使用。在输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流。在flash编程和校验时,P3口接收一些控制信号。引脚号第二功能:P3.0 RXD:串行输入 P3.1 TXD:串行输出P3.2 INT0:外部中断0 P3.3 INT0:外部中断0P3.4 T0:定时器0外部输入 P3.5 T0:定时器1外部输入P3.6 WR:外部数据存储器写选通 P3.7 RD:外部数据存储器读选通6、RST:复位输入。晶振工作时,RST脚持续2个机器周期高电平使单片机复位。看门狗计时完成后,RST脚输出96个晶振周期的高电平。特殊存放器AUXR的DISRT0位可以是此功能无效。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 单片机 控制 超声波 测距 报警 系统 设计
限制150内