找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3215|回复: 1
收起左侧

STC12单片机做平衡车程序 mpu6050+L298N+直流减速电机

[复制链接]
ID:580450 发表于 2019-7-31 16:21 | 显示全部楼层 |阅读模式
大家参考参考。
mpu6050+L298N+直流减速电机

单片机源程序如下:
  1. #include <stc12c5a.h>
  2. #include <intrins.h>
  3. #include <stdio.h>
  4. #include <math.h>

  5. #include "kalman.h"
  6. #include "lcd1602.h"
  7. #include "mpu6050.h"
  8. #include "pid_own.h"
  9. #include "pwm_motor.h"
  10. #include "spe_pos.h"


  11. int INT_PWM;
  12. unsigned int Init_Time=0,Start_Flag=0;


  13. void main()
  14. {
  15.         lcd_init();
  16.         InitMPU6050();
  17.         PWM_Motor_Init();
  18.         INT_Init();
  19.        
  20.         P1M0=1;
  21.         P1M1=0;
  22.        

  23.         while(1)
  24.         {

  25.                 if(GYRO_X<0)
  26.                 {
  27.                         write_com(0x80);
  28.                         write_dat('-');
  29.                         write_dat('0'+(uchar)abs(GYRO_X)/100);
  30.                         write_dat('0'+(uchar)abs(GYRO_X)%100/10);
  31.                         write_dat('0'+(uchar)abs(GYRO_X)%10);
  32.                 }
  33.                 else
  34.                 {
  35.                         write_com(0x80);
  36.                         write_dat('+');
  37.                         write_dat('0'+(uchar)GYRO_X/100);
  38.                         write_dat('0'+(uchar)GYRO_X%100/10);
  39.                         write_dat('0'+(uchar)GYRO_X%10);
  40.                 }

  41.                 if(Angle_End<0)
  42.                 {
  43.                         write_com(0x80+0x40);
  44.                         write_dat('-');
  45.                         write_dat('0'+(uchar)abs(Angle_End)/100);
  46.                         write_dat('0'+(uchar)abs(Angle_End)%100/10);
  47.                         write_dat('0'+(uchar)abs(Angle_End)%10);
  48.                 }
  49.                 else
  50.                 {
  51.                         write_com(0x80+0x40);
  52.                         write_dat('+');
  53.                         write_dat('0'+(uchar)Angle_End/100);
  54.                         write_dat('0'+(uchar)Angle_End%100/10);
  55.                         write_dat('0'+(uchar)Angle_End%10);
  56.                 }
  57.                
  58.                 if(speed<0)
  59.                 {
  60.                         write_com(0x80+9);
  61.                         write_dat('-');
  62.                         write_dat('0'+(uchar)abs(speed)/100);
  63.                         write_dat('0'+(uchar)abs(speed)%100/10);
  64.                         write_dat('0'+(uchar)abs(speed)%10);
  65.                 }
  66.                 else
  67.                 {
  68.                         write_com(0x80+9);
  69.                         write_dat('+');
  70.                         write_dat('0'+(uchar)speed/100);
  71.                         write_dat('0'+(uchar)speed%100/10);
  72.                         write_dat('0'+(uchar)speed%10);
  73.                 }
  74.                
  75.                 if(position<0)
  76.                 {
  77.                         write_com(0x80+0x40+9);
  78.                         write_dat('-');
  79.                         write_dat('0'+(uint)abs(position)/10000);
  80.                         write_dat('0'+(uint)abs(position)%10000/1000);
  81.                         write_dat('0'+(uint)abs(position)%1000/100);
  82.                         write_dat('0'+(uint)abs(position)%100/10);
  83.                         write_dat('0'+(uint)abs(position)%10);
  84.                 }
  85.                 else
  86.                 {
  87.                         write_com(0x80+0x40+9);
  88.                         write_dat('+');
  89.                         write_dat('0'+(uint)abs(position)/10000);
  90.                         write_dat('0'+(uint)abs(position)%10000/1000);
  91.                         write_dat('0'+(uint)position%1000/100);
  92.                         write_dat('0'+(uint)position%100/10);
  93.                         write_dat('0'+(uint)position%10);
  94.                 }
  95.                
  96.                 if(Start_Flag)
  97.                 {
  98.                         INT_PWM = pid_proc(Angle_End,Gyro_End,speed,position);
  99.                        
  100.                         Motor_Con(-INT_PWM,-INT_PWM);
  101.                        
  102.                 }
  103.         }
  104.        
  105. }

  106. void timer1() interrupt 3
  107. {
  108.         TL1 = 0x00;                    //定时10MS
  109.         TH1 = 0xB8;
  110.        
  111.         if(!Start_Flag)                //启动前的延时
  112.         {
  113.                 Init_Time++;
  114.                 if(Init_Time>=100) Start_Flag=1;
  115.         }
  116.        
  117.         if(Start_Flag)
  118.         {
  119.                 Get_Date();
  120.                 Kalman_Filter(Angel_accY,GYRO_X);
  121.                 Speed_Position_Get();
  122.                 speed_mr = speed_ml = 0;
  123.         }
  124. }
复制代码

所有程序51hei提供下载:
小车平衡STC稳定.zip (196.23 KB, 下载次数: 114)
回复

使用道具 举报

ID:1 发表于 2019-7-31 22:52 | 显示全部楼层
本帖需要重新编辑补全电路原理图,源码,详细说明与图片即可获得100+黑币(帖子下方有编辑按钮)
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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