单片机课程设计超声波测距仪_第1页
单片机课程设计超声波测距仪_第2页
单片机课程设计超声波测距仪_第3页
单片机课程设计超声波测距仪_第4页
单片机课程设计超声波测距仪_第5页
已阅读5页,还剩21页未读 继续免费阅读

下载本文档

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

文档简介

1、成绩华中师范大学武汉传媒学院传媒技术学院课程设计报告华中师范大学武汉传媒学院传媒技术学院电子信息工程2011仅发布百度文库,版权所有.一、 设计题目及原理超声波测距仪超声波测距仪是利用反射的原理测量距离的,被测距离一端为超声波传感器,另一端必须有能反射超声波的物体。测量距离时,将超声波传感器对准反射物发射超声波,并开始计时,超声波在空气中传播到达障碍物后被反射回来,传感器接收到反射脉冲后立即停止计时,然后根据超声波的传播速度和计时时间就能计算出两端的距离。测量距离D为式中c超声波的传播速度;超声波发射到接收所需时间的一半,也就是单程传播时间。由上式可风,距离的测量精度主要取决于计时精度和传播速

2、度两方面。计时精度由单片机定时器决定,定时时间为机器周期与计数次数的乘积,可选用12MHz的晶振,使机器周期为精确的1µs,不会产生累积误差,使定时间达到1µs。超声波的传播速度c并不是固定不变的,传播速度受空气密度、温度和气体分子成分的影响,关系式为式中 气体定压热容与定容热容的比值,空气为1.40R气体普适常数,为8.314kg/molT气体势力学温度,与摄氏温度的关系是T=273K+tM气体相对分子质量,空气为28.8×10-3kg/mol0时的声波速度,为331.4m/s由上式可见,超声波在空气中传播时,受温度影响最大,由表达式可计算出波速与温度的关系,如

3、表2.1所示。温度越高,传播速度越快,而且不同温度下传播速度差别非常大,例如0时的速度为332m/s,30时的速度为350m/s,相差18m/s。因此,需要较高的测量精度时,进行温度补偿是最有效的措施。对测量精度要求不高时,可认为超声波在空气中的传播速度为340m/s。超声波传播速度与温度关系表项目数值温度()-30-20-100102030405060100声速(m/s)313319325332338344350356361367388二、 设计框图超声波测距仪系统结构如下图所示。它主要由单片机、超声波发射及接收电路、超声波传感器、温度传感器、键盘、LED显示电路及电源电路组成。系统主要功能

4、包括:1. 超声波的发射、接收,并根据计时时间计算测量距离;2. 检测空气温度用于距离计算的补偿;3. LED显示器显示距离、温度;4. 键盘接收用户命令并处理;5. 当系统运行不正常时,用电平式开关与上电复位电路复位。三、 方案设计测量距离方法有很多种,短距离可以用尺,远距离有激光测距等,超声波测距适用于高精度中长距离测量。因为超声波在标准空气中传播速度为331.45米/秒,由单片机负责计时,单片机使用12.0M晶振,所以此系统测量精度理论上可以达到毫米级。 目前比较普遍的测距的原理:通过发射具有特征频率的超声波对被摄目标的探测,通过发射出特征频率的超声波和反射回接受到特征频率的超声波所用的

5、时间,换算出距离,如超声波液位物位传感器,超声波探头,适合需要非接触测量场合,超声波测厚,超声波汽车测距告警装置等。 由于超声波指向性强,能量消耗缓慢,在介质中传播距离远,因而超声波可以用于距离测量。利用超声波检测距离,设计比较方便,计算处理也较简单,并且在测量精度方面也能达到要求。由于超声波易于定向发射、方向性好、强度易控制、与被测量物体不需要直接接触的优点,是作为液体高度测量的理想手段。在精密的液位测量中需要达到毫米级的测量精度,但是目前国内的超声波测距专用集成电路都是只有厘米级的测量精度。通过分析超声波测距误差产生的原因,提高测量时间差到微秒级,以及用温度传感器进行声波传播速度的补偿后,

6、我们设计的高精度超声波测距仪能达到毫米级的测量精度。目前超声波测距已得到广泛应用,国内一般使用专用集成电路根据超声波测距原理设计各种测距仪器,但是专用集成电路的成本较高、功能单一。而以单片机为核心的测距仪器可以实现预置、多端口检测、显示、报警等多种功能,并且成本低、精度高、操作简单、工作稳定、可靠。以8051为内核的单片机系列,其硬件结构具有功能部件齐全、功能强等特点。尤其值得一提的是,出8位CPU外,还具备一个很强的位处理器,它实际上是一个完整的位微计算机,即包含完整的位CPU,位RAM、ROM(EPROM),位寻址寄存器、I/O口和指令集。所以,8051是双CPU的单片机。位处理在开关决策

