我正在尝试用陀螺仪,加速度计和放大器构建指南针。卡尔曼滤波器 - 指南针和陀螺仪
我正在将acc值与magnometer值进行融合以获得方向(使用旋转矩阵)并且它工作得很好。
但是现在我想添加陀螺仪来帮助补偿磁传感器不准确的时候。所以我想用卡尔曼滤波器来融合这两个结果并得到一个很好的滤波结果(acc和mag已经使用lpf进行滤波)。
我的矩阵是:
state(Xk) => {Compass Heading, Rate from the gyro in that axis}.
transition(Fk) => {{1,dt},{0,1}}
measurement(Zk) => {Compass Heading, Rate from the gyro in that axis}
Hk => {{1,0},{0,1}}
Qk = > {0,0},{0,0}
Rk => {e^2(compass),0},{0,e^2(gyro)}
这是我的卡尔曼滤波器的实现:
public class KalmanFilter {
private Matrix x,F,Q,P,H,K,R;
private Matrix y,s;
public KalmanFilter(){
}
public void setInitialState(Matrix _x, Matrix _p){
this.x = _x;
this.P = _p;
}
public void update(Matrix z){
try {
y = MatrixMath.subtract(z, MatrixMath.multiply(H, x));
s = MatrixMath.add(MatrixMath.multiply(MatrixMath.multiply(H, P),
MatrixMath.transpose(H)), R);
K = MatrixMath.multiply(MatrixMath.multiply(P, H), MatrixMath.inverse(s));
x = MatrixMath.add(x, MatrixMath.multiply(K, y));
P = MatrixMath.subtract(P,
MatrixMath.multiply(MatrixMath.multiply(K, H), P));
} catch (IllegalDimensionException e) {
e.printStackTrace();
} catch (NoSquareException e) {
e.printStackTrace();
}
predict();
}
private void predict(){
try {
x = MatrixMath.multiply(F, x);
P = MatrixMath.add(Q, MatrixMath.multiply(MatrixMath.multiply(F, P),
MatrixMath.transpose(F)));
} catch (IllegalDimensionException e) {
e.printStackTrace();
}
}
public Matrix getStateMatirx(){
return x;
}
public Matrix getCovarianceMatrix(){
return P;
}
public void setMeasurementMatrix(Matrix h){
this.H = h;
}
public void setProcessNoiseMatrix(Matrix q){
this.Q = q;
}
public void setMeasurementNoiseMatrix(Matrix r){
this.R = r;
}
public void setTransformationMatrix(Matrix f){
this.F = f;
}
}
首先给出了这个初始值:
Xk => {0,0}
Pk => {1000,0},{0,1000}
然后我看的两个结果(卡尔曼一号和罗盘一号)。卡尔曼之一是从0开始,并以一定的速度增加,无论测量到的(指南针),它不会停止只是继续增加...
我不明白我在做什么错?
你为什么要自己融合这些数据?平台提供的产品有什么问题? – Ali 2013-03-07 16:16:33
Corrent我如果即时通讯错误,但Android只提供acc + mag融合 – user1396033 2013-03-07 16:18:23
不,AFAIK陀螺也被考虑。 – Ali 2013-03-07 16:29:54