找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 10516|回复: 12
打印 上一主题 下一主题
收起左侧

关于超声波模块测量水位

  [复制链接]
跳转到指定楼层
楼主
问题:超声波测量一个水塔的水位,假如水塔1.5米高,水位有1米,那么我把超声波模块固定在水塔的口子上(因为模块不防水,没办法放进水里),测出来的就只是0.5米已经用了的水位,而不是还有多少,这个问题怎么解决?我这有源程序和原理图大神帮忙修改一下程序使其测的水位是还有多少水而不是用了多少。
谢谢

  1. /***********************************************************************************************************/
  2. //hc-sr04 超声波测距模块 DEMO 程序
  3. //晶振:11。0592
  4. //接线:模块TRIG接 P0.2 ECH0 接P0.1
  5. //数码管:共阳数码管P1接数据口,P2.5 P2.4 P2.3接选通数码管
  6. /***********************************************************************************************************/
  7. #include <AT89x51.H> //器件配置文件
  8. #include <intrins.h>
  9. #define RX P0_1
  10. #define TX P0_2
  11. unsigned int time=0;
  12. unsigned int timer=0;
  13. unsigned char posit=0;
  14. unsigned long S=0;
  15. bit flag =0;
  16. unsigned char const discode[] ={ 0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xBF,0xff/*-*/};
  17. unsigned char const positon[3]={ 0xdf,0xef,0xf7};
  18. unsigned char disbuff[4] ={ 0,0,0,0,};
  19. /********************************************************/
  20. void Display(void) //扫描数码管
  21. {
  22. P2=0xfe;//消隐
  23. //delay(5);
  24. if(posit==0)
  25. {P1=(discode[disbuff[posit]])&0x7f;}
  26. else
  27. {P1=discode[disbuff[posit]];}
  28. P2=positon[posit];
  29. if(++posit>=3)
  30. posit=0;
  31. }
  32. /********************************************************/
  33. void Conut(void)
  34. {
  35. P2=0xfe;
  36. time=TH0*256+TL0;
  37. TH0=0;
  38. TL0=0;
  39. P2=0xfe;//消隐
  40. S=(time*1.7)/100; //算出来是CM
  41. if((S>=700)||flag==1) //超出测量范围显示“-”
  42. {
  43. P2=0xfe;//消隐
  44. flag=0;
  45. //delay(5);
  46. disbuff[0]=10; //“-”
  47. disbuff[1]=10; //“-”
  48. disbuff[2]=10; //“-”
  49. }
  50. else
  51. {
  52. P2=0xfe;//消隐
  53. //delay(5);
  54. disbuff[0]=S%1000/100;
  55. disbuff[1]=S%1000%100/10;
  56. disbuff[2]=S%1000%10 %10;
  57. P2=0xfe;
  58. }
  59. }
  60. /********************************************************/
  61. void zd0() interrupt 1 //T0中断用来计数器溢出,超过测距范围
  62. {
  63. flag=1; //中断溢出标志
  64. }
  65. /********************************************************/
  66. void zd3() interrupt 3 //T1中断用来扫描数码管和计800MS启动模块
  67. {
  68. P2=0xfe;
  69. TH1=0xf8;
  70. TL1=0x30;
  71. Display();
  72. timer++;
  73. if(timer>=400)
  74. {
  75. P2=0xfe;
  76. timer=0;
  77. TX=1; //800MS 启动一次模块
  78. _nop_();
  79. _nop_();
  80. _nop_();
  81. _nop_();
  82. _nop_();
  83. _nop_();
  84. _nop_();
  85. _nop_();
  86. _nop_();
  87. _nop_();
  88. _nop_();
  89. _nop_();
  90. _nop_();
  91. _nop_();
  92. _nop_();
  93. _nop_();
  94. _nop_();
  95. _nop_();
  96. _nop_();
  97. _nop_();
  98. _nop_();
  99. TX=0;
  100. }
  101. }
  102. /*********************************************************/
  103. <DIV class=blockcode>
  104. <BLOCKQUOTE>void main( void )

  105. {
  106. P2=0xfe;//消隐
  107. //delay(5);
  108. TMOD=0x11; //设T0为方式1,GATE=1;
  109. TH0=0;
  110. TL0=0;
  111. TH1=0xf8; //2MS定时
  112. TL1=0x30;
  113. P2=0xfe;
  114. ET0=1; //允许T0中断
  115. ET1=1; //允许T1中断
  116. TR1=1; //开启定时器
  117. EA=1; //开启总中断

  118. while(1)
  119. {
  120. while(!RX); //当RX为零时等待
  121. TR0=1; //开启计数
  122. P2=0xfe;
  123. //delay(5);
  124. while(RX); //当RX为1计数并等待
  125. TR0=0; //关闭计数
  126. Conut(); //计算
  127. }

  128. }
