加深游戏体验 解析游戏AI的设计与实施

GAD 2017-04-19
在过去的几十年中,游戏行业取得了巨大发展。 从《Pong》和《Pac-Man》等让游戏玩家短暂逃离现实的简单游戏发展为《魔兽世界》和《使命召唤》等让游戏玩家真正喜爱的复杂游戏。娱乐软件协会 (ESA) 曾指出,如今的游戏玩家平均有 13 年的游戏经验,已经习惯于看到每款新游戏变得越来越复杂、吸引人且智能。


如今,游戏开发人员的挑战在于如何不断突破极限,开发出越来越引人注目的游戏。 计算机控制的人工智能 (AI) 已经发生了多种形式的演变,以满足测试要求。 然而,为游戏玩家设计符合其动作并促进玩家数量增长的自适应对手并非易事。

第一部分: 设计和实施

对于游戏行业而言,人工智能是什么?

从最基本的层面而言,“人工智能”包括模仿其他玩家或玩家所代表实体(即可以响应或付诸实践的所有游戏元素——从玩家、飞弹到健康皮卡)的行为。关键概念是模仿行为。也就是说,游戏行业的人工智能更加人工化,而智能程度较低。系统既可以是基于规则的简单系统,也可以是旨在挑战玩家作为对立军队指挥官的复杂系统。

游戏行业的人工智能与传统的人工智能观点有何不同

对人工智能的传统研究旨在创建真正的智能——尽管是通过人工手段。有些项目,如麻省理工学院 (MIT) 的Kismet项目,正在尝试创建一种能够进行学习、社交互动并表现情感的人工智能。 在本文撰写之时,麻省理工学院正在创建一种有幼儿教师和可喜成果的人工智能。

对于如今的游戏而言,真正的人工智能已经超出了一款娱乐软件的要求。游戏人工智能不需要具备感受力或自我感知能力(事实上没有最好);它不需要了解除游戏之外的任何信息。游戏人工智能的真正目标是模仿智能行为,为玩家提供一种可信的挑战——即玩家可以克服的挑战。

游戏人工智能的目标

人工智能可以在游戏中扮演多种角色。它可以是一套用于管理游戏世界中实体行为的一般规则。您也可以考虑实体遵循一类人工智能的预制脚本事件。例如在游戏 F.E.A.R 中, 用于恐吓玩家和预示未来事件的令人毛骨悚然的小女孩就是一个预制脚本事件。提到人工智能和游戏时,大多数人都会想到多人游戏中由电脑控制的玩家。不过,所有这些都是人工智能能够实现的不同角色。

F.E.A.R.(Vivendi Universal)在一类人工智能中使用脚本事件

游戏人工智能的基本要素

根据人工智能要实现的角色的性质,系统需求可能非常少。系统越复杂,人工智能的要求就越多。基本需求无非是运行 AI 所需的处理时间。更复杂的系统需要一些感知人工智能环境的手段,玩家行为记录和一些评估先前决策成功度的手段。

决策

人工智能背后的核心概念是决策。为了执行这些选择,智能系统需要能够使用人工智能系统影响实体。您可以通过“人工智能推送”或“实体推送”战略管理这一执行。

人工智能推送系统通常将人工智能系统隔离为游戏架构的独立元素。此类战略通常采取独立线程或线程的形式,线程中的人工智能花时间计算给出游戏选项的最佳选择。当人工智能制定决策时,这一决策将随后传播至涉及的实体。这一方法在实时战略游戏中最有效,因为在这种游戏中,人工智能关注大局。

实体推送系统最适合包含简单实体的游戏。在这些游戏中,实体会在其“思考”或自我更新时调用人工智能系统。这种方法非常适合于包含大量不需要经常思考的实体的系统,如射手系统。这一系统还可以从多线程技术中受益,但需要一些额外的计划(详情请见Orion Granatir 的多线程人工智能上的文章)。

基本感知

为了使人工智能作出有意义的决策,它需要感知周围环境的某种方式。在较简单的系统中,这种感知可能只是对玩家实体的位置进行简单的检查。随着系统的要求越来越苛刻,实体需要找出游戏世界的主要特点,如可行的穿行路径、提供掩护的地形和冲突地区。

设计人员和开发人员面临的挑战在于找出一种方法,以确定对智能系统至关重要的主要特点。例如,掩护可以由关卡设计师预先确定,或可以在加载或编译地图时进行预先计算。有些元素可以动态评估,如冲突地图和紧迫威胁。

基于规则的系统

智能系统采用的最基本形式是基于规则的系统。这一系统延伸了“人工智能”这一术语。一组预设行为用于确定游戏实体的行为。对于各种行为,总体结果可以是一个虽然涉及的实际智能很少但并不明显的行为系统。

在基于规则的系统方面,Black Jack 庄家就是一个很好的例子(无论是视频 Black Jack 还是真正的 Black Jack)。庄家遵循一个简单规则:当牌点数为 17 或不到 17 时必须要牌。一般玩家的看法是庄家有竞争力。玩家会设想一个比其当前敌手更有能力的对手(除非赌场经营者公布庄家遵守的规则)。

Pac-Man 是这一系统的典型应用。 四个鬼纠缠着玩家。每个鬼都遵循一个简单的规则集。一个鬼一直左转,另一个一直右转,一个以随机方向转弯,最后一个转向玩家。每个鬼的移动方向很容易弄清楚,玩家能够轻松避开他们。但作为一个集体,这些鬼的移动方式看起来就复杂的多,相互协调配合共同寻找玩家。事实上,检查玩家位置的只有最后一个鬼。

