找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机遥控强度测量设计

[复制链接]
跳转到指定楼层
楼主
ID:139086 发表于 2016-9-11 14:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include<reg52.h>
  2. #define uchar unsigned char
  3. #define uint unsigned int
  4. sbit E=P2^7;  //1602使能引脚
  5. sbit RW=P2^6;  //1602读写引脚
  6. sbit RS=P2^5;  //1602数据/命令选择引脚
  7. sbit zero=P2^3;   //20厘米调零处(实际上是调20),由于我们采用强度测量,不同使用环境的白噪声(红外线)强度不同,所以需要按键调零;
  8. sbit storage=P2^2;   //存储按键
  9. sbit lookover=P2^1;   //查阅按键
  10. sbit led=P2^0;
  11. uint table[5]={3720,3720,3720,3720,3720};

  12. sbit b1=P1^0;
  13. sbit b2=P1^1;
  14. sbit b3=P1^2;
  15. sbit b4=P1^3;
  16. sbit b5=P1^4;
  17. sbit b6=P1^5;
  18. sbit b7=P1^6;
  19. sbit b8=P1^7;
  20. sbit b9=P3^1;
  21. sbit b10=P3^2;
  22. sbit b11=P3^3;
  23. sbit b12=P3^4; //12位数据端口定义

  24. sbit status=P3^7; //A/D转换器中的status定义,低电平有效
  25. sbit lben=P3^6;
  26. sbit hben=P3^5;  //对低8位数据和高4位数据的端口定义,低电平有效

  27.   uint D1_8;     //  A/D的低8位
  28.   uint D9_12;    //  A/D的高4位
  29.   uint digital_10; // A/D转换后的十进制数
  30.   uint digital_100;
  31.   uint digital_1000;
  32.   uchar shi;     // 距离十位
  33.   uchar ge;   //距离个位
  34.   uchar ge1;   //距离十分位
  35.   float temp;  //距离参考值
  36.   float D;   //距离值
  37.   uint DI;     //整数部分
  38.   float DD;    //小数部分
  39.   float modify; //修正值




  40. void delay()
  41. {
  42. uint i,j;
  43. for(i=0; i<=100; i++)
  44. for(j=0; j<=20; j++);
  45. }


  46. void Delay(uint del)
  47. {
  48. uint i,j;
  49. for(i=0; i<del; i++)
  50. for(j=0; j<1827; j++);
  51. }


  52. void enable(uchar del)
  53. {
  54. P0=del;
  55. RS=0;
  56. RW=0;
  57. E=0;
  58. delay();
  59. E=1;
  60. delay();
  61. }



  62. void write(uchar del)
  63. {
  64. P0=del;
  65. RS=1;
  66. RW=0;
  67. E=0;
  68. delay();
  69. E=1;
  70. delay();
  71. }


  72. void L1602_init(void)
  73. {
  74. enable(0x01); //清屏
  75. enable(0x38); //设置16*2显示,5*7点阵,8位数据接口
  76. enable(0x0c); //显示开,不显示光标,光标不闪烁
  77. enable(0x06); //当读或写一个字符后地址指针加1,且光标加1
  78. enable(0xd0); //设置数据地址指针80H+05H
  79. }

  80. void L1602_string(uchar hang,uchar lie,uchar *p)
  81. {
  82. uchar a;
  83. if(hang==1)  a=0x80;
  84. if(hang==2)  a=0xc0;
  85. a=a+lie-1;
  86. enable(a);
  87. while(1)
  88. {
  89.   if(*p=='\0')
  90.           break;
  91.   write(*p);
  92.   p++;
  93. }
  94. }


  95. void L1602_char(uchar hang,uchar lie,char sign)
  96. {
  97. uchar a;
  98. if(hang==1) a=0x80; //a为第一行的起始数据地址指针
  99. if(hang==2) a=0xc0; //a为第二行的起始数据地址指针
  100. a=a+lie-1;  //因为是5*7的点阵显示,所以每对地址指针加1,其实是对地址的加5
  101. enable(a); //设置数据地址指针
  102. write(sign);
  103. }



  104. void Display_num(uchar h,uchar l,uchar num)
  105. {
  106. L1602_char(h,l,(num+'0'));
  107. }

  108. void main()
  109. {
  110.   uchar n=0; //存储距离的个数,计数
  111.   uchar m=1;//切换显示计数的定义
  112.   L1602_init();
  113.   modify=0;
  114.   while(1)
  115.   {   
  116.    if(status==0)
  117.    {
  118.     lben=0;
  119.     hben=1;  //读取A/D低8位的值
  120.     delay(); //延时是为了让器件达到电压稳定   
  121.     digital_10=(uint)b1+b2*2+b3*4+b4*8+b5*16+b6*32+b7*64+b8*128; //低8位转化为10进制 ;  
  122.     hben=0;
  123.     lben=1;  //读取A/D高4位的值
  124.     delay(); //延时是为了让器件达到电压稳定
  125.    
  126.     digital_10+=b9*256+b10*512+b11*1024+b12*2048; //高4位转化为10进制;   

  127.     digital_10=D1_8+D9_12;  //得到A/D转换的10进制数;
  128.    if(zero==0)
  129.    {
  130.     Delay(2);
  131.    if(zero==0)
  132.    {
  133.     modify=(141.0-(float)digital_10)/1000.0;
  134.     Delay(10);
  135.    }
  136.    }            
  137.    //调零按键功能实现
  138.    if(storage==0)
  139.    {
  140.      Delay(2);
  141.     if(storage==0)
  142.     {
  143.       if(n==5)
  144.      {
  145.          n=0;
  146.      }
  147.       table[n++]=digital_10;
  148.      Delay(10);
  149.     }
  150.    }         
  151.    //存储距离,最多存储5个距离,超过5个距离后就覆盖前面的值

  152.    if(lookover==0)
  153.    {
  154.     Delay(2);
  155.     if(lookover==0)
  156.     {      
  157.         if(m==6)
  158.      {
  159.          m=0;
  160.      }
  161.      m++;
  162.      Delay(10);
  163.     }
  164.    }
  165.    L1602_string(2,5,"P=");
  166.    Display_num(2,7,digital_10/1000);
  167.    Display_num(2,8,digital_1000/100);
  168.    Display_num(2,9,digital_100/10);
  169.    Display_num(2,10,digital_10);
  170.    //显示上面的十进制数,用来作为距离的参考量
  171.   
  172.   switch(m)
  173.   {
  174.    case 1: if(digital_10>=(100+modify))
  175.               {
  176.         L1602_string(1,1,"Now");
  177.         }
  178.         break;
  179.    case 2: digital_10=table[0];  L1602_string(1,1,"M[1]");break;
  180.    case 3: digital_10=table[1];  L1602_string(1,1,"M[2]");break;
  181.    case 4: digital_10=table[2];  L1602_string(1,1,"M[3]");break;
  182.    case 5: digital_10=table[3];  L1602_string(1,1,"M[4]");break;
  183.    case 6: digital_10=table[4];  L1602_string(1,1,"M[5]");break;
  184.    default: break;
  185.      }
  186.     if(digital_10>=(100+modify))
  187.     {
  188.             led=1;
  189.       temp=digital_10/1000.0+modify;
  190.      
  191.       if(digital_10>=1793 )
  192.       {
  193.          D=0.3142*temp*temp-2.7701*temp+5.9567;
  194.       }
  195.      
  196.       else if(digital_10>=666)
  197.       {
  198.        D=2.5279*temp*temp-9.6821*temp+11.2530;
  199.       }
  200.       else if(digital_10>=474)
  201.       {
  202.        D=16.1678*temp*temp-28.8479*temp+18.0414;
  203.       }
  204.       else if(digital_10>=313)
  205.       {
  206.        D=35.1631*temp*temp-46.1739*temp+21.9936;
  207.       }
  208.       else if(digital_10>=208)
  209.       {
  210.        D=122.7448*temp*temp-101.4691*temp+30.7590;
  211.       }
  212.       else if(digital_10>=141)
  213.       {
  214.        D=368.1020*temp*temp-201.6608*temp+41.0483;
  215.       }
  216.       else if(digital_10>=123)
  217.       {
  218.        D=-111.1111*temp+35.6667;
  219.       }
  220.       else if(digital_10>=105)
  221.       {
  222.        D=2311.1*temp*temp-693.1*temp+72.3;
  223.       }
  224.       DI=(uint)D;    //得到整数;
  225.       DD=D-DI;       //得到分数部分;
  226.       shi=DI/10;
  227.       ge=DI;
  228.       ge1=(uchar)(DD*10);
  229.    
  230.       L1602_string(1,5,"D=");
  231.       Display_num(1,8,shi);
  232.       Display_num(1,9,ge);
  233.       L1602_char(1,10,'.');
  234.       Display_num(1,11,ge1);
  235.       L1602_string(1,12,"cm");
  236.     }
  237.      else
  238.      {
  239.        L1602_string(1,1,"Out of range ");
  240.        led=0;
  241.         }
  242.    }
  243.   }
  244. }
复制代码


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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