找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1477|回复: 5
收起左侧

萌新求教一个关于用单片机控制风速传感器的问题,求大佬们指点

[复制链接]
ID:796670 发表于 2020-8-12 10:57 | 显示全部楼层 |阅读模式
风速传感器和单片机连接,风速传感器测出风速后传给单片机,由单片机获取风速
这是传感器说明:
12.jpg
这是完整的单片机程序:
  1. #include<stc12c5a.h>
  2. #include <stdio.h>
  3. #include <string.h>
  4. #include<stdlib.h>
  5. #include<math.h>
  6. #include<intrins.h>
  7. #define uint unsigned int
  8. #define uchar unsigned char
  9. uchar num;//num数据采集计数,mode工作模式设置:水位调节模式1、数据采集模式2、待机模式3
  10. int i,j,k;
  11. int flag1,flag2,flagd,flagj;//串口通信标志位
  12. uint temp1[8]={0,0,0,0,0,0,0,0};//串口通信1接收字符串,temp1和new_value[8]重用,减小内存空间
  13. uchar time0,time1,time2,time3,time4,time5,time6,time7,time8,time9,time10,time11;// 01秒 23分 45时 67日 89月 1011年  
  14. void init();// 初始化函数
  15. void UART_1Interrupt();//串口1接收字符串
  16. void UART_2Interrupt();//串口2接收字符串
  17. void delayms(uint);//延时函数
  18. void delay5ms();//延时函数
  19. void delay50us();//延时函数
  20. void delay5us();//延时函数
  21. uchar wind_speed[8]={0x11,0x03,0x00,0x00,0x00,0x04,0x46,0x99};   //风速
  22. uchar table[24]={0x64,0x19,0x12,0x31,0x23,0x59,0x59,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};
  23. //定义收发数组,收发通用减小内存。
  24. void main()
  25. {
  26. uchar hour,minute,second;//时分秒
  27. int flags;
  28. uchar test[3]={0x01,0x03,0x02};
  29. flag1=0;
  30. flag2=0;
  31. flags=0;   
  32.   flagd=0;//距离标志位,为1时接收到从机串口2距离指令并发送给传感器,为2时发送距离数据
  33.          //到从机串口1
  34.   flagj=0;//继电器标志位,为1时收到继电器指令
  35. init();
  36. while(1)
  37. {
  38.    flags=0;
  39.    flag1=0;
  40.    flag2=0;
  41.    for(i=0;i<80;i++)  //11为table长度table[11]
  42.    {
  43.     table[i]=0x00;
  44.    }
  45.    /******发送风速传感器命令*******/
  46.    if((flag1==0)&&(flags==0))
  47.    {
  48.    
  49.     for(i=0;i<8;i++)   
  50.     {
  51.      SBUF=wind_speed[i];
  52.      while(!TI); //数据传送中,发送完一组指令TI置1,请求中断,响应中断后置0      
  53.      TI=0; //清除数据传送标志
  54.     }
  55.      delay(500);  //delay(1000)用于22.1184Mhz,,delay(500)用于11.0592Mhz
  56.     flags=1;
  57.    }
  58.    if((flag1==0)&&(flags==1))
  59.    {
  60.     flag1=1;
  61.     wind_speed1[0]=0xAA;
  62.     wind_speed1[1]=0xAA;
  63.    }
  64.    /******发送风向传感器命令*******/
  65.    if((flag1==1)&&(flags==1))  
  66.    {
  67.     for(i=0;i<8;i++)
  68.     {
  69.      SBUF=wind_direction[i];
  70.      while(!TI); //等待数据传送      
  71.      TI=0; //清除数据传送标志
  72.     }
  73.       delay(500);
  74.       flags=2;
  75.    }
  76.    if((flag1==1)&&(flags==2))
  77.    {
  78.     flag1=2;
  79.     wind_direction1[0]=0xAA;
  80.     wind_direction1[1]=0xAA;
  81.    }
  82.    if((flag1==2)&&(flags==2))
  83.    {
  84.     table[0]=0x64;//数据校验位
  85.     table[1]=(((time10-0x30)<<4)&0xf0)+(time11-0x30);//时间,年月日时分秒
  86.     table[2]=(((time8-0x30)<<4)&0xf0)+(time9-0x30);
  87.     table[3]=(((time6-0x30)<<4)&0xf0)+(time7-0x30);
  88.     table[4]=(((time4-0x30)<<4)&0xf0)+(time5-0x30);
  89.     table[5]=(((time2-0x30)<<4)&0xf0)+(time3-0x30);
  90.     table[6]=(((time0-0x30)<<4)&0xf0)+(time1-0x30);
  91.                              
  92.     table[7]=wind_speed1[0];
  93.     table[8]=wind_speed1[1];
  94.     flag2=1;   
  95.      /**************监测船数据发送给从机*************/  
  96.     delay(500);
  97.     for(i=0;i<24;i++)
  98.     {
  99.       S2BUF=table[i];            
  100.               while(!(S2CON&S2TI));  //若S2TI=0,在此等待
  101.               S2CON&=~S2TI;   //S2TI=0
  102.        }
  103.     delay(500);      
  104.     Relay=0;   
  105.    }  
  106.   
  107. }
  108. //WDT_CONTR = 0x3C;//看门狗1S
  109. }
  110. /********************************************/
  111. /*串口1数据接收函数
  112. /********************************************/
  113. void UART_1Interrupt() interrupt 4
  114. {
  115. //接收完缓冲数据RI置1,响应中断,响应中断后置0
  116. if(RI)
  117. {  
  118.   RI=0;  

  119.   //----------------风速----------------------
  120.   if(flag1==0)
  121.   {
  122.    if(num==0)
  123.    {
  124.     if(SBUF==0x11) table[num++] = SBUF;
  125.         
  126.    }
  127.    else
  128.    {
  129.     table[num++] = SBUF;
  130.     if(num > 12)                        
  131.     {
  132.      num = 0;
  133.      flag1=1;
  134.      wind_speed1[0]=table[3];
  135.      wind_speed1[1]=table[4];
  136.     }
  137.    
  138.    }
  139.   }
  140. }
  141. }
  142. /********************************************/
  143. /*系统初始化
  144. /********************************************/
  145. void init()
  146. {
  147. uint i;
  148. num=0;//接收传感器数据计数
  149. LCDA=0;
  150. CLK_DIV=0x00;//系统时钟,不分频
  151. /****************串口通信初始化*****************/
  152. /****************定时器1初始化******************/
  153. TMOD=0X20;//定时器1,工作方式2,8位自动重装;定时器0,16位定时器
  154. TH1=0xfa;//定时器装初值,[url=mailto:9600bps@22.1184MHz]9600bps@22.1184MHz[/url]
  155. TL1=0xfa;//定时器装初值,[url=mailto:9600bps@22.1184MHz]9600bps@22.1184MHz[/url]

  156. SCON=0x50;//模式1,8位数据,可接收,0x50
  157. PCON=0x00;
  158. TR1=1;//定时器1中断
  159.     IP=0x10;//串口中断优先
  160. EA=1;//单片机总中断,用下面的EA=1
  161. ES=1;//中断控制位
  162. /***********独立波特率发生器初始化**************/
  163. S2CON = 0x50;    //串口2工作在方式1  10位异步收发 0X50 S2REN=1允许接收 0x40为只发送不接收
  164.     BRT = 0xfa;     //独立波特率发生器初值FA    //22.1184MHz用

  165.     AUXR = 0x10;    //BRTR=1 独立波特率发生器开始计数
  166.     IE2 =0x01; //开串口2中断  ES2=1
  167. /**************外部时钟初始化******************/
  168.     Ds1302Init();//第一次时初始化,调整好时间
  169. }
  170. /********************************************/
  171. /*延时函数
  172. /********************************************/
  173. void delayms(uint ms) //延时ms
  174. {
  175. uchar i;
  176. while(ms--)
  177. {
  178.   for(i=0;i<120;i++);
  179. }
  180. }  
  181. void delay5ms(void)                       //延迟5ms
  182. {
  183. unsigned char a,b;
  184. for(b=185;b>0;b--)
  185. for(a=12;a>0;a--);
  186. }
  187. void delay50us(void)                  //延迟50us
  188. {
  189. unsigned char a,b;
  190. for(b=9;b>0;b--)
  191. for(a=1;a>0;a--);
  192. }
  193. void delay5us(void)                      //延迟5us
  194. {
  195. _nop_();  //if Keil,require use intrins.h
  196. }
  197. void delay(uint z)//延时函数
  198. {
  199. uint x,y;
  200. for(x=z;x>0;x--)
  201.   for(y=110;y>0;y--);
  202. }
