搜索
bottom↓
回复: 0

卡尔曼滤波请教

[复制链接]

出0入0汤圆

发表于 2016-6-22 16:16:13 | 显示全部楼层 |阅读模式
下面是卡尔曼滤波程序的一种,在很多程序里都看到过,但是不知道如何使用,请大家讲解一下
static float gyro,acceler,Vref=2.048,fangdabeishu=24.6;
static float acc,gg,acce;

static float angle, angle_dot;                 
static const float Q_angle = 0.001, Q_gyro = 0.003, R_angle = 0.5, dt = 0.006;
static float PP[2][2] = {{1,0},{0,1}};
static float Pdot[4]  = {0,0,0,0};
static const char C_0 = 1;
static float q_bias, angle_err, PCt_0, PCt_1, E, K_0, K_1, t_0, t_1;
static float gyro,acceler;

void Kalman_Filter(float angle_m,float gyro_m)               
{
          angle += (gyro_m-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 = angle_m-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;
          angle_dot = (gyro_m-q_bias);
}

阿莫论坛20周年了!感谢大家的支持与爱护!!

如果天空是黑暗的,那就摸黑生存;
如果发出声音是危险的,那就保持沉默;
如果自觉无力发光,那就蜷伏于牆角。
但是,不要习惯了黑暗就为黑暗辩护;
也不要为自己的苟且而得意;
不要嘲讽那些比自己更勇敢的人。
我们可以卑微如尘土,但不可扭曲如蛆虫。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-9-21 01:28

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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