找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2455|回复: 3
收起左侧

求解单片机超声波测距测液位问题

[复制链接]
ID:425510 发表于 2018-11-15 21:47 | 显示全部楼层 |阅读模式
这是具体C语言文字,问下    S=(time*1.87)/10;  这是怎么转换计算的,而且现在液晶显示屏显示的S是传感器到液位的距离,怎么填写C语言转换成为液位的液面高度。急急急

单片机源程序如下:
  1. #include<reg52.h>
  2. #include <intrins.h>
  3. #include "LCD1602.h"
  4. sbit  RX = P3^6;  
  5. sbit  TX = P3^7;

  6. sbit LED = P2^0;  
  7. sbit SPEAK = P2^1;
  8. sbit Motor = P2^2;

  9. sbit KEY1 = P1^3;  
  10. sbit KEY2 = P1^4;  
  11. sbit KEY3 = P1^5;  

  12. unsigned int  time=0;
  13. unsigned int  timer=0;
  14. unsigned int S=0;
  15. unsigned int SET_H=100,SET_L=10;
  16. bit  flag =0;
  17. unsigned char Table[3],Table1[5];
  18. unsigned char KEY_flag=0;
  19. //?óê±oˉ
  20. void Delay_ms(int jj)  
  21. {
  22.         int ii;        
  23.         while(jj--)
  24.                 for(ii=0;ii<116;ii++);
  25. }
  26. void Conut(void)         
  27.         {
  28.          time=TH0*256+TL0;         
  29.          TH0=0;         
  30.          TL0=0;         
  31.       
  32.          S=(time*1.87)/10;     
  33.          if((S>=700)||flag==1)
  34.          {         
  35.           flag=0;
  36.          }
  37.          else
  38.          {
  39.           Table1[0]= S/1000+0X30;        
  40.           Table1[1]= S/100%10+0X30;        
  41.           Table1[2]= S/10/10+0X30;        
  42.           Table1[3]= '.';                        
  43.           Table1[4]= S%10+0X30;           
  44.           LCD1602_Disp_ZF(0x88,Table1,5);
  45.         }
  46. }
  47. void main(void)        
  48. {
  49.     LCD1602_init();
  50.         //////////////////////0123456789ABCDEF
  51.     LCD1602_Disp_ZF(0x80,"  Now S:     CM ",16);
  52.                                                      
  53.     LCD1602_Disp_ZF(0x80+0X40,"Set H:    L:    ",16);
  54.         TMOD=0x11;                  
  55.         TH0=0;                           
  56.         TL0=0;            
  57.         TH1=0xf8;                  
  58.         TL1=0x30;                  
  59.         ET0=1;            
  60.         ET1=1;                           
  61.         TR1=1;                           
  62.         EA=1;                           
  63.         EA=0;
  64.         ///SET_H = ISP_READ(0x2c00)*256+ISP_READ(0x2c01);//?áè?′?′¢μ?×?′ó?μ
  65.         
  66.         EA=1;
  67.         while(1)
  68.         {
  69.                 while(!RX);                    
  70.                 TR0=1;                           
  71.                 while(RX);                        
  72.                 TR0=0;                                
  73.                 Conut();  
  74.                 /////////////////////////////////////
  75.                 if((S/10>SET_H)||(S/10<SET_L))
  76.                 {
  77.                         LED=0;SPEAK=0;
  78.                 }
  79.                 else
  80.                 {
  81.                         LED=1;SPEAK=1;
  82.                 }
  83.                 ////////////////////////////////
  84.                 if((S/10>SET_H))
  85.                 {
  86.                         Motor=0;
  87.                 }
  88.                 else
  89.                 {
  90.                         Motor=1;
  91.                 }      
  92.                 if(!KEY1)
  93.                 {
  94.                         Delay_ms(10);
  95.                         if(!KEY1)
  96.                         {
  97.                                 KEY_flag++;        
  98.                                 
  99.                                 
  100.                                 
  101.                                 
  102.                                 
  103.                         }
  104.                         while(!KEY1);
  105.                 }
  106.                 if(!KEY2)
  107.                 {
  108.                         Delay_ms(10);
  109.                         if(!KEY2)
  110.                         {
  111.                                 if(KEY_flag%2==0)SET_H++;
  112.                                 if(KEY_flag%2==1)SET_L++;
  113.                         }
  114.                 }
  115.                 if(!KEY3)
  116.                 {
  117.                         Delay_ms(10);
  118.                         if(!KEY3)
  119.                         {
  120.                                 if(KEY_flag%2==0)SET_H--;
  121.                                 if(KEY_flag%2==1)SET_L--;
  122.                         }
  123.                 }
  124.           Table[0]= SET_H/100+0X30;
  125.           Table[1]= SET_H%100/10+0X30;
  126.           Table[2]= SET_H%10+0X30;
  127.           LCD1602_Disp_ZF(0x86+0x40,Table,3);
  128.           Table[0]= SET_L/100+0X30;         
  129.           Table[1]= SET_L%100/10+0X30;
  130.           Table[2]= SET_L%10+0X30;
  131.           LCD1602_Disp_ZF(0x8C+0x40,Table,3);
  132.         }
  133. }

  134. /********************************************************/
  135.      void zd0() interrupt 1                  
  136.   {
  137.     flag=1;                                                         
  138.   }
  139. /********************************************************/
  140.    void  zd3()  interrupt 3        
  141.   {
  142.          TH1=0xf8;
  143.          TL1=0x30;
  144.          timer++;
  145.          if(timer>=100)
  146.          {
  147.           timer=0;
  148.           TX=1;                                       
  149.           _nop_(); _nop_(); _nop_();
  150.           _nop_(); _nop_(); _nop_();
  151.           _nop_(); _nop_(); _nop_();
  152.           _nop_(); _nop_(); _nop_();
  153.           _nop_(); _nop_(); _nop_();
  154.           _nop_(); _nop_();_nop_();
  155.           _nop_(); _nop_(); _nop_();
  156.           TX=0;
  157.          }
  158.   }