7、、逻辑电路仿真、过程测控等方面极为有效;而8位处理则在数据采集和处理等方面具有明显长处。根据设计要求并综合各方面因素,可以采用AT89C51单片机作为主控制器,它控制发射触发脉冲的开始时间及脉宽,响应回波时刻并测量、计数发射至往返的时间差。利用软件产生超声波信号,通过输出引脚输入至驱动器,经驱动器驱动后推动探头产生超声波;超声波信号的接收采用锁相环LM567对放大后的信号进行频率监视和控制。一旦探头接到回波,若接收到的信号频率等于振荡器的固有频率(此频率主要由RC值决定),则其输出引脚的电平将从“1”变为“0”(此时锁相环已进入锁定状态),这种电平变化可以作为单片机对接收探头的接收情况进行实时

8、监控。可对测得数据优化处理,并采用温度补偿,使测量误差降到更低限度;AT89C51还控制显示电路,用动态扫描法实现LED数字显示。四、 程序流程图及分析系统上电后,首先系统初始化,不断扫描按键k1,若按键k1按下,则开始测量空气温度,然后将P1.0置位,使定时器T0开始定时,控制超声波传感器发出超声波,同时使定时器T1开始定时。CPU循环检测P3.3引脚,当P3.3为低电平时接收到回波,立即使T1停止工作,保存定时器的计数值。然后根据温度和传输时间计算距离,温度补偿措施使测量精度有了明显提高,计算出距离后调用距离显示子程序,LED显示距离。最后检测按键k2,若k2闭合,则调用温度显示子程序,L

9、ED显示温度(温度并非测量距离时用于补偿的温度,而是当前温度)5s后恢复显示本次测量距离;若按键k2没有闭合,则显示器恒定显示最新一次的测量结果;若要进行下一次测量,则先要按下k3重新开始,再按下按键k1才执行新一次测量。由于不需输入数据,键盘只设置了3个按键,用于开始测量距离并显示温度功能设置等。五、 系统仿真六、 制作和调试虽说在仿真时温度传感器DS18B20是可视调节,且全为整数,但LED显示时当温度达到一定范围便会出现小数误差。例如当DS18B20显示是28时,而LED显示是28.4;而当DS18B20显示是25时,而LED显示仍是25;而仿真表明随着温度的升高其误差大小也并不一致,且

10、全都控制在1以内。说明这并不是固有误差,很难避免,可以忽略,其对距离测量的影响也微乎其微,并不会使距离测量精度明显降低。根据超声波的特性,距离测量时必须满足条件:被测目标必须垂直于超声波测距仪。被测目标表面必须平坦。测量时在超声波测距仪周围没有其他可反射超声波的物体。因此在测量过程中稍不小心就会接收不到超声波,而导致没有测量结果。由于超声波的往返时间由单片机AT89C51的定时器T1来记,定时器T1工作在方式1,其最大定时时间为65.536ms,可得出在常温下最大的测量距离在10m以内。且因为发射功率有限,测距仪也无法测量10m外的物体。我们知道C语言程序有利于实现较复杂的算法,汇编语言程序则

11、具有较高的效率且容易精细计算程序运行的时间,而超声波测距仪的程序既有较复杂的计算(计算距离时),又要求精细计算程序运行时间(超声波测距时),所以控制程序可采用C语言和汇编语言混合编程。因为本设计对时间要求精度较高的部分全部由单片机内部的定时器完成,而虽然温度传感器的读写对时间精度要求也高,但经详细计算所得出的C程序已被广泛应用,故直接借用已有程序也能作到对温度的准确读取,所心本设计全部使用C语言编程,这样能使设计中所用到的公式能方便快捷的体现和实现,又缩短了论文的篇幅。软件采用模块化设计方法,由主程序、超声波发生子程序、超声波接收中断子程序、温度测量子程序、距离计算子程序、显示子程序、键盘扫描

12、处理程序等模块组成。七、 心得体会利用51系列单片机设计的测距仪便于操作、读数直观。经实际测试证明,该类测距仪工作稳定,能满足一般近距离测距的要求,且成本较低、有良好的性价比。由于该系统中锁相环锁定需要一定时间,测得的距离有误差,在汽车雷达应用中可忽略不计;但在精度要求较高的工业领域如机器人自动测距等方面,此误差不能忽略,可以通过改变一些硬件的应用实现对超声波的快速锁定或根据自己的需要在程序中加入测距软件补偿的代码,使误差进一步减小,可以满足更高要求。本设计完整地做出之后可测量十米以内的距离。因为超声波的特性,测距时保证传感器与被测物间,以及测量轴线上没有障碍物;且要尽量保证传感器轴线与被测物

13、表面垂直;实际测距范围与被测物表面材料等因素有关,一般不要测量表面为毛料的物体表面。八、 源程序#include<reg51.h>#include<stdio.h>#include<math.h>#include<intrins.h>#define unint unsigned int#define uchar unsigned char #define LED P1/际温度值输出端口定义#define NOP _nop_()sbit tem_in=P11;sbit k1=P37;sbit k2=P36;sbit k3=P35;sbit send

