找回密码
 立即注册

QQ登录

只需一步,快速开始

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

智能小车超声波避障程序(不带1602显示)

  [复制链接]
跳转到指定楼层
楼主

关于超声波测距程序编译不成功的说明:
解压C51FPS.rar
把C51FPS.LIB这个文件放到\Keil\C51\LIB下面,这个文件有浮点运算




源程序:
  1. /**********************ZYWIFI0939C-WIFI机器人实验板例程************************
  2. *  平台:ZYWIFI0939C-WIFI机器人 + Keil U4 + STC89C52
  3. *  名称:ZY-1智能小车参考程序
  4. *  公司:湖南智宇科教设备有限公司
  5. *  编写:智宇公司研发一部
  6. *  日期:2015-1-15
  7. *  交流:智能车QQ:261339276
  8. *  晶振:11.0592MHZ
  9. *  说明:免费开源,不提供源代码分析
  10. *  硬件设置:要有自己动手能力,才能完成实验
  11. *  使用说明:根据下面IO口自己用杜邦线连接各种模块,可以自己修改各种模块IO口
  12. *  视频教程:本小车配套学习C语言详细视频教程,资料统一网盘下载
  13.    重点提示:本程序只做参考,不提供技术支持,请自己研究吸收。
  14. ******************************************************************/
  15. #include <at89x51.h>       
  16. #include <intrins.h>

  17. #define  TX  P2_1
  18. #define  RX  P2_0

  19. #define Forward_L_DATA  180//当前进不能走直线的时候,请调节这两个参数,理想的时候是100,100,最大256,最小0。0的时候最慢,256的时候最快
  20. #define Forward_R_DATA  180        //例如小车前进的时候有点向左拐,说明右边马达转速过快,那可以取一个值大一点,另外一个值小一点,例如 200  190
  21.                             //直流电机因为制造上的误差,同一个脉宽下也不一定速度一致的,需要自己手动调节


  22. /*****按照原图接线定义******/
  23. sbit L293D_IN1=P1^2;
  24. sbit L293D_IN2=P1^3;
  25. sbit L293D_IN3=P1^4;
  26. sbit L293D_IN4=P1^5;
  27. sbit L293D_EN1=P1^6;
  28. sbit L293D_EN2=P1^7;

  29. sbit BUZZ=P2^3;


  30. void Delay400Ms(void);//延时400毫秒函数


  31. unsigned char disbuff[4]={0,0,0,0};//用于分别存放距离的值0.1mm、mm、cm和m的值

  32. void Count(void);//距离计算函数
  33.                           
  34. unsigned int  time=0;//用于存放定时器时间值
  35. unsigned long S=0;//用于存放距离的值
  36. bit  flag =0; //量程溢出标志位
  37. bit  turn_right_flag;


  38. //**********************************************************
  39. //函数名称:Delay1ms(unsigned int i)
  40. //函数功能:延时i*1ms的子程序(对应于22.1184Mhz晶振)   
  41. //形式参数:unsigned int i
  42. //行参说明:无
  43. //返回参数:无
  44. //使用说明:i为要延时的时间长度,单位是MS,最大可以延时65536 ms
  45. //**********************************************************
  46. void Delay1ms(unsigned int i)
  47. {
  48. unsigned char j,k;
  49. do{
  50.   j = 10;
  51.   do{
  52.    k = 50;
  53.    do{
  54.     _nop_();
  55.    }while(--k);     
  56.   }while(--j);
  57. }while(--i);

  58. }
  59. //**********************************************************
  60. //函数名称:Delay10us(unsigned char i)
  61. //函数功能:延时i*10us的子程序(对应于22.1184Mhz晶振)   
  62. //形式参数:无
  63. //行参说明:无
  64. //返回参数:无
  65. //使用说明:i为要延时的时间长度,单位是US,最大可以延时250 ms
  66. //**********************************************************
  67. void Delay10us(unsigned char i)
  68. {
  69.    unsigned char j;
  70. do{
  71.   j = 10;
  72.   do{
  73.    _nop_();
  74.    }while(--j);
  75. }while(--i);
  76. }  

  77. //=========================================================================================================================
  78. void Forward()//           前进
  79. {

  80.          L293D_IN1=1;
  81.          L293D_IN2=0;
  82.          L293D_IN3=1;
  83.          L293D_IN4=0;
  84. //     PWM_Set(255-Speed_Right,255-Speed_Left);
  85. }
  86. void  backrun()//           后退
  87. {

  88.          L293D_IN1=0;
  89.          L293D_IN2=1;
  90.          L293D_IN3=0;
  91.          L293D_IN4=1;
  92. //     PWM_Set(255-Speed_Right,255-Speed_Left);
  93. }
  94. void Stop(void)        //刹车
  95. {

  96.      L293D_IN1=0;
  97.          L293D_IN2=0;
  98.          L293D_IN3=0;
  99.          L293D_IN4=0;
  100. //         PWM_Set(0,0);
  101. }
  102. void Turn_Retreat()         //左
  103. {
  104.     L293D_IN1=0;
  105.         L293D_IN2=0;
  106.         L293D_IN3=0;
  107.         L293D_IN4=1;
  108. //        PWM_Set(255-Speed_Right,255-Speed_Left);
  109. }

  110. void Turn_left()         //右
  111. {
  112.     L293D_IN1=1;
  113.         L293D_IN2=0;
  114.         L293D_IN3=0;
  115.         L293D_IN4=0;
  116. //        PWM_Set(255-Speed_Right,255-Speed_Left);
  117. }

  118. //=========================================================================================================================
  119. /********距离计算程序***************/
  120.     void Conut(void)
  121.         {
  122.          time=TH1*256+TL1;
  123.          TH1=0;
  124.          TL1=0;
  125.        
  126.          //此时time的时间单位决定于晶振的速度,外接晶振为11.0592MHZ时,
  127.                     //time的值为0.54us*time,单位为微秒
  128.                                 //那么1us声波能走多远的距离呢?1s=1000ms=1000000us
  129.                                 // 340/1000000=0.00034米
  130.                                 //0.00034米/1000=0.34毫米  也就是1us能走0.34毫米
  131.                                 //但是,我们现在计算的是从超声波发射到反射接收的双路程,
  132.                                 //所以我们将计算的结果除以2才是实际的路程

  133.         S=time*2;//先算出一共的时间是多少微秒。
  134.            S=S*0.17;//此时计算到的结果为毫米,并且是精确到毫米的后两位了,有两个小数点
  135.          if(S<=400)         //
  136.          {       
  137.             if(turn_right_flag!=1)
  138.                 {
  139.                     Stop();
  140.                     Delay1ms(5);//发现小车自动复位的时候,可以稍微延长一点这个延时,减少电机反向电压对电路板的冲击。
  141.                 }
  142.                 turn_right_flag=1;
  143.                
  144.                 P2_3=0;

  145.                 Delay1ms(50);
  146.                
  147.                 P2_3=1;
  148.             backrun();
  149.            Delay1ms(300);         // 关键点  延时5MS  
  150.            Turn_left();
  151.            Delay1ms(400);           //左转800MS

  152.          }
  153.          else
  154.          {
  155.             turn_right_flag=0;
  156.             //Forward(Forward_R_DATA,Forward_L_DATA);
  157.                 Forward();

  158.          }
  159.          //=======================================
  160.          if((S>=5000)||flag==1) //超出测量范围
  161.          {       
  162.           flag=0;
  163.       //DisplayListChar(0, 1, table1);
  164.          }
  165.          else
  166.          {
  167.       disbuff[0]=S%10;
  168.           disbuff[1]=S/10%10;
  169.           disbuff[2]=S/100%10;
  170.           disbuff[3]=S/1000;
  171.          }
  172.         }

  173. /********************************************************/
  174.      void zd0() interrupt 3                  //T0中断用来计数器溢出,超过测距范围
  175.   {
  176.     flag=1;                         //中断溢出标志
  177.         RX=0;
  178.   }

  179. /********超声波高电平脉冲宽度计算程序***************/
  180. void Timer_Count(void)
  181. {
  182.                  TR1=1;                            //开启计数
  183.              while(RX);                        //当RX为1计数并等待
  184.              TR1=0;                                //关闭计数
  185.          Conut();                        //计算

  186. }
  187. /********************************************************/
  188.    void  StartModule()                          //启动模块
  189.   {
  190.           TX=1;                                             //启动一次模块
  191.       Delay10us(2);
  192.           TX=0;
  193.   }
  194. /********************************************************/

  195. /*************主程序********************/
  196. void main(void)
  197. {
  198.     unsigned char i;
  199.         unsigned int a;
  200.         Delay1ms(5);//延时片刻
  201.     TMOD=TMOD|0x10;//设T0为方式1,GATE=1;
  202.     EA=1;
  203.     TH1=0;
  204.     TL1=0;         
  205.     ET1=1;             //允许T0中断
  206.                                    //开启总中断

  207.         turn_right_flag=0;
  208.         //=================================
  209. B:                for(i=0;i<50;i++) //判断K3是否按下
  210.                 {
  211.                    Delay1ms(1);        //1ms内判断50次,如果其中有一次被判断到K3没按下,便重新检测
  212.                    if(P3_2!=0 )//当S1按下时,启动小车
  213.                    goto B; //跳转到标号B,重新检测
  214.                 }
  215.         //蜂鸣器响一声
  216.         BUZZ=0;        //50次检测K3确认是按下之后,蜂鸣器发出“滴”声响,然后启动小车。
  217.         Delay1ms(50);
  218.         BUZZ=1;//响50ms后关闭蜂鸣器
  219.         //=======================================================================================================================                       
  220.         while(1)
  221.           {
  222.                 RX=1;
  223.             StartModule();
  224.         for(a=951;a>0;a--)
  225.             {
  226.                   
  227.                if(RX==1)
  228.                    {
  229.            Timer_Count();
  230.                    }
  231.              }
  232.            }
  233. }



  234.                
复制代码

下载:
9、ZYWIFI0939C超声波避障程序(不带1602显示).rar (54.07 KB, 下载次数: 66)

评分

参与人数 1黑币 +3 收起 理由
Ashily丶恒 + 3 赞一个!

查看全部评分

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

使用道具 举报

沙发
ID:149774 发表于 2017-3-26 16:41 | 只看该作者
沙发~~~~~~~~~~~~
回复

使用道具 举报

板凳
ID:184168 发表于 2017-3-29 15:04 | 只看该作者
大神 我想问一下 这个程序能实现侧向防撞吗
回复

使用道具 举报

地板
ID:184467 发表于 2017-3-29 15:22 | 只看该作者
好好学习 总能派上用场的
回复

使用道具 举报

5#
ID:449368 发表于 2018-12-21 21:51 | 只看该作者
可以添加pwm和舵机程序 么
回复

使用道具 举报

6#
ID:549519 发表于 2019-5-28 19:39 | 只看该作者
一直右转是怎么回事?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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