找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机循迹小车Proteus仿真程序

  [复制链接]
跳转到指定楼层
楼主
51循迹智能小车仿真电路及程序
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  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. }

  192. /*void time1() interrupt 3
  193. {

  194.         TH1=-(1000/256);
  195.         TL1=-(1000%256);
  196.         tt1++;
  197.         if(tt1==300)
  198.         {
  199.                 motor_back();
  200.         //        delay_1ms(1);
  201.                 tt1=0;
  202.         }
  203. } */
复制代码

所有资料51hei提供下载:
循迹小车程序及仿真电路图.zip (197.94 KB, 下载次数: 452)


评分

参与人数 2黑币 +55 收起 理由
xzy1997 + 5 赞一个!
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

沙发
ID:773598 发表于 2020-6-9 10:09 | 只看该作者
这是几个寻迹的智能小车啊?
回复

使用道具 举报

板凳
ID:783907 发表于 2020-6-19 10:36 | 只看该作者
感谢分享~
回复

使用道具 举报

地板
ID:872129 发表于 2021-2-17 21:33 | 只看该作者
轮胎是怎么来的 能简单说下吗?
回复

使用道具 举报

5#
ID:982933 发表于 2021-11-27 15:48 | 只看该作者
这个为什么仿真开始两个轮胎是相反转的
回复

使用道具 举报

6#
ID:998140 发表于 2021-12-30 13:32 | 只看该作者
zxcvbnm5280 发表于 2021-11-27 15:48
这个为什么仿真开始两个轮胎是相反转的

不懂,刚来看见
回复

使用道具 举报

7#
ID:982933 发表于 2022-1-2 20:43 | 只看该作者

就是我仿真开始是,两个轮一个是顺时针,一个是逆时针转动
回复

使用道具 举报

8#
ID:982933 发表于 2022-1-8 22:23 | 只看该作者
请问能有这个程序的注释讲解吗
回复

使用道具 举报

9#
ID:685462 发表于 2022-4-22 19:25 | 只看该作者
速度慢可以,可能自己程序有问题,速度快了后,反应不过来。最后换成arm直接开多线程,感觉比单片机反应快好多,不时还能来个甩尾。

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

10#
ID:1021092 发表于 2022-4-23 23:26 | 只看该作者
lose2836 发表于 2022-4-22 19:25
速度慢可以,可能自己程序有问题,速度快了后,反应不过来。最后换成arm直接开多线程,感觉比单片机反应快 ...

我能问你一些问题吗,你昨天还在,希望你能看见消息
回复

使用道具 举报

11#
ID:849479 发表于 2022-4-26 15:54 | 只看该作者
这是光电对管循迹的吗
回复

使用道具 举报

12#
ID:1055693 发表于 2022-12-5 08:51 | 只看该作者
这俩个轮胎怎么相反
回复

使用道具 举报

13#
ID:1057667 发表于 2022-12-15 10:16 | 只看该作者
empor 发表于 2020-6-9 10:09
这是几个寻迹的智能小车啊?

我觉得是一个
回复

使用道具 举报

14#
ID:1074920 发表于 2023-5-20 06:37 | 只看该作者
牛逼,水晶雕刻技法
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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