找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 9103|回复: 0
收起左侧

单片机智能循迹小车原理图+程序+Proteus仿真图

[复制链接]
ID:449323 发表于 2019-7-25 16:10 | 显示全部楼层 |阅读模式
希望能帮助到大家
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
12.jpg 51hei.gif
backup of(高电平).png Backup of.png

单片机源程序如下:
  1. #include<reg52.h>
  2. #define uchar unsigned char
  3. #define uint unsigned int
  4. uchar temp,signal,tt1,t0,t1,t2,t3,t4,t5,t6;


  5. void delay_1ms(uint d)
  6. {
  7.         uint i;
  8.         while(d--)
  9.                 for(i=0;i<75;i++);
  10. }

  11. void motor_run()                   //电机起动
  12. {
  13.           P1=0x35;
  14.         delay_1ms(200);
  15.         P1=0x53;
  16.         delay_1ms(10);
  17. /*        ENA=1;

  18.         OUT1=0;

  19.         OUT2=1;
  20.         delay_1ms(800);
  21.         OUT2=0;
  22.         delay_1ms(200);
  23.         
  24.         ENB=1;

  25.         OUT4=0;

  26.         OUT3=1;
  27.         delay_1ms(800);
  28.         OUT3=0;
  29.         delay_1ms(200);
  30. */
  31. }
  32. void motor_left()                         //左进
  33. {
  34.         P1=0x30;
  35.         delay_1ms(200);
  36.         P1=0x00;
  37.         delay_1ms(20);
  38. }

  39. void motor_right()                   //右进
  40. {
  41.         P1=0x05;
  42.         delay_1ms(200);
  43.         P1=0x00;
  44.         delay_1ms(20);
  45. }

  46. void motor_big_right()                         //粗右进
  47. {
  48.         P1=0x55;
  49.         delay_1ms(200);
  50.         P1=0x00;
  51.         delay_1ms(20);
  52. }
  53. void motor_big_left()
  54. {
  55.         P1=0x33;
  56.         delay_1ms(200);
  57.         P1=0x00;
  58.         delay_1ms(20);
  59. }
  60. void motor_stop()                                        //电机停止
  61. {
  62.          P1=0x00;
  63. }
  64. void motor_back()
  65. {
  66.         P1=0x53;
  67. }
  68. void main()
  69. {
  70.         t0=0;
  71.         t1=0;
  72.         t2=0;
  73.         t3=0;
  74.         t4=0;
  75.         t5=0;
  76.         t6=0;

  77.         tt1=0;
  78.         EA=1;
  79.         ET1=1;
  80.         TR1=1;
  81.         TMOD=0x01;
  82.         TH1=-(1000/256);
  83.         TL1=-(1000%256);
  84.         while(1)
  85.         {

  86.                  temp=P2;
  87.                 signal=temp&0xff;                   //得到红外反向信号
  88.                 switch(signal)
  89.                 {
  90.                         case 0xff:           //无偏差
  91.                                 motor_run();
  92.                                 t0++;
  93.                                 if(t0==10)
  94.                                 {
  95.                                         t0=0;
  96.                                         motor_left();
  97.                                         motor_right();
  98.                                 }
  99.                                 t1=t2=t3=t4=t5=t6=0;        
  100.                                 break;
  101.                         case 0xfd:           //1轮右偏                        

  102.                                 motor_big_left();
  103.                                 t1++;
  104.                                 if(t1==4)
  105.                                 {
  106.                                         t1=0;
  107.                                         motor_left();
  108.                                 }
  109.                                 t0=t2=t3=t4=t5=t6=0;        
  110.                                 break;
  111.                         case 0xef:            //4轮左偏                           

  112.                                 motor_big_right();
  113.                                 t2++;
  114.                                 if(t2==4)
  115.                                 {
  116.                                         t2=0;
  117.                                         motor_right();
  118.                                 }
  119.                                 t0=t1=t3=t4=t5=t6=0;        
  120.                                 break;
  121.                         case 0xfb:     //2轮右偏出轨
  122.                         case 0xf9:           //1、2轮右偏                                                
  123.                                  motor_big_left();
  124.                                 t3++;
  125.                                 if(t3==4)
  126.                                 {
  127.                                         t3=0;
  128.                                         motor_left();
  129.                                 }
  130.                                 t0=t1=t2=t4=t5=t6=0;        
  131. //                                delay_1ms(10);
  132.                                 break;

  133.                         case 0xdf:           //5左偏出轨                           
  134.                         case 0xcf:      //4、5轮左偏
  135.                                  motor_big_right();
  136.                                 t4++;
  137.                                 if(t4==4)
  138.                                 {
  139.                                         t4=0;
  140.                                         motor_right();
  141.                                 }
  142.                                 t0=t1=t2=t3=t5=t6=0;        
  143. //                                delay_1ms(10);
  144.                                 break;

  145.                         case 0xfe:           //0最右偏出轨           
  146.                         case 0xfa:
  147.                                  motor_big_left();
  148.                                 t5++;
  149.                                 if(t5==1)
  150.                                 {
  151.                                         t5=0;
  152.                                         motor_left();
  153.                                         motor_left();
  154.                                 }
  155.                                 t0=t1=t2=t3=t4=t6=0;        
  156. //                                delay_1ms(10);
  157.                                 break;

  158.                         case 0xbf:     //6最左偏出轨         
  159.                          case 0x9f:           
  160.                                 motor_big_right();
  161.                                 t6++;
  162.                                 if(t6==1)
  163.                                 {
  164.                                         t6=0;
  165.                                         motor_right();
  166.                                         motor_right();
  167.                                 }
  168.                                 t0=t1=t2=t3=t4=t5=0;        
  169. //                                delay_1ms(10);
  170.                                 break;        
  171.                         
  172.                         case 0xeb:         //前两传感器压在黑线上
  173.                         case 0xdb:         //后两传感器压在黑线上
  174.                         case 0xbe:         //中间两传感器压在黑线上
  175.                         case 0xac:                 //前四传感器压在黑线上
  176.                         case 0x9a:                //后四传感器压在黑线上
  177.                                 motor_back();
  178.                                 delay_1ms(200);
  179.                                 motor_stop();
  180.                                 
  181. //                                delay_1ms(1000);                                                                                                                                          

  182.                         default:
  183. //                                motor_back();
  184. //                                delay_1ms(50);
  185. //                                motor_left();
  186. //                                motor_right();
  187.                                 break;
  188.                 }  
  189.         }
  190.                         
  191. }
复制代码
51hei.png

所有资料51hei提供下载:
小车程序、仿真、电路图.7z (57.8 KB, 下载次数: 125)
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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