找回密码
 立即注册

QQ登录

只需一步,快速开始

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

两轮平衡车源程序 直走+蓝牙

[复制链接]
跳转到指定楼层
楼主
stm32f103+减速电机


单片机源程序如下:
  1. /***************************************************************
  2. 自平衡程序
  3. ***************************************************************/
  4. #include "main.h"
  5. #define position_max 6000  //位置最大值
  6. int j=0;
  7. int position=0;
  8. int k=0;
  9. int i=0;
  10. int speed1=0;
  11. int speed=0;
  12. int acc_y=0;
  13. int acc_z=0;
  14. int gyr_x=0;
  15. int receive=0;
  16. int pwm=0;
  17. float G_X=0,A_X=0;
  18. float gyro_angle=0;
  19. float balan_angle=0;
  20. float balan_angle1=0;
  21. float G_X1=0,A_X1=0,G_X2=0,G_X3=0,GXERRO=0;
  22. float erro[3];
  23. int pwmneed=0;
  24. int pwmturn=0;
  25. void adjust(void);

  26. void judge()
  27. {
  28.   pwm=PID_control(erro[0],G_X)+PID_control_2(speed,position);
  29.   //pwm+=pwmneed;
  30.   if(pwm>100) //pwm限幅
  31.   {
  32.     pwm=100;
  33.   }
  34.   if(pwm<-100)
  35.   {
  36.     pwm=-100;
  37.   }
  38.   moto_right(pwm+pwmturn);   
  39.   moto_left(pwm-pwmturn);
  40.   if((balan_angle>45)||(balan_angle<(-45)))//角度大于45度 电机停止
  41.   {
  42.      moto_stop();
  43.   }
  44. }

  45. void bluetooth()
  46. {
  47.      while (!(IFG1 & URXIFG0));   
  48.      receive=U0RXBUF;
  49.      if(receive==0x01)  //直走
  50.      {
  51.        pwmneed=12;
  52.        pwmturn=0;
  53.      }
  54.       if(receive==0x02)//后退
  55.      {  
  56.        pwmneed=-13;
  57.        pwmturn=0;
  58.      }
  59.      if(receive==0x04)//右转
  60.      {
  61.        pwmturn=10;
  62.        pwmneed=0;

  63.      }
  64.         if(receive==0x03)//左转
  65.      {
  66.         pwmturn=-10;
  67.         pwmneed=0;
  68.      }
  69.           if(receive==0x00)//停
  70.      {
  71.         pwmturn=0;
  72.         pwmneed=0;
  73.      }
  74. }

  75. void main(void)
  76. {
  77.    WDTCTL=WDTPW+WDTHOLD;
  78.    init_all( );
  79.    InitMPU6050();        //初始化MPU6050
  80.    _EINT();           //开总中断
  81.    while(1)
  82.    {
  83.     bluetooth();
  84.   }
  85. }

  86. #pragma vector=PORT1_VECTOR   //外部中断计脉冲
  87. __interrupt void port1(void)
  88. {
  89.   
  90.   if(P1IFG&BIT0==BIT0)
  91.   {  
  92.     P1IFG=0X00;
  93.     if((P1IN&BIT1)==BIT1)
  94.     i++;
  95.     else
  96.     i--;
  97.   }
  98. }

  99. //定时器定时中断 10ms
  100. #pragma vector=TIMERA0_VECTOR
  101. __interrupt void Timer_A(void)
  102. {
  103.    adjust();
  104. }

  105. void adjust(void)
  106. {
  107.     acc_y=GetData(ACCEL_YOUT_H);               //读取三轴Y的 值
  108.     acc_z=GetData(ACCEL_ZOUT_H);               //读取三轴Z的 值
  109.     gyr_x=GetData(GYRO_XOUT_H);                //读取陀螺仪X的值
  110.     A_X=count_acc_angle(acc_y,acc_z);          //计算X角度a
  111.    
  112.     G_X=read_gyro(gyr_x);                  //计算X轴转动角速度
  113.     erro[2]=erro[1];
  114.     erro[1]=erro[0];
  115.     balan_angle=blance_filter(balan_angle,A_X,G_X); //互补滤波
  116.     erro[0]=balan_angle;
  117.    
  118.     speed=i; //计算速度
  119.     speed=(int)(0.3*speed+0.7*speed1);  //速度滤波
  120.     speed1=speed;
  121.     position+=speed;   //计算出位置
  122.     position+=pwmneed; //前进后退 积分
  123. ……………………

  124. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
自平衡小车 - 直走 蓝牙.zip (61.94 KB, 下载次数: 70)


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

使用道具 举报

沙发
ID:223788 发表于 2019-1-17 22:25 | 只看该作者
怎么找不到项目文件
代码是完整的???
回复

使用道具 举报

板凳
ID:283315 发表于 2019-1-22 16:47 | 只看该作者
这个是什么平台的 MDK5可以编译吗
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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