智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 1762|回复: 8
打印 上一主题 下一主题

求赐教,卡尔曼滤波,有反向过冲!

[复制链接]

2

主题

9

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
277
威望
151
贡献
84
兑换币
84
注册时间
2013-9-14
在线时间
21 小时
毕业学校
辽宁工程技术大学
跳转到指定楼层
1#
发表于 2015-9-24 10:10:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
file:///C:\Users\acer PC\AppData\Roaming\Tencent\Users\1622542013\QQ\WinTemp\RichOle\_))~4}APN`GRRU$EKG%354S.pngfile:///C:\Users\acer PC\AppData\Roaming\Tencent\Users\1622542013\QQ\WinTemp\RichOle\_))~4}APN`GRRU$EKG%354S.png

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
回复

使用道具 举报

2

主题

9

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
277
威望
151
贡献
84
兑换币
84
注册时间
2013-9-14
在线时间
21 小时
毕业学校
辽宁工程技术大学
2#
 楼主| 发表于 2015-9-24 10:11:14 | 只看该作者
float  Q_angle=0.001;//0.0001;  
float  Q_gyro=0.00001;//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;


}
回复 支持 反对

使用道具 举报

2

主题

9

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
277
威望
151
贡献
84
兑换币
84
注册时间
2013-9-14
在线时间
21 小时
毕业学校
辽宁工程技术大学
3#
 楼主| 发表于 2015-9-24 10:11:48 | 只看该作者
求看看我的程序,还要调哪个参数,才能去掉反向过冲啊
回复 支持 反对

使用道具 举报

34

主题

452

帖子

0

精华

杰出人士

Rank: 12Rank: 12Rank: 12

积分
14046

优秀会员奖章活跃会员奖章在线王奖章

威望
6066
贡献
2554
兑换币
4050
注册时间
2013-7-29
在线时间
2713 小时
毕业学校
南京气象学院
4#
发表于 2015-9-24 10:17:45 | 只看该作者
阿乾 发表于 2015-9-24 10:11
求看看我的程序,还要调哪个参数,才能去掉反向过冲啊

一边过冲,一边跟踪不够。你的dt设置错了。
回复 支持 反对

使用道具 举报

2

主题

9

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
277
威望
151
贡献
84
兑换币
84
注册时间
2013-9-14
在线时间
21 小时
毕业学校
辽宁工程技术大学
5#
 楼主| 发表于 2015-9-24 10:43:06 | 只看该作者
额,我的定时是1ms,处理一次。我设的是0.001.我调整下试试
回复 支持 反对

使用道具 举报

2

主题

9

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
277
威望
151
贡献
84
兑换币
84
注册时间
2013-9-14
在线时间
21 小时
毕业学校
辽宁工程技术大学
6#
 楼主| 发表于 2015-9-24 10:45:21 | 只看该作者
何俊 发表于 2015-9-24 10:17
一边过冲,一边跟踪不够。你的dt设置错了。

我试试调下dt。我的中断定时是1ms一次采集和处理。我设的是0.001
回复 支持 反对

使用道具 举报

2

主题

9

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
277
威望
151
贡献
84
兑换币
84
注册时间
2013-9-14
在线时间
21 小时
毕业学校
辽宁工程技术大学
7#
 楼主| 发表于 2015-9-24 10:57:47 | 只看该作者
何俊 发表于 2015-9-24 10:17
一边过冲,一边跟踪不够。你的dt设置错了。

求qq,求赐教
回复 支持 反对

使用道具 举报

5

主题

348

帖子

0

精华

常驻嘉宾

Rank: 8Rank: 8

积分
4680

优秀会员奖章活跃会员奖章在线王奖章论坛元老奖章

威望
2065
贡献
1355
兑换币
1329
注册时间
2014-3-5
在线时间
630 小时
毕业学校
重庆大学
8#
发表于 2015-9-24 20:23:43 | 只看该作者

float  Q_angle=0.01
float  Q_gyro=0.003
float  R_angle=10
float  dt=0.001;//0.005;   
回复 支持 反对

使用道具 举报

1

主题

7

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
威望
104
贡献
68
兑换币
66
注册时间
2017-1-7
在线时间
21 小时
毕业学校
嘉兴学院
9#
发表于 2017-3-18 13:26:41 | 只看该作者
请问楼主怎么解决的?
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

关于我们|联系我们|小黑屋|智能车制作 ( 黑ICP备2022002344号

GMT+8, 2024-11-8 03:39 , Processed in 0.050652 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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