本文是该篇文章的归纳http://aigamedev.com/open/tutorial/lazy-theta-star/#Nash:07 。

传统的A*算法中,寻找出来的路径只能是沿着给出的模型(比如TileMap、网格模型)上的路径依次行走。(上图上半)

在游戏中寻路的场合下,这种路径看起来是十分不自然的。与之相对的“自然的”寻路称为Any-Angle Path Planning。(上图下半)

对于A*的一个简单的修正是,在生成路径之后,检测路径上隔开的两个点之间是否有line of sight(即视线,以下简称LOS),有的话便可以把中间的点删除,让人物直接穿过。这种方法称之为A* with post-smoothed paths。依据如何选取这两个点,最终优化的效果不同。但是要注意的是这种修正得到的路径的质量和效率是需要取舍的。

另外,本文介绍的算法都不保证寻找的路径是最佳的。不要尝试用来刷题233。

Theta*

修正的第二种办法,即Theta*算法。这种算法是A*的一种改进,关键在于其打开一个节点s,然后更新周围的节点s'时,会检查s'与parent(s)的可见性。如果可见,则把s'的父节点设置成parent(s)。


左边是\A*算法,中间是Theta*算法,右边是等下介绍的Lazy Theta*。

可以看到在Theta*中,除了ComputeCost函数之外,其他的内容和A*算法是相同的。

在ComputeCost中,A*算法计算一个点s'的新的g,如果比原来的更好,则将原来的parent和g换成新的。

在Theta*中,则在计算前,先去计算s's的parent有无视线。如果有视线,则把s'的parent和gs的parent为parent进行更新。否则跟A*一样处理。

然而,Theta*有一个很大的问题,就是需要做大量的line of sight检查。有多少个点进入过open列表,就有多少次检查。在较为细致的网格中这个数量是十分巨大的。

Lazy Theta*

这里就引出了Theta*的一种优化,即Lazy Theta*。


两种算法进行的LOS检查数。

Lazy Theta*的核心思想在于,将line of sight检查延迟到打开该节点为止。


示例,注意右上图(第二步)中B2指向的是start而不是B3,因为B2尚未打开,我们可以乐观认为B2和父节点B3的父节点有LOS。这一假设在左下图(第三步)中,B2打开时才得到修正。

在Theta*中,检查视线的时机发生于一个点进入open列表的时候。但是实际上,有很多进入open列表的点最终不在路径中,这意味着LOS检查是无效的。因此Lazy Theta*选择把LOS检查放到打开该节点的时候进行。

当然,进入open列表的点,我们需要设置它的g值和parent。在Lazy Theta*中,我们乐观地认为在这里LOS检查永远成立的,因此g值和parent值得的设置按照Theta*中LOS检查成立一般地进行设置。

随后,在打开一个节点时,我们对这个点调用SetVertex方法。该方法中我们对该点和它的父节点进行真正的LOS检查。如果成立,那么我们之前的假设是对的,那就继续进行下去。如果没有LOS,那么我们还需要为这个点找到一个正确的parent。

对点s找到正确的parent的方法稍微繁杂一点。首先我们要知道什么点能成为s的parent,答案是在close表里的点。其次还应该是和s有LOS关系的点。如果有的选择的话,我们还要选择g(parent) + c(parent,s)最小的。

当然,如果我们对close表里的点全部做一遍LOS检查那就是本末倒置了。在这里我们直接取s的相邻点作为parent的候选。然后和close表做个交集,在其中选择最好的点即可。

Lazy Theta*的优化

这个优化是在A*中就存在的,优化的A*叫做Weighted A*,即带权重的A*。

所谓权重是加给启发函数的。原本的估值函数F(s) = G(s) + H(s),加入权重后变成F(s) = G(s) + weight * H(s) 。

这意味着比起从出发点到当前点的距离,当前点到终点的距离的估值影响更大(当weight > 1时)。

可以简单的理解为weight越大,会“更想接近终点”。

在Lazy Theta*中也可以直接套用这个优化。同时比起普通的weighted A*,Lazy Theta*中的这项优化更加有价值。具体的就不在这里叙述了,在原文中有提到。

下一篇文章中我会简单叙述一下我在unity/C#中实现的Lazy Theta*寻路。

