[12]发明专利申请公布说明书
[21]申请号200710099440.7
[51]Int.CI.
G06F 17/00 (2006.01)
[43]公开日2007年10月17日[22]申请日2007.05.21[21]申请号200710099440.7
[71]申请人北京理工大学
地址100081北京市海淀区中关村南大街5号[72]发明人赵清杰 王法胜 王巍
[11]公开号CN 101055563A
[74]专利代理机构北京理工大学专利中心
代理人张利萍
权利要求书 1 页 说明书 6 页 附图 3 页
[54]发明名称
基于多建议分布的粒子滤波方法
[57]摘要
本发明涉及基于多建议分布的粒子滤波方法,属于信号处理、人工智能和计算机视觉领域。本发明在粒子滤波器的框架内使用多种建议分布:先验概率分布、扩展卡尔曼滤波器、unscented卡尔曼滤波器等,采用分治采样策略来处理样本粒子,把总的粒子数分成多个部分,分别从不同的建议分布中提取,这样可以降低粒子滤波器的运行时间,提高运行效率,而不损失粒子滤波器的估计精度。用户可以根据自己对时间和精度的需求进行参数设置。在涉及非线性滤波问题的领域具有广泛的应用前景。
200710099440.7
权 利 要 求 书
第1/1页
1、基于多建议分布的粒子滤波方法,其特征在于:包括以下步骤: 1)首先初始化一组(N个)样本粒子,并设置其初始的均值和方差; 2)对于c*N个粒子:
(1)首先使用UKF进行粒子传递和更新,获得关于该时刻状态的估计 xk
(i)
ukf;
(2)使用EKF重复粒子更新过程,并以第(1)步中得到的状态估计作为输
入。得到该时刻最终的估计量 xk
(i)
和
(3)根据(2)中得到的估计量,构成建议分布N( xk
(i)
,),并从中抽取新的
样本粒子,并赋予权值wk;
3)对于剩余的(1-c)*N个粒子,使用非线性系统方程进行更新,得到状态估
计预测量 xk|k-1
(i)
(i)
(i)
i
,并从先验概率分布p(xk|k-1|xk-1
)中抽取粒子,赋予权值wk;
i
4)对所有粒子的权值进行归一化处理;
5)执行再采样过程,对得到的新的粒子集合中的每一个粒子赋予相同的权值1/N; 6)输出;
7)如继续迭代,转到二,否则结束。
2
200710099440.7
说 明 书
基于多建议分布的粒子滤波方法
第1/6页
技术领域
本发明涉及基于多建议分布的粒子滤波方法,要求保护的技术方案属于信号处理、人工智能和计算机视觉领域。 背景技术
非线性滤波问题在很多领域的问题中都涉及到,其中包括信号处理、金融、人工智能和计算机视觉等等。解决非线性滤波问题最为普遍的一种方法是使用扩展卡尔曼滤波器(EKF),但是EKF只适用于弱非线性系统,对于强非线性系统很容易导致发散。还有一种解决非线性滤波问题的办法是无迹卡尔曼滤波器(UKF)。UKF和EKF不同,它不使用局部线性化技术,而直接使用系统的非线性方程进行运算,从而能够避免局部线性化所引入的误差,避免在强非线性系统中出现发散。但是,UKF的使用不适用于一般的非高斯模型。
另一种解决非线性滤波问题的方法就是粒子滤波器(Particle Filter)。它的基本思
想就是使用一组带有权值的粒子(样本)集合来近似表示解决问题时需要的系统后验概率密度。粒子滤波器自提出以来已经广泛应用到信号处理、金融、人工智能、计算机视觉以及机器人等领域中,成为各国研究者关注的焦点。
粒子滤波算法中的一项关键技术是建议分布的选择。选择好的建议分布能够有效的避免退化问题的影响,提高系统的状态估计精度。目前,常见的建议分布有先验概率分布(Transition Prior,TP)、EKF、UKF等。以这三种建议分布为基础的粒子滤波器,分别被称为:基本粒子滤波器(Generic PF)、扩展卡尔曼粒子滤波器(EKPF)和无迹粒子滤波器(UPF)。但是先验概率分布没有考虑当前时刻新的观测值的影响,从而影响了粒子滤波器估计精度;而EKF采用局部线性化技术,引入了过多的截断误差,对估计精度产生影响;以UKF为建议分布的粒子滤波器具有较高的时间耗费。 发明内容
针对上述问题,本发明提出一种基于多建议分布的粒子滤波算法。 该算法包括以下基本步骤:
一.初始状态下,首先从初始分布p(x0)中提取一组(N个)样本粒子,并设置其初始的均值和方差。 二.对于c*N个粒子:
(1)首先使用UKF进行粒子传递和更新,获得关于该时刻状态的估计 xk ukf
(i)
.
(i)
(2)使用EKF重复粒子更新过程,并以第(1)步中得到的状态估计作为输入。得到该时刻最终的估计量 xk
和
3
200710099440.7说 明 书 第2/6页
(i)
(3)根据(2)中得到的估计量,构成建议分布N( xk
),从中抽取新的
,
样本粒子,并赋予权值wk。
三.对于剩余的(1-c)*N个粒子,使用非线性系统方程进行更新,得到状态估
(i)(i)(i)
计预测量 xk|k-1,并从先验概率分布p(xk|k-1|xk-1)中抽取粒子,赋予
i
权值wk。
四.对所有粒子的权值进行归一化处理。
五.执行再采样过程,对得到的新的粒子集合中的每一个粒子赋予相同的权值1/N。
六.输出
七.如继续迭代,转到二,否则结束。
本发明采用分治采样策略,将系统所需粒子分成两部分,分别由不同的建议分布中提取。
一部分(假设占百分比为c)由混合的建议分布提取,即:由UKF和EKF组成的混合建议分布。其余的一部分(1-c),由先验概率分布p(xk|xk-1)中提取。以此为基础的粒子滤波算法不仅能够产生较高的估计精度,而且能够降低粒子滤波器的运行时间。用户可以根据自身对实际要求的不同,调整参数c,以满足他们对运行效率和精度的不同要求。
假设非线性动态系统的状态空间模型为: xk=fk(xk-1,vk-1) yk=hk(xk,uk)
其中xk表示系统在k时刻所处的状态,yk表示k时刻的观测值。函数f和h表示系统的状态转移和测量模型。vk和uk分别表示系统噪声与测量噪声。 本发明提供的多建议分布粒子滤波器采用了EKF、UKF和TP作为建议分布,将总的粒子数分成两部分,分别由不同的建议分布中抽取,具体实现过程包括以下步骤:
第一步.k=0时,初始化一组粒子作为初始状态下的粒子集合,并设置初始的均值和协方差矩阵,设置方法同UPF算法中的初始设置。 第二步.对于c*N个粒子, 1.首先使用UKF更新粒子:
(1)选择一组sigma点,构成sigma矩阵。
(2)根据动态系统的非线性方程,将这些sigma点向前传递,得到系统状态的
(i)(i)
均值的预测量 xk|k-1ukf和协方差的预测量Pk|k-1ukf,以及与测量值有关的预测量
(i)
yk|k-1ukf(预测):
4
i
200710099440.7说 明 书 第3/6页
(3)获取当前时刻的测量值yk之后,并根据该测量值对(2)中得到的一步预测值(更新): 其中
这样就获得了估计量 xk 。ukf
aTTTT
其中,x=[x v u]为扩张(augmented)状态变量,由系统状态x,系统噪声v和
axTvTuTTa
测量噪声u组成。χ=[(χ) (χ) (χ)]为sigma矩阵。na=nx+nv+nu为x的维
(i)a(i)(i)
数。χk-1表示k-1时刻由sigma点构成的sigma矩阵,χj,k|k-1为χk|k-1的第j个元
(m)(c)
素。Wi和Wi表示sigma向量的权值,分别用来求均值和协方差估计,其计算方法在文献(Rudolph van der Merwe等,The Unscented Particle Filter)中。
2
λ=α(nx+k)-nx是一个尺度调节因子,α决定了选择的sigma点在其均值 x附
近的分布情况,通常将α设置为一个很小的正值(如0.001)。k是次级尺度调节因子,通常设置为0,β是用来结合关于x的分布的先验知识(对于高斯分布,β的最佳取值为2)。
是矩阵(nx+
(i)
(卡尔曼增益)
λ)Px平方根的第i行,
(i)
2.使用EKF更新粒子,并以 xk 作为输入,即:令ukf (1)传递粒子,并得到相关的一步预测量:
5
200710099440.7说 明 书 第4/6页
(2)计算系统状态转移模型的雅可比矩阵F和G,以及测量模型的雅可比矩阵H和U.并计算出卡尔曼增益。
(3)根据当前的时刻的观测值yk,修正(1)中的一步预测量,得到修正的的估计量: (4)令
3.从它们所组成的建议分布中抽取新的粒子:
并赋予其权值wk。
其中,Q和R分别表示系统噪声和测量噪声的方差
第三步.对于剩余的(1-c)*N个粒子,使用先验概率分布进行更新。 1.直接根据系统的非线性方程计算出状态估计量:
2.从先验分布密度函数p(xk|k-1
(i)
i
|xk-1
(i)
)中抽取粒子,即:
并
为其赋予权值wk。
第四步.对所有的粒子的权值进行归一化处理:
第五步.执行再采样过程:
去除那些权值较小的粒子,复制权值较大的粒子,得到一组近似服从后验概率分布p(x0:k|z1:k)的粒子集合,并为其中的每个粒子赋予相同的权值1/N。 第六步.输出阶段。
第七步.k=k+1,如继续迭代,转到第二步循环,否则结束。
6
i
200710099440.7说 明 书 第5/6页
本发明具有以下优点:
1.采用多建议分布方案,融合了各种独立建议分布在粒子滤波器框架内的优点。 2.采用分治采样策略,在粒子滤波器的运行时间和估计精度等方面作折衷,用户可以根据自己的需求适当调整参数,获得对运行时间或精度的要求。 附图说明
图1-多建议分布的粒子滤波流程图;
图2-在不同的c取值下,多建议分布粒子滤波器算法与其它粒子滤波器算法的估计均方误差对比曲线;
图3-在不同的c取值下,多建议分布粒子滤波器算法与其它粒子滤波器算法的运行时间对比曲线; 图4-原始信号曲线;
图5-使用本发明进行滤波后的曲线; 具体实施方式
下面结合附图和实施例对本发明作进一步说明。 本发明的算法包括以下基本步骤:
一.初始状态下,首先从初始分布p(x0)中提取一组(N个)样本粒子,并设置其初始的均值和方差。
二.对于c*N个粒子:
(1)首先使用UKF进行粒子传递和更新,获得关于该时刻状态的估计
(i)
xk 。ukf
(2)使用EKF重复粒子更新过程,并以第(1)步中得到的状态估计作为输
(i)
入。得到该时刻最终的估计量 xk和
(3)根据(2)中得到的估计量,构成建议分布N( xk
),从中抽取新的
(i)
,
样本粒子,并赋予权值wk。
三.对于剩余的(1-c)*N个粒子,使用非线性系统方程进行更新,得到状态估
(i)(i)(i)
计预测量 xk|k-1,并从先验概率分布p(xk|k-1|xk-1)中抽取粒子,赋予
i
权值wk。
四.对所有粒子的权值进行归一化处理。
五.执行再采样过程,对得到的新的粒子集合中的每一个粒子赋予相同的权值1/N。
六.输出
七.如继续迭代,转到二,否则结束。
实施例1.通过一个非线性动态系统的状态空间模型如下: xk=1+sin(0.04π(k-1))+0.5xk-1+vk-1 (状态转移模型)
7
i
200710099440.7说 明 书 第6/6页
(测量模型)
对本发明与其它几种粒子滤波器算法进行对比。使用粒子数目N=200,观测时间T=60。程序在CPU为2.67GHz,内存为1GB的微型计算机上运行100次。 每次运行程序的输出为粒子集合的均值:
每一次运行中,均方误差
的计算公式为:
取c=0.3,在时间耗费和精度方面进行对比时,本发明算法产生的估计均方误差比UPF低80%,运行时间比UPF低约50%。在c=0.4时,本发明算法的均方误差比UPF低72%,运行时间比UPF低44%。
图2所示,c在取不同的值时,本发明与其它粒子滤波器算法均方误差的对比,图3为相应的运行时间对比。随着c值的增加,本发明提出的算法在运行时间上也随之增加,但是本发明所产生的均方误差总体上是呈现递减的趋势。 实施例2.将本发明实施于钻井系统中的随钻测井仪。随钻测井仪器分为井上部分和井下部分。井下部分的测量信号经泥浆传送到地面。井上部分首先要对接收到的井下信号进行滤波,然后是解码并算出物理参数值。本发明的作用就是将带噪声的编码信号进行滤波,得到去噪的信号。将本发明实施于仪器的井上部分。本发明能够得到理想的滤波效果(图4,图5),为之后数据的处理提供了基础。
8
200710099440.7
说 明 书 附 图
第1/3页
9
200710099440.7说 明 书 附 图 第2/3页
10
200710099440.7说 明 书 附 图 第3/3页
11
因篇幅问题不能全部显示,请点此查看更多更全内容