首页 > 其他分享 >RTS核心技术:流场寻路详解(Flow Field Pathfinding)

RTS核心技术:流场寻路详解(Flow Field Pathfinding)

时间:2023-12-08 15:57:42浏览次数:37  
标签:路径 Flow 距离 Pathfinding Field 算法 Heatmap 流场 寻路

RTS里面经常会有很多角色,群体一起寻路到目的地附近,这种寻路是如何实现的,今天给大家详细的讲解基于流场寻路的算法。在本教程中,我将解释向量场寻路及其相对于Dijkstra等传统寻路算法的优势。对Dijkstra算法和势场的基本理解将有助于理解本文,但不是必需的。

寻路的问题有很多种解决方案,如AStar等, 每种寻路的方案都各有优缺点,大部分的寻路,都是角色要从A点走到B点,然后调用寻路算法找出一条路径出来。通常情况下这样是不会有问题的,但是对于像RTS这种游戏需要做群体寻路,从A点到B点一群角色走过去,如果每个角色都单独寻路,这样性能开销会比较大,所以今天我们为了解决这个问题,介绍基于流场向量的寻路。它的原理是把目标点的流场计算出来,所有移动的目标共用这个流量场。接下来本文讲详细的介绍流场寻路的核心技术与步骤。(本文是将地图基于网格来讲解的,你也可以用到其它的地方,不限于网格)。

基于流场寻路的算法的主要步骤

基于流场寻路的算法主要包含以下三个步骤:

(1) 遍历游戏地图种的每个块,计算出来当前块到目标的距离,称为"Heatmap"热度图;

(2) 为每个地图块,根据Heatmap生成一个向量场,指定了每个块到目标的方向 称为"Vector Field";

(3) 到目的地的每个角色,都共用这个向量场来移动导航到目标点;

生成Heatmap

Heatmap 是指从目标点到地图上每个图块的路径距离。路径距离不同于欧几里德距离,它是通过可穿越地形的最短的两点之间距离来计算。如下图,你可以看到从目标点(用红色标记)到地图任意的点(用粉色标记)的路径距离和线性距离之间的差异。不可行走的块以绿色绘制。如图,路径距离(以黄色显示)为9,而线性距离(以浅蓝色显示)约为4.12。每个图块左上角的数字显示由Heatmap生成算法计算出的到目标的路径距离。注意两点之间可能有一个以上的路径距离, 我们只算最短的那个距离。经过算法第一步,我们把地图上的每个块到目的地的最短距离都计算了出来,生成了Heatmap。

Heatmap生成算法是一种 wavefront 算法。它从值为0的目标开始,然后向外流动以填充整个可遍历区域。 wavefront 算法有两个步骤:

(1)从目标开始,并用0的路径距离标记它。

(2)获取每个标记的图块的未标记邻居,并用前一个图块的路径距离+1标记它们。

(3) 标记完所有地图的块后,算法结束。

注: wavefront 算法是在网格上执行广度优先搜索,并存储沿途到达每个块所需的步骤。这种算法有时也称为brushfire算法。

Vector Field 生成

现在已经计算了从每个块到目标的路径距离,我们可以很容易地确定接近目标需要采取的路径。通常计算一次Vector Filed,然后让所有要寻路的对象在运行时引用该Vector Filed。

Vector Field 简单地存储了一个向量,该向量指向每个地图块走向目的地的方向(朝向目标)。这里是向量场的可视化,向量从图块的中心沿着最短路径指向目标,形成了一个流场。(红色为原点,白色的线为方向,大体趋势都指向目标点)。

这个向量场里面的每个向量,是通过Heatmap计算出来的,具体的计算Vector向量方式如下:

Vector.x = left_tile.distance - right_tile.distance, 向量x为左边的块-右边的块;

Vector.y = up_tile.distance - down_tile.distance,向量y为上边的块-下面的块;

每个块的distance,就是上面Heatmap种计算出来的数值。

如果当前块的(左/右/上/下)不可行走(障碍物等),则使用与当前块的距离来代替缺少的值。一旦粗略计算了路径向量,就对其进行归一化,以避免以后出现不一致。

角色移动导航

现在矢量场已经计算出来了,计算探路者的运动就很容易了。假设vector_field(x,y)返回我们之前在tile(x,y)处计算的向量,并且移动速度大小一直,则计算tile(x,y)处移动速度的伪代码如下所示:

velocity_vector = vector_field(x, y) * desired_velocity

当我们导航的时候,只要沿着向量方向移动就可以了,很容易就实现了流场移动, 同时多个角色目标寻路的时候,只要计算一次。