控制Pac-Man 鬼的规则集的直观图,其中的箭头代表将作出的“决策”。

正如本例所示,规则不需要硬编码: 规则可以基于感知到的状态(如最后一只鬼)或实体的可编辑参数。 进攻、勇气、视线范围和思考速度等变量均可以产生更多样化的实体行为,即使是在基于规则的系统中。 基于规则的系统是最简单的人工智能结构。更复杂的智能系统基于一系列条件规则构建并由这些规则管理。在战术游戏中,规则控制着要使用的策略。在策略游戏中,规则控制着建造顺序和应对冲突的方式。基于规则的系统是人工智能的基础。

有限状态机作为人工智能

有限状态机 (FMS) 是一种概念化和实施在整个生命周期中拥有不同状态的实体的方式。“状态”可以代表实体所处的物理状态,或者也可以代表实体展示出的情感状态。在本例中,情感状态并不是真正人工智能的情感状态,而是融入游戏环境的预定行为模型。

下面是一个人工智能系统的常见状态示例,针对一个包含隐性元素的游戏:

典型 FSM 中的状态布局,其中的箭头表示可能的状态变化

闲置。在这种状态下,实体会被动地站着或沿固定路线走动。感知水平低。不常检查游戏玩家的声音。只有这一实体受到攻击或“看到”玩家直接在其前面时,它的状态才会更改为较高的认知水平。

感知。这一实体主动寻找入侵者。它会经常检查游戏玩家的声音,比闲置实体看得更远更宽泛。如果这一实体注意到碍事的某物(在其检查范围之内),如打开的门、无意识的尸体和用过的弹壳等,它将变为好奇状态。

好奇。这一实体意识到发生了不寻常的事情。为了证实这一行为,该实体将放弃其正常岗位或路线,移动到感兴趣的区域,如前面提到的打开的门或尸体。 如果玩家被发现,实体将变为警戒状态。

警戒。在这种状态下,实体已经注意到玩家并将开展追捕玩家的行动:移入攻击范围、提醒其他警卫、发出警报并寻找掩护。当实体在敌人范围内时,它将切换到攻击状态。

攻击。在这种状态下,敌人已经参与到与玩家的战斗中来。 实体会在可能时攻击玩家,并在不同的攻击回合之间寻找掩护(根据攻击缓和时间或装弹时间)。只有在消灭敌人后(恢复正常)、敌人移动到射程之外(回到警戒阶段)或实体死亡(进入死亡状态)时,实体才会离开这个状态。 如果实体的生命值很低,它可以切换为逃跑状态,这取决于特定实体的胆量。

逃跑。在这种状况下,实体会试图逃离战斗。根据游戏的不同,可能会有寻找生命值或离开游戏区域的次级目标。 当实体找到生命值后,它可能会返回到警戒状态并恢复战斗力。 “离开”的实体只是删除了而已。

死亡。在有些游戏中,死亡状态可能不是完全闲置。死亡或濒死的实体可能会“大声呼叫”,从而提醒附近的实体,或进入神志不清的状态,医师可使其复活(并返回到警戒状态)。

在实体系统中实施 FMS 至少有两种简单方法。第一种是让每种状态成为一种可以检查的变量(通常通过大量的开关语句)。第二种方法是使用函数指针(C 语言)或虚拟函数(C++ 和其他面向对象的语言)。

自适应人工智能

前面的章节讨论了如何设计融入游戏预定义事件的智能系统。 对于大多数游戏而言,只要设计缜密且对智能实体的目标有清晰的认识,这就足够了。如果游戏需要更多的变化并为玩家提供更好、更有活力的对手,人工智能可能需要具备增长和独自适应的能力。

自适应人工智能通常用于格斗游戏和策略游戏,这些游戏具有深层次的机制和无数的游戏选项。若要为玩家提供持续的挑战且避免玩家最终找出打败电脑的最佳策略,人工智能需要具备学习和适应的能力。

预测

有效预测对手下一步行动的能力对于自适应系统至关重要。可以使用不同的方法,如过去模式识别(在未来的文章中介绍)或随机猜测,以确定要采取的下一步行动。

适应的一个基本方法是记录过去的决策并评估成功程度。人工智能系统会记录一个游戏玩家在过去所做的选择。过去的决策必须以某种方式进行评估。 (如在格斗游戏中,获得的优势或损失的生命值或时间优势可以作为成功的衡量指标。) 可以通过收集有关这种情况的更多信息来为决策提供一些背景,如相对生命值、以前的行为和关卡定位(当玩家走投无路时会采用不同的游戏方式)。

可以通过评估这些历史信息来确定以前行为的成功程度以及是否需要改变战术。在构建过去行为列表之前,可以使用一般战术或随机行为来引导实体的行为。这一系统可以与基于规则的系统和不同的状态相结合。

在战术游戏中,过去的历史可以决定用于对付玩家团队的最佳战术,如防守、进攻、狂暴或一些平衡的游戏方法。在策略游戏中,可以基于玩家发现一个部队中最佳的分队组合。在由人工智能控制玩家支持角色的游戏中,通过了解玩家的行为方式,自适应人工智能可以更好地补充玩家的自然风格。

总结

人工智能是一个复杂的研究领域。根据游戏需求的不同,游戏行业的人工智能会采用不同的形式,从计算机控制器实体的简单规则集到更先进的自适应系统。在游戏行业中应用人工智能概念对于提高电子娱乐产品中虚拟人物的可信度必不可少,但它并不是一个不可能的挑战。

via:GAD

相关阅读:游戏AI设计经验分享——行为树研究

最新评论
暂无评论
参与评论

商务合作 查看更多

编辑推荐 查看更多