【机器人状态估计】粒子滤波算法介绍

概率定位算法

问题分类:位姿追踪、局部定位、全局定位;静态、动态环境定位;单一机器人定位、多机器人定位。

贝叶斯滤波框架:

定位置信度与运动模型卷积,两次独立估计值的整合比单一估计值使系统状态确定性更高。

粒子滤波

基本思路

  1. 随机产生M个粒子(如M=1000),每个粒子表示状态变量的(随机)数值,如位置、航向等,粒子有权重,即重要性因子,初始时每个粒子的权重都相等
  2. 预测(运动方程)每个粒子下一时刻的"位置"
  3. 根据测量更新粒子的权重,与测量更接近的粒子具有更高的权重
  4. 重采样粒子,去除权重低的粒子,并用高权重的粒子去复制替代,粒子的权重被重新均分
  5. 统计粒子集合的加权均值和方差以得到系统的状态估计

粒子滤波实现自动驾驶多传感器融合定位

  1. 使用运动方程从上一时刻完成更新的粒子预测状态
  2. 传感器测量与从预测的状态估计的测量做差, 称为innovation, 重新确定第i个粒子的权重
    w t i = p ( z t ∣ x t i , m ) w^{i}_t = p(z_t|x^{i}_t, m) wti=p(zt∣xti,m)

δ z = h ( x , m ) − z w t i = w t − 1 i ∗ N ( 0 , σ , δ z ) \delta z = h(x,m) - z \\ w^{i}t = w^{i}{t-1} * N(0, \sigma, \delta z) δz=h(x,m)−zwti=wt−1i∗N(0,σ,δz)
N ( 0 , σ , δ z ) N(0, \sigma, \delta z) N(0,σ,δz)指正态分布取 δ z \delta z δz的数值

更新状态
x t = Σ i ( w t i x t i ) Σ i ( w t i ) x_t = \frac{\Sigma_i(w^{i}_tx^{i}_t)}{\Sigma_i(w^{i}_t)} xt=Σi(wti)Σi(wtixti)

计算状态协方差

第j行第k列元素的值为:

X j , k = 1 1 − Σ i = 1 N ( w i ) 2 Σ i = 1 N w i ( x j i − u j ) ( x k i − u k ) X_{j,k}=\frac{1}{1-\Sigma^N_{i=1}(w^i)^2}\Sigma^N_{i=1}w^i(x^i_j-u_j)(x^i_k-u_k) Xj,k=1−Σi=1N(wi)21Σi=1Nwi(xji−uj)(xki−uk)

x j i x^i_j xji是第i个粒子的第j维值, x k i x^i_k xki是第i个粒子的第k维值, u j u_j uj是估计的状态第j维值

python 复制代码
#计算协方差
def calc_covariance(x_est, px, pw):
    """
    calculate covariance matrix
    see ipynb doc
    """
    cov = np.zeros((3, 3))
    n_particle = px.shape[1]
    for i in range(n_particle):
        dx = (px[:, i:i + 1] - x_est)[0:3]
        cov += pw[0, i] * dx @ dx.T
    cov *= 1.0 / (1.0 - pw @ pw.T)
    return cov

工程与参考《概率机器人》中有一处差异,粒子的权重更新,参考为似然函数值,参考代码将先前权重与函数值相乘。

重采样的实现

经过重采样,粒子的分布近似后验,重复高权重的粒子,低权重的粒子更有可能被替换掉

python 复制代码
def re_sampling(px, pw):
    """
    low variance re-sampling
    """

    w_cum = np.cumsum(pw)
    base = np.arange(0.0, 1.0, 1 / NP)
    re_sample_id = base + np.random.uniform(0, 1 / NP)
    indexes = []
    ind = 0
    for ip in range(NP):
        while re_sample_id[ip] > w_cum[ind]:
            ind += 1
        indexes.append(ind)

    px = px[:, indexes]
    pw = np.zeros((1, NP)) + 1.0 / NP  # init weight
    return px, pw
相关推荐
庄小焱4 分钟前
【机器学习】——房屋销售价格预测实战
人工智能·算法·机器学习·预测模型
才兄说10 分钟前
机器人租售走上下场?会提前走一遍
机器人
txzrxz10 分钟前
单调栈详解(含题目)
数据结构·c++·算法·前缀和·单调栈
AI科技星23 分钟前
张祥前统一场论的数学表述与概念梳理:从几何公设到统一场方程
人工智能·线性代数·算法·机器学习·矩阵·数据挖掘
程序员-King.29 分钟前
day167—递归—二叉树的直径(LeetCode-543)
算法·leetcode·深度优先·递归
亲爱的非洲野猪33 分钟前
2动态规划进阶:背包问题详解与实战
算法·动态规划·代理模式
瑞璐塑业peek注塑1 小时前
轻量化线性执行器PEEK注塑降本:助力人形机器人关节模组精密制造
机器人·制造
YH12312359h1 小时前
战斗机目标检测与跟踪:YOLOv26算法详解与应用
算法·yolo·目标检测
芒克芒克1 小时前
LeetCode 134. 加油站(O(n)时间+O(1)空间最优解)
java·算法·leetcode·职场和发展
TracyCoder1232 小时前
LeetCode Hot100(4/100)——283. 移动零
算法·leetcode