找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1525|回復: 0
打印 上一主題 下一主題
收起左側(cè)

卡爾曼濾波

[復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:323888 發(fā)表于 2018-5-7 00:42 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
#include "include.h"


s16    Angle=0;
float  Gyro_x=0;       
float  Q_angle=1;//0.0001;  
float  Q_gyro=0.3;//0.00003;
float  R_angle=0.01;
float  dt=0.001;//0.005;                         
float  C_0 = 1.0;
float  Q_bias=0, Angle_err=0;
float  PCt_0=0.0, PCt_1=0, E=0.0;
float  K_0=0.0, K_1=0.0, t_0=0.0, t_1=0.0;
float  Pdot[4] ={0,0,0,0};
float  PP[2][2] = { { 1.0, 0 },{ 0, 1.0 } };

void Kalman_Filter(int Gyro,int Accel)       
{
Angle+=(Gyro - Q_bias) * dt;         

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;

Angle_err =Accel-Angle;

PCt_0 = C_0 * PP[0][0];
PCt_1 = C_0 * PP[1][0];

E = R_angle + C_0 * PCt_0;

K_0 = PCt_0 / E;
K_1 = PCt_1 / E;

t_0 = PCt_0;
t_1 = C_0 * PP[0][1];

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;

Angle        += K_0 * Angle_err;         
Q_bias        += K_1 * Angle_err;         
Gyro_x   = Gyro - Q_bias;


}

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表