如上图,紫色的点,水平不可以移动,上下两个块的距离都是一样的,这样就导致了不唯一性,一半这种情况,我们会随机选着一个方向,这样导致的结果可能就是我们选择的路径不一定是最短的,所以流场寻路又是基于局部最优解的。要解决这样的问题,还有一个好的方法,就是把块分小,降低这样的几率。

当然把块分小,计算量也会增大。

好今天的流场寻路的内容就分享到这里了

博毅创为游戏学院​bycwedu.vipwan.cn/promotion_channels/2146264125

标签:路径,Flow,距离,Pathfinding,Field,算法,Heatmap,流场,寻路
From: https://www.cnblogs.com/liuwenyi/p/17888309.html

相关文章

  • PWN入门之Stack Overflow
    本文是i春秋论坛签约作家「Binarystar」分享的技术文章,旨在为大家提供更多的学习方法与技能技巧,文章仅供学习参考。大家好,我是Binarystar,目前从事于公安行业,擅长Web、二进制和电子取证方向。能把网络安全技能运用在工作中,与我的职业结合起来做有意义的事,是非常自豪的,我希望通......
  • 人工智能学习一、使用miniconda安装tensorflow
    1、condaconfig--addchannelshttps://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free/condaconfig--setshow_channel_urlsyes用户目录底下找到.condarc文件,打开.condarc文件,删除第3行–defaults,保存文件2、创建一个虚拟环境,其实相当于创建了一个docker环境类似......
  • 第二章 若依JFlow流程模型设计
    若依-JFlow框架如何拉取、配置并运行请查看这篇文章:《第一章若依-JFlow的配置与启动》上一节我们讲解了如何拉取若依-JFlow框架代码并配置运行,这一部分我们就以公司员工请假的流程为例,设计一个流程,并为初始节点设计一个表单。一、新建业务场景和流程模型1.启动项目以后,登录......
  • Detecting Unknown Encrypted Malicious Traffic in Real Time via Flow Interaction
    1前言1.1标题DetectingUnknownEncryptedMaliciousTrafficinRealTimeviaFlowInteractionGraphAnalysis1.2摘要为了保护网络的机密性和隐私性,目前互联网上的流量被广泛地加密。然而,流量加密技术经常被攻击者滥用,以掩盖其恶意行为。由于加密的恶意流量具有与良性......
  • flowable 项目的Pom.xml
    <?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/......
  • CTfpwn攻防世界int_overflow对于strlen的利用以及汇编是神
    分析这题题目已经在暗示用int数据的overflow了,不过不急,先分析一下。保护基本没啥保护,也挺好,适合不用搞太多花里胡哨的泄露,只需理解这题想告诉你的知识。后门函数看到有一个whatisthis函数,正是我们要的catflag函数。main函数login函数main函数里需要的操作很简单,只需输入一个1就......
  • Guo_AD-NeRF_Audio_Driven_Neural_Radiance_Fields_for_Talking_Head_Synthesis_ICCV_
    可以看看这个向量场的虚拟人像的效果.看论文第三章: 3.2: F_theta是一个神经网络,a是声音d是viewdirection,x是3dlocation.普通的向量场是F_theta:d,x--->(c,σ)表示d是一个方向,表示观看者水平的偏移角度和数值的偏移角度.x是一个3d坐标表示看物......
  • Keras 3.0正式发布:可用于TensorFlow、JAX和PyTorch
    前言 Keras3.0正式发布:可用于TensorFlow、JAX和PyTorch本文转载自机器之心仅用于学术分享,若侵权请联系删除欢迎关注公众号CV技术指南,专注于计算机视觉的技术总结、最新技术跟踪、经典论文解读、CV招聘信息。CV各大方向专栏与各个部署框架最全教程整理【CV技术指南】CV全栈......
  • 第一章 若依-JFlow的配置与启动
    若依(Ruoyi)一款开源的后台管理admin框架,JFlow是一款经典的纯国产全开源的工作流引擎,该版本是两者的完美结合。RuoYi是一个后台管理系统,基于经典技术组合(SpringBoot、ApacheShiro、MyBatis、Thymeleaf)主要目的让开发者注重专注业务,降低技术难度,从而节省人力成本,缩短项目周期,提高......
  • java 8 利用lambda 获取 记录类(get/set) field 上面 注解
    packagetianrun.ziguan.api.center.alert.util;importcom.baomidou.mybatisplus.annotation.TableField;importjava.io.*;importjava.lang.annotation.Annotation;importjava.lang.invoke.SerializedLambda;importjava.lang.reflect.Field;importjava.lang.ref......