找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机开发的平衡小型车(电路图+程序+仿真程序设计思路)

[复制链接]
跳转到指定楼层
楼主
最近工作不忙,就把以前的做的一些东西整理分享给大家。

制作出来的实物图如下:


仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


Part Type    Designator    Description
1N5822    D7    Schottky Diode
4148  *  8个    D11    Diode
4007    D1    Diode整流二极管1N4007
        
3K    R2    电阻
5.1K  *  12个    R12    电阻
150  *  5个    R18    电阻
620    R25    电阻
100    R3    电阻
10K  *  6个    RV1    电位器
        
89C52    U2    单片机
        
        
1000uF/25V    C13    Electrolytic Capacitor
100uF/25V    C4    Electrolytic Capacitor
        
100uH    L1    电感
        
        
LED红和黄各一个    LED2    LED2
        
LM2576-5.0    U1    开头稳压
7812  *  2个    U14    三端固定稳压器
        
L298    D10    驱动芯片
LM393  *  3个    U4    LM393
        
12V电机  *  2个    MG1   
        
RPR220  *  6个    U9    光电探测器
        
        
12V蓄电池    JP1   
开关按钮  *  5个    S1      
        
两个轮子和万向轮        

单片机源程序如下:
  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提供下载:
智能循迹小车(电路图+程序+仿真图).rar (128.98 KB, 下载次数: 29)

评分

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

查看全部评分

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

使用道具 举报

沙发
ID:895440 发表于 2021-4-17 22:35 | 只看该作者
四个轮子能叫平衡车?
回复

使用道具 举报

板凳
ID:143767 发表于 2021-4-18 14:03 | 只看该作者
雷欧库珀 发表于 2021-4-17 22:35
四个轮子能叫平衡车?

这样的话八个轮子岂不是更平衡,哈哈
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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