智能车学习(十三)——角度控制
一、手册代码以及图示

二、流程说明
1、角度计算函数说明
//============================================================================
//函数名称:void AngleCalculate(void)
//函数返回:无
//参数说明:无
//功能概要:车身角度计算。
//============================================================================
void AngleCalculate(void)
{
//读取加速度计
MMA8451_Read(); //读取陀螺仪
LS3G4200D_Read(); //取陀螺仪的X轴数据
VOLTAGE_GYRO = Gyro_X; //取加速度读计的Y轴数据
VOLTAGE_GRAVITY = Gray_Y; //陀螺仪零偏跟随
Gyro_Offset_Calculate(); if(VOLTAGE_GRAVITY > 1050) //限制加速度计读数-1050 ~1050
{
VOLTAGE_GRAVITY = 1050;
} if(VOLTAGE_GRAVITY <= -1050)
{
VOLTAGE_GRAVITY = - 1050;
} //加速度计读取的Y轴数值转换为角度
g_fGravityAngle = (VOLTAGE_GRAVITY - GRAVITY_OFFSET) * GRAVITY_ANGLE_RATIO; //陀螺仪提取角速度
g_fGyroscopeAngleSpeed = (VOLTAGE_GYRO - GYROSCOPE_OFFSET) * GYROSCOPE_ANGLE_RATIO; //车身角度计算
g_fCarAngle = g_fGyroscopeAngleIntegral;
fDeltaValue = (g_fGravityAngle - g_fCarAngle) / GRAVITY_ADJUST_TIME_CONSTANT;
g_fGyroscopeAngleIntegral += (g_fGyroscopeAngleSpeed + fDeltaValue) / GYROSCOPE_ANGLE_SIGMA_FREQUENCY;
}
首先是通过加速度计测得重力加速度,然后通过归一化(因为g和角度成正比),计算出角度。然后由于车子运动过程中,车子加速度会产生一定的影响,导致不是正比关系,所以使用陀螺仪进行修正,陀螺仪测得是角速度,积分之后就是角度,然后再和加速度计测得角度进行融合,然后反馈回去,使得系统平衡。
2、陀螺仪零点跟随
/============================================================================
//函数名称:void Gyro_Offset_Calculate()
//函数返回:无
//参数说明:无
//功能概要://陀螺仪三个轴的零点跟随 Cut_Gyro_X为经过处理后的值, Gyro_X为实际的读值,Gyro_X_Offset 为零点
//============================================================================
void Gyro_Offset_Calculate()
{
float Cut_Gyro_X; //减去偏移值得到的实时值
Cut_Gyro_X = Gyro_X - GYROSCOPE_OFFSET; //根据实时值,修改零偏置
if(Cut_Gyro_X>=2)
{
GYROSCOPE_OFFSET += 0.001;
}
else if(Cut_Gyro_X<=-2)
{
GYROSCOPE_OFFSET -= 0.001;
}
else
{
GYROSCOPE_OFFSET = GYROSCOPE_OFFSET * 0.99 + 0.01 * Gyro_X;
}
//开机2秒进行跟随
if (Clocks_Gyro <= 400)
{
GYROSCOPE_OFFSET = GYROSCOPE_OFFSET * 0.5 + 0.5 * Gyro_X;
} }
根据实时值,修改零偏值。
3、其中有一些参数设置:
/***************直立控制*****************/ float g_fGravityAngle = 0; //加速度计转换来的角度
float g_fGyroscopeAngleSpeed = 0; //陀螺仪转换来的角速度
float g_fCarAngle = 0; //车身角度 float VOLTAGE_GYRO = 0; //定义陀螺仪(选X,Y,Z)
float VOLTAGE_GRAVITY = 0; //定义加速度计(选X,Y,Z) float GRAVITY_OFFSET = 27; //加速度计零偏
float GRAVITY_ANGLE_RATIO = (90 /(1050.0 - 27)) ; //加速度计归一化因子 float GYROSCOPE_OFFSET = 0 ; //陀螺仪零偏移
float GYROSCOPE_ANGLE_RATIO = 1.780; //归一化因子 float GRAVITY_ADJUST_TIME_CONSTANT = 2; //陀螺仪加速度计加和的比例因子
float GYROSCOPE_ANGLE_SIGMA_FREQUENCY = 200; //积分的频率 float Clocks_Gyro = 0; //开机2s内进行陀螺仪零点比对
智能车学习(十三)——角度控制的更多相关文章
- 智能车学习(十五)——K60野火2013版例程
一.中断函数注册方法: 1.格式: 配置某个功能的中断 注册中断函数 开启中断 2.一个例子 pit_init_ms(PIT0,);//定时中断初始化 set_vector_handler(PIT0_ ...
- 智能车学习(二十三)——浅谈心得体会
因为毕竟是竞赛,跟学校挂钩,没办法开源代码和算法完成思路,所以不能详细写太多,如果可以等价交换的话,应该还是可以向领导申请一下的. 在厦大信科通信系,参加这个比赛,大家都觉得性 ...
- 智能车学习(二十二)——浅谈速度控制
一.经典PID控制 使用遇限反向PID会比较适合有加减速的车子,使用变速积分适合跑匀速的车子.然后这种方法的条件下,一定要尽可能缩短控制周期.. 二.PID加棒棒控制 针对 ...
- 智能车学习(二十)——浅谈C车硬连接与软连接
一.为何要追求软连接? 车子进行软连接之后,可以达到一种效果,就是在高速过程中,车子如果快要发生侧翻的时候,只会跳一个后轮,且只是轻微,而前轮如果进行的内倾,就可以让前轮最大面积接触,增大 ...
- 智能车学习(十八)——电机学习
一.C车电机选择 1.摘要: 因为C车模在四轮车的优势是有两个电机,可以进行主动差速,劣势是电机太弱了....所以如何选择电机,就是个钱的问题了,电机多一点,就比较好选,但是C车电机跑多了就 ...
- 智能车学习(十七)——舵机学习
一.舵机的结构 舵机简单的说就是集成了直流电机.电机控制器和减速器等,并封装在一个便于安装的外壳里的伺服单元.能够利用简单的输入信号比较精确的转动给定角度的电机系统.舵机安装了一个电位器(或 ...
- 智能车学习(十一)——陀螺仪学习
一.学习说明 感觉就是配置I2C通信,然后直接移植51代码... 二.代码分享: 1.头文件: #ifndef I2C_GYRO_H_ #define I2C_GYRO_H_ /*********** ...
- 智能车学习(六)——OLED屏幕使用
一.代码展示 1.头文件: #ifndef OLED_H_ #define OLED_H_ extern unsigned char Draw[]; extern const unsigned cha ...
- 智能车学习(二)—— GPIO学习
一.概述 使用的是蓝宇的底层,主要有初始化管脚,设置管脚状态,反转管脚状态等. 二.代码重述: 1.头文件gpio.h #ifndef GPIO_H //防止重复定义(gpio_H 开头) #defi ...
随机推荐
- settings的保存位置
xp:C:\Documents and Settings\Administrator\Local Settings\Application Data\ win8 C:\Users\XXX\AppDat ...
- ZOJ 3812 We Need Medicine(dp、背包、状态压缩、路径记录)
参考:http://blog.csdn.net/qian99/article/details/39138329 参考的链接里说明得很好,注释也很好...thanks for sharing 朴素的想法 ...
- HDU 4870 Rating(概率、期望、推公式) && ZOJ 3415 Zhou Yu
其实zoj 3415不是应该叫Yu Zhou吗...碰到ZOJ 3415之后用了第二个参考网址的方法去求通项,然后这次碰到4870不会搞.参考了chanme的,然后重新把周瑜跟排名都反复推导(不是推倒 ...
- Divide and conquer:4 Values whose Sum is 0(POJ 2785)
找四个数的和为0 题目大意:给定四个集合,要你每个集合选4个数字,组成和为0 这题是3977的简单版,只要和是0就可以了 #include <iostream> #include < ...
- NSBundle的pathForResource:ofType: 返回值为nil问题
一.问题描述 在处理XML的过程中,在项目中手动创建名为“data.xml”的文件,加入网上找的内容 <?xml version="1.0" encoding="u ...
- c++从文件中读取特定字符串问题的总结
1.每次从文件中读出一行作为一个字符串 可以用ifstream()函数来打开一个文件,然后用while加getline()函数即可每次读一行文件,直到文件结束 #include<unistd.h ...
- WP开发资源
wp开发:连续两次点击返回键退出程序的设计: http://hi.baidu.com/youngytj/item/6be317719cc371306cc37ce4 X http://www.cnblo ...
- spring mvc 重定向问题
(1)我在后台一个controller跳转到另一个controller,为什么有这种需求呢,是这样的.我有一个列表页面,然后我会进行新增操作,新增在后台完成之后我要跳转到列表页面,不需要传递参数,列表 ...
- Parallels Destop软件配置
Parallels Destop个人感觉最好用的mac虚拟win软件 http://pan.baidu.com/s/1jHFwIGm 密码:ab21百度云下载(或者下载自己百度云的) 安装方法: 1. ...
- 【C语言】结构体
不能定义 struct Node { struct Node a; int b; } 这样的结构,因为为了建立Node 需要 建立一个新的Node a, 可为了建立Node a, 还需要再建立Node ...