复制代码
请问上面的程序里哪一个是代表测得的风速啊?是这个吗:
123.png
还有请问wind_speed[8]里面的八个数代表什么?,table[24]里面的数代表什么?
捕获1.PNG
求指点,哪一个是表示所测得的风速啊?
回复

使用道具 举报

ID:648281 发表于 2020-8-12 12:21 | 显示全部楼层
协议都有了,风速根据收到的数据,按照协议规定去计算
2020-08-12_121704.jpg

回复

使用道具 举报

ID:796670 发表于 2020-8-12 16:19 | 显示全部楼层
51hei**1140 发表于 2020-8-12 12:21
协议都有了,风速根据收到的数据,按照协议规定去计算

我知道这个计算规则,但我不知道哪个是代表风速的,就是哪个相当于这个例子里的0x56H
回复

使用道具 举报

ID:8222 发表于 2020-8-12 21:13 | 显示全部楼层
明日香 发表于 2020-8-12 16:19
我知道这个计算规则,但我不知道哪个是代表风速的,就是哪个相当于这个例子里的0x56H

135和136行得到的数据就是风速了。
回复

使用道具 举报

ID:595237 发表于 2020-8-12 21:55 | 显示全部楼层
uchar wind_speed[8]={0x11,0x03,0x00,0x00,0x00,0x04,0x46,0x99};   //风速

wind_speed
//----------------风速----------------------
wind_speed1[0]=table[3];
     wind_speed1[1]=table[4];
回复

使用道具 举报

ID:420836 发表于 2020-8-13 09:01 | 显示全部楼层
所有信息都包含在数据表中。 仔细阅读数据表。
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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