float Angle = 0.0;//卡尔曼滤波器的输出值,最优估计的角度
//float Gyro_x = 0.0;//卡尔曼滤波器的输出值,最优估计的角速度
float Q_angle = 0.001;//陀螺仪噪声的协方差(估计过程的误差协方差)
float Q_gyro = 0.003;//陀螺仪漂移噪声的协方差(估计过程的误差协方差)
float R_angle = 0.5;//加速度计测量噪声的协方差
float dt = 0.005;//积分时间,dt为滤波器采样时间(秒)
char C_0 = 1;//H矩阵的一个数
float Q_bias = 0,Angle_err = 0;//Q_bias为陀螺仪漂移
float PCt_0 = 0,PCt_1 = 0,E = 0;//中间变量
float K_0 = 0,K_1 = 0,t_0 = 0,t_1= 0;//K是卡尔曼增益,t是中间变量
float Pdot[4] = {0,0,0,0};//计算P矩阵的中间变量
float PP[2][2] = {{1,0},{0,1}};//公式中P矩阵,X的协方差 //gx...分别为重力加速度在三个轴向的分力 由加速度计测得
//ax...分别为角速度在三个轴向的角速度 由陀螺仪测得
//最后得到最终滤波完毕的x、y、z方向的角度值(°)
//调用下面的函数应该如下调用,使用atan2更为准确
//Kalman_Filter(gx,atan2(ay,sqrt(ax*ax+az*az))*1800/3.14);//与x轴角度
//Kalman_Filter(gx,atan(ay/sqrt(ax*ax+az*az))*1800/3.14);//与x轴角度
//三个方位具体带入如下
//atan(sqrt(ax*ax+ay*ay)/z)*1800/3.14;
//atan(ay/sqrt(ax*ax+az*az))*1800/3.14;
//atan(ax/sqrt(ay*ay+az*az))*1800/3.14; void Kalman_Filter(float Gyro,float Accel)//Gyro陀螺仪的测量值,Accel加速度计的角度计算值
{
Angle+=(Gyro-Q_bias)*dt;
//角度测量模型方程,角度估计值=上一次的最优角度+(角速度-上一次的最优零漂)*dt为滤波器采样时间(秒)
//就漂移来说认为每次都是相同的Q_bias=Q_bias Pdot[0] = Q_angle - PP[0][1] - PP[1][0];
Pdot[1] = -PP[1][1];
Pdot[2] = -PP[1][1];
Pdot[3] = Q_gyro; PP[0][0] += Pdot[0] * dt;
PP[0][1] += Pdot[1] * dt;
PP[1][0] += Pdot[2] * dt;
PP[1][1] += Pdot[3] * dt; PCt_0 = C_0 * PP[0][0];//矩阵乘法的中间变量
PCt_1 = C_0 * PP[1][0];//C_0 = 1
E = R_angle + C_0 * PCt_0;//分母
K_0 = PCt_0 / E;//卡尔曼增益,两个,一个是Angle的,一个是Q_bias的
K_1 = PCt_1 / E; Angle_err = Accel - Angle;
Angle += K_0 * Angle_err;//计算最优角度
Q_bias += K_1 * Angle_err;//计算最优零漂
//Gyro_x = Gyro - Q_bias;//计算得最优角速度 t_0 = PCt_0;//矩阵计算中间变量,相当于a
t_1 = C_0 * PP[0][1];//矩阵计算中间变量,相当于b PP[0][0]-=K_0 * t_0;
PP[0][1]-=K_0 * t_1;
PP[1][0]-=K_1 * t_0;
PP[1][1]-=K_1 * t_1; }