A*算法改进——Any-Angle Path Planning的Theta*算法与Lazy Theta*算法的更多相关文章

  1. Design and Implementation of Global Path Planning System for Unmanned Surface Vehicle among Multiple Task Points

    Design and Implementation of Global Path Planning System for Unmanned Surface Vehicle among Multiple ...

  2. 算法:Astar寻路算法改进,双向A*寻路算法

    早前写了一篇关于A*算法的文章:<算法:Astar寻路算法改进> 最近在写个js的UI框架,顺便实现了一个js版本的A*算法,与之前不同的是,该A*算法是个双向A*. 双向A*有什么好处呢 ...

  3. BP神经网络算法改进

    周志华机器学习BP改进 试设计一个算法,能通过动态调整学习率显著提升收敛速度,编程实现该算法,并选择两个UCI数据集与标准的BP算法进行实验比较. 1.方法设计 传统的BP算法改进主要有两类: - 启 ...

  4. 【强化学习】DQN 算法改进

    DQN 算法改进 (一)Dueling DQN Dueling DQN 是一种基于 DQN 的改进算法.主要突破点:利用模型结构将值函数表示成更加细致的形式,这使得模型能够拥有更好的表现.下面给出公式 ...

  5. Behavior Trees for Path Planning (Autonomous Driving)

    Behavior Trees for Path Planning (Autonomous Driving) 2019-11-13 08:16:52 Path planning in self-driv ...

  6. Grassfire算法- 运动规划(Motion planning)

     Grassfire算法: 一.概念 这个算法是做图像处理的抽骨架处理,目的是求出图像的骨架,可以想象一片与物体形状相同的草,沿其外围各点同时点火.当火势向内蔓延,向前推进的火线相遇处各点的轨迹就是中 ...

  7. 【Machine Learning in Action --2】K-近邻算法改进约会网站的配对效果

    摘自:<机器学习实战>,用python编写的(需要matplotlib和numpy库) 海伦一直使用在线约会网站寻找合适自己的约会对象.尽管约会网站会推荐不同的人选,但她没有从中找到喜欢的 ...

  8. 算法(第4版)-1.5 案例研究:union-find算法

    问题→ 动态连通性:当程序从输入中读取了整数对p q时,如果已知的所有整数对都不能说明p和q是相连的,那么则将这一对整数写入到输出中.如果已知的数据可以说明p和q 是相连的,那么程序应该忽略p q这对 ...

  9. Intel发布神经网络压缩库Distiller:快速利用前沿算法压缩PyTorch模型——AttributeError: module ‘tensorboard' has no attribute 'lazy'

    转载自:CSDN Nine-days   近日,Intel 开源了一个用于神经网络压缩的开源 Python 软件包 Distiller,它可以减少深度神经网络的内存占用.加快推断速度及节省能耗.Dis ...

随机推荐

  1. lambda表达式,map函数

    lambda只是一个表达式,不需要定义函数,故也是匿名函数,用法为:lambda 参数:表达式. x=5 list1=[2,3,4] list2=[10,20,30] s=lambda x:x**3 ...

  2. 1094. The Largest Generation (25)-(dfs,树的遍历,统计每层的节点数)

    题目很简单,就是统计一下每层的节点数,输出节点数最多的个数和对应的层数即可. #include <iostream> #include <cstdio> #include &l ...

  3. Alpha冲刺第6天

    Alpha第六天 1.团队成员 郑西坤 031602542 (队长) 陈俊杰 031602504 陈顺兴 031602505 张胜男 031602540 廖钰萍 031602323 雷光游 03160 ...

  4. jmeter测试soap协议时候 路径不需要添加

  5. MT【164】条件化简

    (2017北大优特测试第9题) 已知实数 \(a_i\)(\(i=1,2,3,4,5\))满足 \((a_1-a_2)^2+(a_2-a_3)^2+(a_3-a_4)^2+(a_4-a_5)^2=1\ ...

  6. 【刷题】LOJ 6224 「网络流 24 题」深海机器人问题

    题目描述 深海资源考察探险队的潜艇将到达深海的海底进行科学考察. 潜艇内有多个深海机器人.潜艇到达深海海底后,深海机器人将离开潜艇向预定目标移动. 深海机器人在移动中还必须沿途采集海底生物标本.沿途生 ...

  7. ARG102E:Stop. Otherwise...

    传送门 Sol 对于每个 \(i\) ,可以把 \(k\) 个数字分成 \((x,i-x)\) 的若干组. 那么就是求每组只能其中选择一个且可以重复的方案数. 预处理 \(f[i][j]\) 表示从 ...

  8. sql server 小技巧(5) Sql server 获取指定字符后的所有字符 - 去掉指定字符前的所有字符

    select top 10  SUBSTRING( sproductcode, CHARINDEX('-', SProductCode)+1, LEN(SProductCode)) from csmr ...

  9. JDK自带线程池介绍及使用环境

    1.newFixedThreadPool创建一个指定工作线程数量的线程池.每当提交一个任务就创建一个工作线程,如果工作线程数量达到线程池初始的最大数,则将提交的任务存入到池队列中. 2.newCach ...

  10. Spring中 <context:property-placeholder 的使用与解析 .properties 配置文件的加载

    转: Spring中property-placeholder的使用与解析 Spring中property-placeholder的使用与解析 我们在基于spring开发应用的时候,一般都会将数据库的配 ...