14、=P10;sbit recieve=P32;uchar temp_h,temp_l;/温度值变量float temnum; /当前温度值float t; /超声波往返所占用的时间bit setb; bit b; /测距成功标志位,当b=1时标志测距成功uchar flag1; /正负标志位uchar code ledcode=0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf,0xff;/数码显示数据:0,1,2,3,4,5,6,7,8,9,-,消隐uchar dispbuf4=0,0,0,0,tembuf4=0,0,0,0;/void

15、 delay(unsigned int count) unint i;while(count)i=38;while(i>0)i-;count-; /void delay10ms(unsigned int n) unsigned int j,k; while(n-!=0) for(j=0;j<10;j+)for(k=0;k<72;k+); /void delay_us(uchar n) uchar i;i=0;while(i<n)i+;return;/void dsreset(void) /DS18B20重设unsigned int i;tem_in=0;i=103;wh

16、ile(i>0)i-;tem_in=1;i=4;while(i>0)i-;/uchar readbyte(void) /直接读一字节程序uchar i,k;i=8;k=0;while(i-)tem_in=1;delay_us(1);tem_in=0;k=k>>1;tem_in=1;NOP;if(tem_in)k |= 0x80; /tem_in为1时,则该位也为1delay_us(4);return(k);/void tmpwrite(unsigned char dat) /函数功能:向B20写一字节unsigned int i;unsigned char j;bit

17、testb;for(j=1;j<=8;j+)testb=dat&0x01;dat=dat>>1;if(testb)tem_in=0;i+;i+;tem_in=1;i=8;while(i>0)i-;elsetem_in=0;i=8;while(i>0)i-;tem_in=1;i+;i+;/void tmpchange(void)dsreset();/复位delay(1);tmpwrite(0xcc);/跳过序列号命令tmpwrite(0x44);/转换命令/void tmp(void) /温度采集及转换 int m,n=0; float temnum1=0;

18、 dsreset(); delay(1); tmpwrite(0xcc); tmpwrite(0xbe); temp_l=readbyte(); /低位在前 temp_h=readbyte(); /高位在后 flag1=temp_h&0xf8; if(flag1) n=flag1;temp_h=temp_h;if(temp_l=0)temp_h+;/若低8位全为0且温度为负,取补时就要向高位进1temp_l=temp_l+1; temnum1=(temp_h*256+temp_l)/16; if(temnum1<10) tembuf3=11;tembuf2=11;tembuf1=

19、(uchar)temnum1;tembuf0=(uchar)(temnum1*10)%10; if(temnum1>=100) tembuf3=(uchar)temnum1/100; m=(int)temnum1%100; tembuf2=(uchar)m/10; tembuf1=(uchar)m%10; tembuf0=(uchar)(temnum1*10)%10; if(temnum1<100&&temnum1>=10) tembuf3=11;tembuf2=(uchar)temnum1/10;tembuf1=(uchar)temnum1%10;tembu

20、f0=(uchar)(temnum1*10)%10; if(n=0xf8)tembuf3=10; temnum=temnum1; / void dis(void) /温度显示uchar i; uchar j=0xfe;for(i=0;i<4;i+) /输送显示数据 P0=0xff;P0=ledcodetembufi;if(i=1)P0=ledcodetembufi+0x80; /小数点显示P2=j;delay(15);j=(j<<1)+0x01;/void distance(void) /计算测量得到的距离 double radical,dist; if(b!=0) radi

21、cal=sqrt(1+(temnum+273)/273); dist=165.7*t*radical; dist=dist+0.005; /四舍五入并留两位小数if(dist>0&&dist<10)dispbuf3=11;dispbuf2=(uchar)dist;dispbuf1=(uchar)(dist*10)%10;dispbuf0=(uchar)(dist*100)%10;if(dist>=10&&dist<=0) /测量距离大于10米或小于0显示"-",也有出错的意思 dispbuf3=10; dispbuf2

22、=10; dispbuf1=10; dispbuf0=10; if(dist<100&&dist>=10) dispbuf3=(uchar)dist/10;dispbuf2=(uchar)dist%10;dispbuf1=(uchar)(dist*10)%10;dispbuf0=(uchar)(dist*100)%10; else /当T1溢出时,则测量时间无效 dispbuf3=10; dispbuf2=10; dispbuf1=10; dispbuf0=10; /void dis1(void) /距离显示uchar i; uchar j=0xfe;for(i=0

23、;i<0;i+) /*输送显示数据*/ P0=0xff;P0=ledcodedispbufi;if(i=2)P0=ledcodedispbufi+0x80; /小数点显示P2=j;delay10ms(1);j=(j<<1)+0x01;/void dis2(void) uchar i; uchar j=0xfe; dispbuf3=11; dispbuf2=11; dispbuf1=11; dispbuf0=0;for(i=0;i<4;i+) /*输送显示数据*/ P0=0xff;P0=ledcodedispbufi;P2=j;delay10ms(1);j=(j<<1)+0x01;/void timer1(void)interrupt 3 TR1=0; TH1=0x00; TL1=0x00;/void timer0(void

温馨提示

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

评论

0/150

提交评论