智能车制作

 找回密码
 注册

扫一扫,访问微社区

楼主: Eternalve
打印 上一主题 下一主题

卡尔曼 角度 波型 求指导 谢谢

  [复制链接]

2

主题

48

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2603
威望
1282
贡献
807
兑换币
851
注册时间
2012-11-2
在线时间
257 小时
毕业学校
华电
31#
 楼主| 发表于 2014-2-21 21:54:37 | 只看该作者
林JJ 发表于 2014-2-21 14:50
我想问一下,我用的是数字加速度器,放着不动的时候读出来的值会在5的范围内变动正常码?变换好角度之后就可 ...

最大值  最小值是多少呢
5大概占百分之多少呀
如果 5/几千  那应该可以吧

前期数据处理要仔细一点额
回复 支持 反对

使用道具 举报

27

主题

332

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1842
威望
967
贡献
517
兑换币
575
注册时间
2012-12-20
在线时间
179 小时
毕业学校
广工
32#
发表于 2014-2-22 10:02:45 | 只看该作者
Eternalve 发表于 2014-2-21 21:54
最大值  最小值是多少呢
5大概占百分之多少呀
如果 5/几千  那应该可以吧

读出来最大最小是-128到127,比如放水平的话它就会在-1到3的范围波动,我还没有进行角度换算
回复 支持 反对

使用道具 举报

2

主题

48

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2603
威望
1282
贡献
807
兑换币
851
注册时间
2012-11-2
在线时间
257 小时
毕业学校
华电
33#
 楼主| 发表于 2014-2-22 18:25:50 | 只看该作者
林JJ 发表于 2014-2-22 10:02
读出来最大最小是-128到127,比如放水平的话它就会在-1到3的范围波动,我还没有进行角度换算

应该还行吧  毕竟是数字的   也改不了太多东西是几位精度的呀   可以多读几位哦   8位感觉有点少  12位、14位比较好
可以直接用  愿意的话也可以好好看看手册   初始化的时候设置一下寄存器
回复 支持 反对

使用道具 举报

27

主题

332

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1842
威望
967
贡献
517
兑换币
575
注册时间
2012-12-20
在线时间
179 小时
毕业学校
广工
34#
发表于 2014-2-22 18:55:57 | 只看该作者
Eternalve 发表于 2014-2-22 18:25
应该还行吧  毕竟是数字的   也改不了太多东西是几位精度的呀   可以多读几位哦   8位感觉有点少  12位、 ...

谢谢
回复 支持 反对

使用道具 举报

5

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
554
威望
267
贡献
137
兑换币
171
注册时间
2013-9-22
在线时间
75 小时
35#
发表于 2014-2-23 16:55:41 | 只看该作者
请问楼主 你的卡尔曼得出来的值变化范围多大 我读出来的值才有一点几  是不时正常值? 还有调的值是不是主要调R ??
回复 支持 反对

使用道具 举报

2

主题

48

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2603
威望
1282
贡献
807
兑换币
851
注册时间
2012-11-2
在线时间
257 小时
毕业学校
华电
36#
 楼主| 发表于 2014-2-23 16:58:18 | 只看该作者
鸟人 发表于 2014-2-23 16:55
请问楼主 你的卡尔曼得出来的值变化范围多大 我读出来的值才有一点几  是不时正常值? 还有调的值是不是主要 ...

我是加速度计arctan算的角度   出来的一点几是弧度(rad)  要自己转化成角度  或者其他度量
前面的那个卡尔曼程序  主要就是调Q R 的相对大小
可以固定Q=1;  调R   
也可以固定R=1;调Q
回复 支持 反对

使用道具 举报

5

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
554
威望
267
贡献
137
兑换币
171
注册时间
2013-9-22
在线时间
75 小时
37#
发表于 2014-2-24 09:54:14 | 只看该作者
那你的X轴的加速度零点值是陀螺仪水平时还是小车直立时的输出值? 角速度和Z轴零点值是直立时输出值??
回复 支持 反对

