卡尔曼滤波 C++

#include <iostream>
#include <Eigen/Dense>

using namespace Eigen;

// Kalman Filter function
void KalmanFilter(const MatrixXd& F, const MatrixXd& Q, const MatrixXd& R, MatrixXd& P, VectorXd& state_mear, VectorXd& state_hat) {
    // Prediction step
    state_hat = F * state_mear;
    P = F * P * F.transpose() + Q;

    // Update step
    VectorXd y = state_mear - state_hat;
    MatrixXd H = MatrixXd::Identity(state_hat.size(), state_mear.size());
    MatrixXd S = H * P * H.transpose() + R;
    MatrixXd K = P * H.transpose() * S.inverse();
    state_hat = state_hat + K * y;
    P = (MatrixXd::Identity(state_hat.size(), state_hat.size()) - K * H) * P;
}

int main() {
    // Define initial state estimate
    VectorXd state_hat(6);
    state_hat << 0, 0, 0, 0, 0, 0;

    // Define initial state covariance matrix
    MatrixXd P(6, 6);
    P << 1, 0, 0, 0, 0, 0,
         0, 1, 0, 0, 0, 0,
         0, 0, 1, 0, 0, 0,
         0, 0, 0, 1, 0, 0,
         0, 0, 0, 0, 1, 0,
         0, 0, 0, 0, 0, 1;

    // Define system dynamics matrix F
    MatrixXd F(6, 6);
    F << 1, 0, 0, 1, 0, 0,
         0, 1, 0, 0, 1, 0,
         0, 0, 1, 0, 0, 1,
         0, 0, 0, 1, 0, 0,
         0, 0, 0, 0, 1, 0,
         0, 0, 0, 0, 0, 1;

    // Define process noise covariance matrix Q
    MatrixXd Q(6, 6);
    Q << 0.01, 0, 0, 0, 0, 0,
         0, 0.01, 0, 0, 0, 0,
         0, 0, 0.01, 0, 0, 0,
         0, 0, 0, 0.01, 0, 0,
         0, 0, 0, 0, 0.01, 0,
         0, 0, 0, 0, 0, 0.01;

    // Define measurement noise covariance matrix R
    MatrixXd R(6, 6);
    R << 1, 0, 0, 0, 0, 0,
         0, 1, 0, 0, 0, 0,
         0, 0, 1, 0, 0, 0,
         0, 0, 0, 1, 0, 0,
         0, 0, 0, 0, 1, 0,
         0, 0, 0, 0, 0, 1;

    // Define a sample measurement in the form of target vector
    VectorXd target(3);
    target << 1.2, 3.4, 5.6;

    // Map target vector to state_mear
    VectorXd state_mear(6);
    state_mear << target[0], 0, target[1], 0, target[2], 0;

    // Call Kalman Filter function
    KalmanFilter(F, Q, R, P, state_mear, state_hat);

    std::cout << "Updated state estimate:\n" << state_hat << std::endl;

    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值