复制代码




分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:171096 发表于 2017-3-29 04:34 | 只看该作者
解决的怎么样了,手绘原理图很漂亮.
回复

使用道具 举报

板凳
ID:105425 发表于 2017-3-29 08:18 | 只看该作者
我的思路是,安装时,先让超声波模块测量并记录空水池的深度,作为初始常量--因为该水池深度是不变。
然后,实际运作时,利用超声波测量到的安装点到水面距离,记录测试变量。
最后,简单计算下即可得到可读的水位信息:水池深度(初始变量)-水面距离(实测变量)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

地板
ID:151348 发表于 2017-3-29 09:16 | 只看该作者
用水塔高度减去超声波半程吧,S=150-(time*1.7)/100; //算出来是CM,150是水塔高度,单位cm

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

5#
ID:104472 发表于 2017-3-29 09:16 | 只看该作者
既然用超声波头测试距离,那么要知道水位,就要进行简单的距离计算和判断,修改这一句
S=(time*1.7)/100; //算出来是CM
对S进行重新计算    S=1.5-((time*17)/100)
试试,然后修改

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

6#
ID:22751 发表于 2017-3-29 11:01 | 只看该作者
设置水塔深为初始值,减去超声波测得的距离不就是剩余的水位高度了么?

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

7#
ID:187473 发表于 2017-5-30 10:47 | 只看该作者
实地测试了吗,超声波遇到水面反射的多吗,能测准吗
回复

使用道具 举报

8#
ID:159139 发表于 2017-5-30 16:15 来自手机 | 只看该作者
先测一个空池深度,然后用池深减去你的测量值,最后显示剩下的数就是水深。
回复

使用道具 举报

9#
ID:70302 发表于 2017-5-30 19:20 | 只看该作者
超声波测水位严重不准,测水上漂浮物还可以。
回复

使用道具 举报

10#
ID:318695 发表于 2018-4-28 23:29 | 只看该作者
可以用一个连通器,测得就准了
回复

使用道具 举报

11#
ID:305386 发表于 2018-7-17 10:46 | 只看该作者
其实可以用共阴极的数码管来显示,而且电路图几乎跟你一样,不用到锁存器。
求黑币,求黑币,求黑币!!!!
#include<reg51.h>
#include<intrins.h>
#define uint  unsigned int   
#define uchar unsigned char
sbit c=P2^0;                  //
sbit b=P2^1;
sbit a=P2^2;
sbit d=P2^3;
sbit trig=P2^4;
sbit echo=P2^5;
uint time=0;
uint timer=0;
uchar posit=0;
unsigned long s=0;
bit  flag =0;
unsigned char code WE0[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
//uchar temp[3];    //测距接收缓冲区        
void delay(uint z)
{
    uchar x,y;
    for(x=z;x>0;x--)
        for(y=110;y>0;y--);
}

void display() //显示函数
{

a=1,b=0,c=0,d=0;
P0=WE0[s/100];
delay(25);
P0=0x00;

a=0,b=1,c=0,d=0;
P0=WE0[s%100/10];
delay(25);
P0=0x00;

a=0;b=0;c=1;d=0;
P0=WE0[s%100%10];
delay(25);
P0=0x00;
}

void time0() interrupt 1
{
   flag=1;
}
void StartModule()         //启动模块
{
   trig=1;                  //启动一次模块
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   //delay(20000);
   trig=0 ;
}
void count()
{
   time=TH0*256+TL0;
   TH0=0;
   TL0=0;
   s=(time*1.7)/100;     //算出来是CM
   display();
}
void main()
{     
    TMOD=0x01;                       //设T0、T1为方式1,GATE=1;
    TH0=0;
    TL0=0;         
    ET0=1;                          //允许T0中断
        EA=1;
//        uint z;                                                          //开启总中断
           while(1)
    {
                StartModule();
                while(!echo);                     //当UL_RX为零时等待
                TR0 = 1;                           //开启计数
                while(echo);                      //当UL_RX为1计数并等待
                TR0 = 0;
                count();
    }
}
回复

使用道具 举报

12#
ID:450090 发表于 2018-12-19 18:06 | 只看该作者
做一个相减就行
回复

使用道具 举报

13#
ID:450546 发表于 2018-12-20 10:56 | 只看该作者
已知水塔深度的话 做减法 水塔深度未知的话 这种方式水塔有水的情况下测量不到水塔深度的
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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