import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['figure.figsize'] = (10, 8)
n_iter = 50
sz = (n_iter,)
x = -0.37727
z = np.random.normal(x,0.1,size=sz)
Q = 1e-5
xhat=np.zeros(sz)
P=np.zeros(sz)
xhatminus=np.zeros(sz)
Pminus=np.zeros(sz)
K=np.zeros(sz)
R = 0.1**2
xhat[0] = 0.0
P[0] = 1.0
for k in range(1,n_iter):
xhatminus[k] = xhat[k-1]
Pminus[k] = P[k-1]+Q
K[k] = Pminus[k]/( Pminus[k]+R )
xhat[k] = xhatminus[k]+K[k]*(z[k]-xhatminus[k])
P[k] = (1-K[k])*Pminus[k]
plt.figure()
plt.plot(z,'k+',label='noisy measurements')
plt.plot(xhat,'b-',label='a posteri estimate')
plt.axhline(x,color='g',label='truth value')
plt.legend()
plt.title('Estimate vs. iteration step', fontweight='bold')
plt.xlabel('Iteration')
plt.ylabel('Voltage')
plt.figure()
valid_iter = range(1,n_iter)
plt.plot(valid_iter,Pminus[valid_iter],label='a priori error estimate')
plt.title('Estimated $it{mathbf{a priori}}$ error vs. iteration step', fontweight='bold')
plt.xlabel('Iteration')
plt.ylabel('$(Voltage)^2$')
plt.setp(plt.gca(),'ylim',[0,.01])
plt.show()
近期评论