卡尔曼滤波法C编程的更多相关文章

  1. 概率编程:《贝叶斯方法概率编程与贝叶斯推断》中文PDF+英文PDF+代码

    贝叶斯推理的方法非常自然和极其强大.然而,大多数图书讨论贝叶斯推理,依赖于非常复杂的数学分析和人工的例子,使没有强大数学背景的人无法接触.<贝叶斯方法概率编程与贝叶斯推断>从编程.计算的角 ...

  2. 8皇后-----回溯法C++编程练习

    /* * 八皇后问题回溯法编程练习 * 在8×8的棋盘上,放置8个皇后,两个皇后之间不能两两攻击 * 也即,直线,垂直45度.135度方向不能出现两个皇后 * * copyright Michael ...

  3. 匈牙利命名法,骆驼命名法(camel),帕斯卡(Pascal)命名法(转)

    一.匈牙利命名法      Windows 编程中用到的变量(还包括宏)的命名规则匈牙利命名法,这种命名技术是由一位能干的 Microsoft 程序员查尔斯·西蒙尼(Charles Simonyi) ...

  4. NLP点滴——文本相似度

    [TOC] 前言 在自然语言处理过程中,经常会涉及到如何度量两个文本之间的相似性,我们都知道文本是一种高维的语义空间,如何对其进行抽象分解,从而能够站在数学角度去量化其相似性.而有了文本之间相似性的度 ...

  5. python编码规范

    python编码规范 文件及目录规范 文件保存为 utf-8 格式. 程序首行必须为编码声明:# -*- coding:utf-8 -*- 文件名全部小写. 代码风格 空格 设置用空格符替换TAB符. ...

  6. 从零开始山寨Caffe·壹:仰望星空与脚踏实地

    请以“仰望星空与脚踏实地”作为题目,写一篇不少于800字的文章.除诗歌外,文体不限. ——2010·北京卷 仰望星空 规范性 Caffe诞生于12年末,如果偏要形容一下这个框架,可以用"须敬 ...

  7. Unity3.0基于约定的自动注册机制

    前文<Unity2.0容器自动注册机制>中,介绍了如何在 Unity 2.0 版本中使用 Auto Registration 自动注册机制.在 Unity 3.0 版本中(2013年),新 ...

  8. Eviews 9.0新功能——估计方法(ARDL、面板自回归、门限回归)

    每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 9.2 估计功能 eviews9.0下载链接: ...

  9. [转]EM算法(Expectation Maximization Algorithm)详解

    https://blog.csdn.net/zhihua_oba/article/details/73776553 EM算法(Expectation Maximization Algorithm)详解 ...

随机推荐

  1. DirectSound---3D环境

    DirectSound对于单声道的Wav文件(或者说对于单声道的PCM音频数据)提供了内置3D音效的模拟,你能够控制每一个声源和收听者的立体位置,对移动的物体应用多普勒效果等等.在单个应用程序中,可以 ...

  2. Keras官方中文文档:关于Keras模型

    关于Keras模型 Keras有两种类型的模型,序贯模型(Sequential)和函数式模型(Model),函数式模型应用更为广泛,序贯模型是函数式模型的一种特殊情况. 两类模型有一些方法是相同的: ...

  3. JS实现全选功能

    000. 开始 学习JS有一段时间了,最近看了一些JS练手的小demo实例,自己也尝试着用JS进行实现. 全选功能是在很多注册页面.获取用户兴趣爱好.让用户勾选一些选项等页面中常见的一种效果,主要有全 ...

  4. 【CJOJ2484】【Luogu2805】最小函数值(函数最小值)

    题面 Description 有n个函数,分别为F1,F2,...,Fn.定义 Fi(x)=Aix2+Bix+Ci(x∈N∗)Fi(x)=Aix2+Bix+Ci(x∈N∗) .给定这些Ai.Bi和Ci ...

  5. [BZOJ3110][ZJOI2013]K大数查询(整体二分)

    BZOJ Luogu sol 整体二分,其实很简单的啦. 对所有询问二分一个答案mid,把所有修改操作中数字大于mid的做一个区间覆盖(区间加1) 查询就是区间查询 然后左右分一分即可 注意是第k大 ...

  6. [BZOJ1212][HNOI2004]L语言

    BZOJ Luogu sol 设\(f_i\)表示文章的前\(i\)个字符是否可以被理解.每次匹配要暴跳\(fail\)到根,转移就是\(f_i|=f_{i-len}\),其中\(len\)是某个可以 ...

  7. Java 容器之Hashset 详解

    Java 容器之Hashset 详解.http://blog.csdn.net/nvd11/article/details/27716511

  8. ValueError: Cannot feed value of shape ..

    这里x_,y_是两个数字,当我运行时 with tf.Session() as sess: #定义session对象生成器 for step in range(201) : sess.run(trai ...

  9. 项目角度谈矢量切片运用以及Geoserver处理自定义规格矢量切片方案

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1. 背景 矢量切图方案目前已经是很常见的一个方案,在2016年时团队 ...

  10. 电路ppt作业

    例二 例三 3.例一