卡曼滤波-python

# Kalman filter example demo in Python
# A Python implementation of the example given in pages 11-15 of "An
# Introduction to the Kalman Filter" by Greg Welch and Gary Bishop,
# University of North Carolina at Chapel Hill, Department of Computer
# Science, TR 95-041,
# http://www.cs.unc.edu/~welch/kalman/kalmanIntro.html
# by Andrew D. Straw
import numpy
import pylab
# intial parameters
n_iter = 50
sz = (n_iter,) # size of array
x = -0.37727 # truth value (typo in example at top of p. 13 calls this z)
z = numpy.random.normal(x,0.1,size=sz) # observations (normal about x, sigma=0.1)
Q = 1e-5 # process variance
# allocate space for arrays
xhat=numpy.zeros(sz)      # a posteri estimate of x
P=numpy.zeros(sz)         # a posteri error estimate
xhatminus=numpy.zeros(sz) # a priori estimate of x
Pminus=numpy.zeros(sz)    # a priori error estimate
K=numpy.zeros(sz)         # gain or blending factor
R = 0.1**2 # estimate of measurement variance, change to see effect
# intial guesses
xhat[0] = 0.0
P[0] = 1.0
for k in range(1,n_iter):
    # time update
    xhatminus[k] = xhat[k-1]
    Pminus[k] = P[k-1]+Q
    # measurement update
    K[k] = Pminus[k]/( Pminus[k]+R )
    xhat[k] = xhatminus[k]+K[k]*(z[k]-xhatminus[k])
    P[k] = (1-K[k])*Pminus[k]
pylab.figure()
pylab.plot(z,'k+',label='noisy measurements')
pylab.plot(xhat,'b-',label='a posteri estimate')
pylab.axhline(x,color='g',label='truth value')
pylab.legend()
pylab.xlabel('Iteration')
pylab.ylabel('Voltage')
pylab.figure()
valid_iter = range(1,n_iter) # Pminus not valid at step 0
pylab.plot(valid_iter,Pminus[valid_iter],label='a priori error estimate')
pylab.xlabel('Iteration')
pylab.ylabel('$(Voltage)^2$')
pylab.setp(pylab.gca(),'ylim',[0,.01])
pylab.show()


转自:http://www.cnblogs.com/zjuhjm/archive/2012/12/29/2838472.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
滤波是一种常用的数据处理技术,可以用于估计和预测系统的状态。它最初是由史蒂文·于1960年提出的。 Python提供了很多库和工具,可以帮助我们实现滤波算法。其中最常用的库是SciPy和NumPy。 首先,我们需要导入相关库。使用SciPy的`linalg`模块进行矩阵运算,使用NumPy的`matrix`模块构建矩阵。 接下来,我们需要定义系统的状态方程和观测方程。状态方程描述了系统的演化过程,观测方程描述了观测值和状态值之间的关系。 然后,我们需要初始化系统的状态向量和协方差矩阵。状态向量表示系统当前的状态,协方差矩阵表示系统状态的不确定性。 在每个时刻,我们通过观测值更新滤波器的状态估计。具体步骤如下: 1. 预测步骤:根据系统的状态方程,使用前一时刻的状态和控制输入预测当前时刻的状态。 2. 更新步骤:通过观测方程,根据当前时刻的观测值和预测的状态估计值,计算增益,然后更新状态估计值和协方差矩阵。 最后,我们可以根据滤波器的输出,得到系统状态的估计值。 需要注意的是,滤波是一种递归算法,即每个时刻的输出作为下一时刻的输入。因此,我们需要在每个时刻重复更新步骤,以获得最新的状态估计值。 总而言之,Python提供了丰富的库和工具,使得实现滤波算法变得非常简单。我们只需导入相关库,定义状态方程和观测方程,初始化系统状态,然后在每个时刻通过预测和更新步骤更新状态估计值即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值