使用道具 举报

65

主题

696

帖子

0

精华

常驻嘉宾

Rank: 8Rank: 8

积分
3631

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

威望
1886
贡献
1057
兑换币
1118
注册时间
2013-4-23
在线时间
344 小时
38#
发表于 2014-2-24 09:57:59 | 只看该作者
vccv
回复 支持 反对

使用道具 举报

2

主题

48

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2603
威望
1282
贡献
807
兑换币
851
注册时间
2012-11-2
在线时间
257 小时
毕业学校
华电
39#
 楼主| 发表于 2014-2-24 12:59:52 | 只看该作者
鸟人 发表于 2014-2-24 09:54
那你的X轴的加速度零点值是陀螺仪水平时还是小车直立时的输出值? 角速度和Z轴零点值是直立时输出值??

我的“零点”就是小车处于平衡位置不动时加速度计的计算值
不动的时候  陀螺仪处于零点   有绕陀螺仪旋转的运动是    采集到的陀螺仪ad电压值有变化
不知道说到点上了没有
回复 支持 反对

使用道具 举报

5

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
554
威望
267
贡献
137
兑换币
171
注册时间
2013-9-22
在线时间
75 小时
40#
发表于 2014-2-24 20:02:31 | 只看该作者
我的三个零点值也是平衡时的输出值 我滤出来波如下
黄色是加速度算出来的
红色是角速度  紫色是卡尔曼算出来得角度值
感觉滤出来的波形 粗糙而且还有尖峰
你帮我看看是哪里出问题

程序是这个
    Gyro  = g_ADvalue[0];   
    Acc_x = g_ADvalue[2];
    Acc_z = g_ADvalue[1];
    OutData[1]=Acc_z;
   
   if(Gyro > 4090) Gyro += 1000;
   else
   if(Gyro > 4084) Gyro += 500;
   
   if(Gyro < 55)   Gyro -= 1000;
   else
   if(Gyro < 60)   Gyro -= 500;
      
    Acc_x = Acc_x - 1389.6;
    Acc_z = Acc_z - 2450.0;
    Gyro  = Gyro  - 2860.4;
    Gyro_Data = Gyro;
   
    OutData[0] = Gyro_Data;
    accelerometer_angle =atan2f(Acc_z,Acc_x);
    OutData[2] = accelerometer_angle*1000;

    gyroscope_rate = Gyro*0.0023;         //参考电压3.3v 12位ADC 放大9.1倍 enc-03 0.67mv/deg./sec.
   
                                          //(3300/4096)/(0.67*9.1)*(3.14/180) =  0.0023
   
    NowData = RealData + gyroscope_rate*0.04;                 //1.预估计 X(k|k-1) = A(k,k-1)*X(k-1|k-1) + B(k)*u(k)
    NowData_P = sqrt(Q*Q+RealData_P*RealData_P);              //2.计算预估计协方差矩阵   P(k|k-1) = A(k,k-1)*P(k-1|k-1)*A(k,k-1)'+Q(k)
    Kg = sqrt(NowData_P*NowData_P/(NowData_P*NowData_P+R*R)); //3.计算卡尔曼增益矩阵 K(k) = P(k|k-1)*H(k)' / (H(k)*P(k|k-1)*H(k)' + R(k))
    RealData = NowData + Kg*(accelerometer_angle - NowData);  //4.更新估计 X(k|k) = X(k|k-1)+K(k)*(Z(k)-H(k)*X(k|k-1))
    RealData_P = sqrt((1-Kg)*NowData_P*NowData_P);            //5.计算更新后估计协防差矩阵 P(k|k) =(I-K(k)*H(k))*P(k|k-1)
   
    QingJiao =  RealData;  
   
   
    OutData[3] = QingJiao*1000;//*180/3.141592653;
   // OutPut_Data();

本帖子中包含更多资源

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

x
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-25 14:31 , Processed in 0.082179 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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