美文网首页
第三课:多峰,连续,粒子滤波

第三课:多峰,连续,粒子滤波

作者: Allen的光影天地 | 来源:发表于2019-03-02 21:05 被阅读0次
三种滤波的比较

粒子滤波的关键函数

这部分主要叙述,如何初始化粒子群,然后对粒子群做measurement,并与权重对应,最后通过巧妙设计,实现按照权重占比,实现重组(重新生成)粒子群

def get_position(p):
    x = 0.0
    y = 0.0
    orientation = 0.0
    for i in range(len(p)):
        x += p[i].x
        y += p[i].y
        # orientation is tricky because it is cyclic. By normalizing
        # around the first particle we are somewhat more robust to
        # the 0=2pi problem [-pi,pi]
        orientation += (((p[i].orientation - p[0].orientation + pi) % (2.0 * pi))
                        + p[0].orientation - pi)
    return [x / len(p), y / len(p), orientation / len(p)]


def particle_filter(motions, measurements, N=500):  # I know it's tempting, but don't change N!
    # --------
    #
    # Make particles
    #

    p = []
    for i in range(N):
        r = robot()
        r.set_noise(bearing_noise, steering_noise, distance_noise)
        p.append(r)

    # --------
    #
    # Update particles
    #

    for t in range(len(motions)):

        # motion update (prediction)
        p2 = []
        for i in range(N):
            p2.append(p[i].move(motions[t]))
        p = p2

        # measurement update
        w = []
        for i in range(N):
            w.append(p[i].measurement_prob(measurements[t]))

        # resampling
        p3 = []
        index = int(random.random() * N)
        beta = 0.0
        mw = max(w)
        for i in range(N):
            beta += random.random() * 2.0 * mw
            while beta > w[index]:
                beta -= w[index]
                index = (index + 1) % N
            p3.append(p[index])
        p = p3

    return get_position(p)

自行车模型

在这讲中,引入自行车模型的概念,这篇博客讲的很细致
https://blog.csdn.net/adamshan/article/details/78696874

自行车模型:一图胜千言
课件中的表示方法与上图一致,其对应公式如下如所示:
运动学模型对应公式
注意:上图中描述的公式,其中绿色部分的beta,我认为是tan(beta),不过tan在该范围内是单调递增的,所以关系不大,不是很影响。
而且在最后蓝色的x`的推导部分,分别对两种情况做了描述:
  1. 当|beta| < 0.001时, 认为tanx = sinx = x, 是近似相同,在物理上认为没有小车基本没有偏转
  2. 当|beta| >= 0.001时, 用上面的那一排公式求取,用到了cx和cy

基于自行车模型的粒子滤波

这部分主要两块:

  1. 面向自行车模型的move函数
    def move(self, motion):  # Do not change the name of this function
        alfa = motion[0]
        d = motion[1]
        if alfa > max_steering_angle:
            raise ValueError('the steer angle is too much')
        if d < 0:
            raise ValueError('the distance is less than zero')

        result = robot()
        result.distance_noise = self.distance_noise
        result.steering_noise = self.steering_noise
        result.bearing_noise = self.bearing_noise
        result.length = self.length

        steer = random.gauss(alfa, steering_noise)
        distance = random.gauss(d, distance_noise)

        beta = d / self.length * tan(steer)
        R = distance / beta
        result.orientation = (self.orientation + beta) % (2 * pi)

        if abs(beta) < 0.001:
            result.x = self.x + distance * cos(self.orientation)
            result.y = self.y + distance * sin(self.orientation)
        else:
            cx = result.x - sin(self.orientation) * R
            cy = result.y + cos(self.orientation) * R
            result.x = cx + sin(beta+self.orientation) * R
            result.y = cy - cos(beta+self.orientation) * R

        return result
  1. 新的感知sense函数
    与四个landmark求对应的方向夹角bearings
    def sense(self,flag):  # do not change the name of this function
        Z = []
        # ENTER CODE HERE
        # HINT: You will probably need to use the function atan2()
        for i in range(len(landmarks)):
            if flag:
                Z.append(((atan2((landmarks[i][0] - self.y), (landmarks[i][1] - self.x)) - self.orientation) % (2 * pi)) + random.gauss(0,self.bearing_noise))
            else:
                Z.append(((atan2((landmarks[i][0] - self.y), (landmarks[i][1] - self.x)) - self.orientation) % (2 * pi)))
        return Z  # Leave this line here. Return vector Z of 4 bearings.

相关文章

  • 第三课:多峰,连续,粒子滤波

    粒子滤波的关键函数 这部分主要叙述,如何初始化粒子群,然后对粒子群做measurement,并与权重对应,最后通过...

  • 粒子滤波

    参考博客 //================================================= ...

  • 粒子滤波

    上图中还应打出地标的位置。 粒子滤波的核心思路是通过两种测量的比较,反推出观测者本身的位置。测量类型I: 从未知观...

  • 智能科学技术中心技术必备

    1. 粒子滤波 2.卷积神经网络

  • 粒子滤波学习笔记

    本文参考博客地址 粒子滤波 粒子滤波的状态转移方程和观测方程如下:其中的x(t)为t时刻状态,u(t)为控制量,w...

  • 粒子滤波ParticalFilter

    有关于粒子滤波的参考资料: 入门概念理解:https://www.zhihu.com/question/25371...

  • 粒子滤波小记

    关于粒子滤波,我其实早就应该写篇文章来简单的聊一聊。但是由于拖延症加健忘症,一直就到了现在才开始写。 先说粒子滤波...

  • 粒子滤波算法--定位

    传送门:Udacity无人驾驶课程:粒子滤波算法介绍补充说明:某一粒子相较于robot的location近似度(决...

  • 粒子滤波(CSDN通俗解释)

    关于卡尔曼滤波和粒子滤波最直白的解释 卡尔曼滤波本来是控制系统课上学的,当时就没学明白,也蒙混过关了,以为以后也不...

  • [转]粒子滤波(particle filtering)的思路发展

    粒子滤波作为视觉SLAM中后端进行状态估计的主要算法之一,很好的完成了扩展卡尔曼滤波无法有效处理的复杂状态方程下的...

网友评论

      本文标题:第三课:多峰,连续,粒子滤波

      本文链接:https://www.haomeiwen.com/subject/fiasuqtx.html