复制代码


回复

使用道具 举报

ID:164602 发表于 2018-11-16 12:49 | 显示全部楼层
第一个问题:S是表示超声波传感器到障碍物的距离,声波通常在空气中的传播速度340m/s,超声波在发射、反射回来,所以要除以2,time是单片机的定时脉冲次数,不同的单片机,这个次数表达的时间不一样(不知道你用的单片机晶振是多少),以STC89C52单片机为例,晶振12M,定时器频率为主频的12分频,为1M,即定时器一个脉冲1us=0.000001s,这样就可以用高中物理知识来计算距离:S=vt=340*time/2。此时S的单位是米m,可以换成mm,就要乘1000,现在就是你给出的公式了,即你给出的公式得出的距离是以mm为单位的距离。至于为什么我说的是time*1.7/10,而你的公式是1.87,这就是对声波在空气中传播速度的补偿了,不同温度下声波传播速度不一样,即空气密度大时,传播速度快,所以不是一个定值。(复习高初中的物理,真的意思)。
第二个问题:又用高中物理中的运动学知识吧(其实是常识),你的超声波传感器到装水容器的底部有多远,我们设为H,现在得超声波传感器到水面的距离S,那么,水深就是H-S嘛。哈哈哈,好玩不?!
回复

使用道具 举报

ID:425510 发表于 2018-11-16 15:17 | 显示全部楼层
HC6800-ES-V2.0 发表于 2018-11-16 12:49
第一个问题:S是表示超声波传感器到障碍物的距离,声波通常在空气中的传播速度340m/s,超声波在发射、反射 ...

大佬谢谢前面都看懂了,可是第二个问题,我在用Proteus进行仿真时, S=(time*1.87)/10;     ,假设传感器到容器低400,我直接变为S=400-(time*1.87)/10; 好像无法显示,是下面IF函数的问题吗,也没有S>700呀,我重新设定一个变量X=H-S也不行。为什么急急急
回复

使用道具 举报

ID:425510 发表于 2018-11-16 17:21 | 显示全部楼层
HC6800-ES-V2.0 发表于 2018-11-16 12:49
第一个问题:S是表示超声波传感器到障碍物的距离,声波通常在空气中的传播速度340m/s,超声波在发射、反射 ...

Table1[0]= S/1000+0X30;        
          Table1[1]= S/100%10+0X30;        
          Table1[2]= S/10/10+0X30;        
          Table1[3]= '.';                        
          Table1[4]= S%10+0X30;           
          LCD1602_Disp_ZF(0x88,Table1,5); 大佬这个取百十个位好像是错误的格式,我改成Table1[0]= S/100+0X30;        //ÏÔê¾μ±Ç°Öμ
          Table1[1]= S/10%10+0X30;        //ÏÔê¾μ±Ç°Öμ
          Table1[2]= S%10+0X30;        //ÏÔê¾μ±Ç°Öμ
          Table1[3]= '.';                        //ÏÔê¾μ±Ç°Öμ
          Table1[4]= S%10+0X30;           //ÏÔê¾μ±Ç°Öμ
          LCD1602_Disp_ZF(0x88,Table1,5); //ÏÔê¾μ±Ç°Öμ 好像可以了正常仿真的,但是仿真时S数据好像会上下浮动,我用的是脉冲信号来模拟超声波侧位的,大佬知道为什么吗
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表