标题:
STC12单片机做平衡车程序 mpu6050+L298N+直流减速电机
[打印本页]
作者:
生铁0
时间:
2019-7-31 16:21
标题:
STC12单片机做平衡车程序 mpu6050+L298N+直流减速电机
大家参考参考。
mpu6050+L298N+直流减速电机
单片机源程序如下:
#include <stc12c5a.h>
#include <intrins.h>
#include <stdio.h>
#include <math.h>
#include "kalman.h"
#include "lcd1602.h"
#include "mpu6050.h"
#include "pid_own.h"
#include "pwm_motor.h"
#include "spe_pos.h"
int INT_PWM;
unsigned int Init_Time=0,Start_Flag=0;
void main()
{
lcd_init();
InitMPU6050();
PWM_Motor_Init();
INT_Init();
P1M0=1;
P1M1=0;
while(1)
{
if(GYRO_X<0)
{
write_com(0x80);
write_dat('-');
write_dat('0'+(uchar)abs(GYRO_X)/100);
write_dat('0'+(uchar)abs(GYRO_X)%100/10);
write_dat('0'+(uchar)abs(GYRO_X)%10);
}
else
{
write_com(0x80);
write_dat('+');
write_dat('0'+(uchar)GYRO_X/100);
write_dat('0'+(uchar)GYRO_X%100/10);
write_dat('0'+(uchar)GYRO_X%10);
}
if(Angle_End<0)
{
write_com(0x80+0x40);
write_dat('-');
write_dat('0'+(uchar)abs(Angle_End)/100);
write_dat('0'+(uchar)abs(Angle_End)%100/10);
write_dat('0'+(uchar)abs(Angle_End)%10);
}
else
{
write_com(0x80+0x40);
write_dat('+');
write_dat('0'+(uchar)Angle_End/100);
write_dat('0'+(uchar)Angle_End%100/10);
write_dat('0'+(uchar)Angle_End%10);
}
if(speed<0)
{
write_com(0x80+9);
write_dat('-');
write_dat('0'+(uchar)abs(speed)/100);
write_dat('0'+(uchar)abs(speed)%100/10);
write_dat('0'+(uchar)abs(speed)%10);
}
else
{
write_com(0x80+9);
write_dat('+');
write_dat('0'+(uchar)speed/100);
write_dat('0'+(uchar)speed%100/10);
write_dat('0'+(uchar)speed%10);
}
if(position<0)
{
write_com(0x80+0x40+9);
write_dat('-');
write_dat('0'+(uint)abs(position)/10000);
write_dat('0'+(uint)abs(position)%10000/1000);
write_dat('0'+(uint)abs(position)%1000/100);
write_dat('0'+(uint)abs(position)%100/10);
write_dat('0'+(uint)abs(position)%10);
}
else
{
write_com(0x80+0x40+9);
write_dat('+');
write_dat('0'+(uint)abs(position)/10000);
write_dat('0'+(uint)abs(position)%10000/1000);
write_dat('0'+(uint)position%1000/100);
write_dat('0'+(uint)position%100/10);
write_dat('0'+(uint)position%10);
}
if(Start_Flag)
{
INT_PWM = pid_proc(Angle_End,Gyro_End,speed,position);
Motor_Con(-INT_PWM,-INT_PWM);
}
}
}
void timer1() interrupt 3
{
TL1 = 0x00; //定时10MS
TH1 = 0xB8;
if(!Start_Flag) //启动前的延时
{
Init_Time++;
if(Init_Time>=100) Start_Flag=1;
}
if(Start_Flag)
{
Get_Date();
Kalman_Filter(Angel_accY,GYRO_X);
Speed_Position_Get();
speed_mr = speed_ml = 0;
}
}
复制代码
所有程序51hei提供下载:
小车平衡STC稳定.zip
(196.23 KB, 下载次数: 114)
2019-7-31 16:21 上传
点击文件名下载附件
下载积分: 黑币 -5
作者:
admin
时间:
2019-7-31 22:52
本帖需要重新编辑补全电路原理图,源码,详细说明与图片即可获得100+黑币(帖子下方有编辑按钮)
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1