找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机小车避障代码

[复制链接]
跳转到指定楼层
楼主
ID:212108 发表于 2017-6-17 18:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
51单片机小车避障代码:
避障.docx (15.81 KB, 下载次数: 13)

  1. #include<AT89x51.H>
  2. #include <intrins.h>
  3. #define Sevro_moto_pwm P2_7 //接舵机信号端输入PWM信号调节速度
  4. #define ECHO P1_1 //超声波接口定义
  5. #define TRIG P1_0 //超声波接口定义
  6. #define Left_moto_go {P1_4=1,P1_5=0;} //左边两个电机向前走
  7. #define Left_moto_back {P1_4=0,P1_5=1;} //左边两个电机向后转
  8. #define Left_moto_Stop {P1_4=0,P1_5=0;} //左边两个电机停转
  9. #define Right_moto_go {P1_6=1,P1_7=0;} //右边两个电机向前走
  10. #define Right_moto_back {P1_6=0,P1_7=1;} //右边两个电机向后走
  11. #define Right_moto_Stop {P1_6=0,P1_7=0;} //右边两个电机停转
  12. #define DJEAEBGAO {P1_0=1,P1_1=1;}
  13. #define DJEAEBDI {P1_0=0,P1_1=0;}

  14. unsigned char pwm_val_left = 0;//变量定义
  15. unsigned char push_val_left =15;//舵机归中,产生约,1.5MS 信号
  16. unsigned long S=0;
  17. unsigned long S1=0;
  18. unsigned long S2=0;
  19. unsigned long S3=0;
  20. unsigned long S4=0;
  21. unsigned int time=0; //时间变量
  22. unsigned int timer=0; //延时基准变量
  23. /************************************************************************/
  24. void delay(unsigned int k) //延时函数
  25. {
  26.         unsigned int x,y;
  27.         for(x=0;x<k;x++)
  28.         for(y=0;y<2000;y++);
  29. }
  30. void pwm_leftdianji()
  31. {
  32.         DJEAEBGAO;
  33.         delay(3);
  34.         DJEAEBDI;
  35.         delay(1);
  36. }


  37. void StartModule() //启动测距信号
  38. {
  39.         TRIG=1;
  40.         _nop_();
  41.         _nop_();
  42.         _nop_();
  43.         _nop_();
  44.         _nop_();
  45.         _nop_();
  46.         _nop_();
  47.         _nop_();
  48.         _nop_();
  49.         _nop_();
  50.         _nop_();
  51.         _nop_();
  52.         TRIG=0;
  53. }
  54. /***************************************************/
  55. void Conut(void) //计算距离
  56. {
  57.         while(!ECHO&&timer<=250); //当RX为零时等待,等待25ms没信号则跳出
  58.         if(timer<=250)
  59.         {
  60.                 TR0=1; //开启计数
  61.                 while(ECHO); //当RX为1计数并等待
  62.                 TR0=0; //关闭计数
  63.                 time=TH0*256+TL0; //读取脉宽长度
  64.                 TH0=0;
  65.                 TL0=0;
  66.                 S=(time*1.7)/100; //算出来是CM
  67.         }
  68.         else
  69.                 S=400;               
  70. }
  71. /************************************************************************/
  72. //前进
  73. void run(void)
  74. {
  75.         pwm_leftdianji();
  76.         Left_moto_go ; //左电机往前走
  77.         Right_moto_go ; //右电机往前走

  78. }
  79. /************************************************************************/
  80. //后退
  81. void backrun(void)
  82. {
  83.         pwm_leftdianji();
  84.         Left_moto_back; //左电机往后
  85.         Right_moto_back; //右电机往后
  86. }
  87. /************************************************************************/
  88. //左转y
  89. void leftrun(void)
  90. {
  91.         pwm_leftdianji();
  92.         Left_moto_Stop; //左电机停止
  93.         Right_moto_go ; //右电机往前走
  94. }
  95. /************************************************************************/
  96. //右转
  97. void rightrun(void)
  98. {
  99.         pwm_leftdianji();
  100.         Right_moto_Stop ; //右电机停止
  101.         Left_moto_go ; //左电机往前       
  102. }
  103. /************************************************************************/
  104. //STOP
  105. void stoprun(void)
  106. {
  107.         pwm_leftdianji();
  108.         Left_moto_Stop ; //左电机停走
  109.         Right_moto_Stop ; //右电机停走
  110. }
  111. /************************************************************************/
  112. void COMM( void )  //
  113. {
  114.         push_val_left=5; //舵机向左转45度
  115.         timer=0;
  116.         while(timer<=3000); //延时400MS让舵机转到其位置
  117.         timer=0;
  118.         StartModule(); //启动超声波测距
  119.         Conut(); //计算距离
  120.         S2=S;
  121.         push_val_left=19; //舵机向右转45度
  122.         timer=0;
  123.         while(timer<=3000); //延时400MS让舵机转到其位置
  124.         timer=0;
  125.         StartModule(); //启动超声波测距
  126.         Conut(); //计算距离
  127.         S4=S;
  128.         push_val_left=12; //舵机归中
  129.         timer=0;
  130.         while(timer<=3000); //延时400MS让舵机转到其位置
  131.         timer=0;
  132.         StartModule(); //启动超声波测距
  133.         Conut(); //计算距离
  134.         S1=S;
  135.         if((S2<20)||(S4<20)) //只要左右各有距离小于20CM小车后退
  136.         {
  137.                 backrun(); //后退
  138.                 timer=0;
  139.                 while(timer<=4000);
  140.                 timer=0;
  141.         }
  142.         /*******************************************/
  143.         if(S2>S4)   //判断方向
  144.         {
  145.                 rightrun(); //车的左边比车的右边距离小 右转
  146.                 timer=0;
  147.                 while(timer<=4000);
  148.                 timer=0;
  149.         }
  150.         else
  151.         {
  152.             leftrun(); //车的左边比车的右边距离大 左转
  153.             timer=0;
  154.             while(timer<=4000);
  155.                 timer=0;
  156.         }
  157. }
  158. /************************************************************************/
  159. /* PWM调制电机转速 */
  160. /************************************************************************/
  161. /* 左电机调速 */
  162. /*调节push_val_left的值改变电机转速,占空比 */
  163. void pwm_Servomoto(void)
  164. {
  165. if(pwm_val_left<=push_val_left)
  166.   Sevro_moto_pwm=1;
  167. else
  168.   Sevro_moto_pwm=0;
  169. if(pwm_val_left>=200)
  170.    pwm_val_left=0;
  171. }
  172. /***************************************************/
  173. ///*TIMER中断服务子函数产生PWM信号*/
  174. void time1()interrupt 3 using 2
  175. {
  176.         TH1=(65536-100)/256; //100US定时
  177.         TL1=(65536-100)%256;
  178.         timer++; //定时器100US为准。在这个基础上延时
  179.         pwm_val_left++;
  180.         pwm_Servomoto();
  181. //timer1++; //2MS扫一次数码管
  182. //if(timer1>=20)
  183. //{
  184. //timer1=0;
  185. //Display();
  186. //}
  187. }
  188. /***************************************************/
  189. ///*TIME中断服务子函数产生PWM信号*/
  190. void time0()interrupt 1 using 0
  191. {

  192. } /***************************************************/
  193. void main(void)
  194. {
  195. TMOD=0X11;
  196. TH1=(65536-100)/256; //100US定时
  197. TL1=(65536-100)%256;
  198. TR1=1;
  199. ET1=1;
  200. ET0=1;
  201. EA =1;
  202. delay(100);
  203. push_val_left=12; //舵机归中

  204. while(1) /*无限循环*/
  205. {
  206.         if(timer>=65) //80MS检测启动检测一次
  207.         {
  208.                 timer=0;
  209.                 StartModule(); //启动检测
  210.                 Conut(); //计算距离             
  211.                 if(S<20) //距离小于20CM
  212.                 {
  213.                         stoprun(); //小车停止
  214.                         COMM(); //方向函数
  215.                 }                            
  216.                 else
  217.                         run();
  218.         }
  219. }
  220. }
复制代码


评分

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

查看全部评分

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

使用道具 举报

沙发
ID:209421 发表于 2017-6-20 06:41 | 只看该作者
谢谢分享,先下载试试
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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