当前位置: 首页 > news >正文

Game AI ——游戏人工智能(逻辑及剧情生成)

一、Game AI 的介绍 

       "Game AI"(游戏人工智能)通常指的是在电子游戏中使用的各种人工智能技术和算法,用于控制游戏中的非玩家角色(NPC)、敌人、队友等,以及为玩家提供有挑战性的对手或有趣的互动体验。Game AI 的核心目的是增强游戏的可玩性和沉浸感,使游戏世界更加生动和富有挑战性。

       包括 AI bot、NPC 逻辑及剧情生成和数字资产生成。
       游戏AI主要关注实体根据当前条件所采取的行动。这就是传统人工智能文献所指的控制“ 智能代理”,代理通常是游戏中的角色,但也可以是车辆,机器人。或者更抽象的东西,例如一组实体,甚至一个国家或文明。 

二、Game AI 的核心功能和技术 

1. 路径规划与导航(Pathfinding & Navigation)

功能:

路径规划与导航是Game AI的重要组成部分,主要用于指导NPC或敌人在游戏环境中移动,使其能够有效地避开障碍物并到达目标地点。这在开放世界、策略、动作游戏中尤为关键。

技术:
  • A算法(A Search Algorithm)

    • 一种启发式搜索算法,广泛应用于游戏中。A*算法通过评估从起点到目标的“成本”,选择最佳路径。它结合了Dijkstra算法的最短路径和贪婪搜索算法的启发式方法,既保证了路径的最优性,又提高了搜索效率。
  • Dijkstra算法(Dijkstra’s Algorithm)

    • 用于计算图中节点之间的最短路径。虽然效率不如A*算法高,但在某些无障碍的游戏场景中仍有应用。
  • NavMesh导航网格(Navigation Meshes, NavMesh)

    • 一种几何分割技术,将游戏环境划分为一系列可导航区域,NPC在这些区域之间移动。NavMesh可以通过预先计算路径提高游戏运行时的效率。
  • 基于物理模拟的运动规划(Physics-based Motion Planning)

    • 结合物理引擎,使NPC能够以更自然和真实的方式移动。常见于3D游戏中,如使用力和碰撞检测来模拟NPC的行走、奔跑、跳跃等动作。

2. 决策树与行为树(Decision Trees & Behavior Trees)

功能:

决策树和行为树用于管理NPC的行为逻辑和决策制定,帮助NPC选择适当的行动响应玩家的操作和环境变化。

技术:
  • 决策树(Decision Trees)

    • 一种分层结构,通过一系列的条件判断来决定NPC的行为。决策树是简单且直观的,适用于处理明确的行为逻辑,如“如果看到玩家,则攻击,否则巡逻”。
  • 行为树(Behavior Trees)

    • 行为树是决策树的扩展,提供了更灵活的结构。它不仅可以处理条件判断,还可以管理复杂的行为组合和序列化操作。行为树能够在不影响整体逻辑的情况下轻松添加或修改行为,广泛应用于复杂的AI行为管理。

3. 有限状态机(Finite State Machines, FSMs)

功能:

FSMs用于描述NPC在不同状态之间的转换,如攻击、防御、巡逻、逃跑等状态,使得AI能够根据游戏场景变化做出合适的反应。

技术:
  • 状态与转换(States & Transitions)

    • NPC的行为被分解为多个状态,每个状态代表一种特定的行为。状态之间通过条件转换连接,例如“当玩家接近时,从巡逻状态切换到攻击状态”。
  • 层次有限状态机(Hierarchical FSM, HFSM)

    • 允许状态机嵌套,使得复杂行为可以分解为更小的子状态机,从而提高AI行为的管理和扩展能力。

4. 群体行为与协作(Group Behavior & Cooperation)

功能:

群体行为与协作技术允许多个NPC或敌人协调行动,如团队战斗、群体移动等。这在多人游戏和策略游戏中尤其重要。

技术:
  • 分布式AI(Distributed AI)

    • 在群体行为中,每个NPC都有自己的AI,但它们之间通过信息共享来协调行动,如共同攻击目标或维持队形。
  • 领队-跟随模型(Leader-Follower Model)

    • 一个NPC作为领队,其他NPC作为跟随者。领队决定整体行动方向,跟随者根据领队的位置和行动进行调整。这种模型常用于实现如队伍移动、护送任务等。
  • 基于物理的碰撞避免(Physics-based Collision Avoidance)

    • 利用物理模拟来处理NPC之间的碰撞避免,使群体行为更加流畅和真实。

5. 学习与适应(Learning & Adaptation)

功能:

使得Game AI能够根据玩家的行为进行学习和适应,提高游戏挑战性,保持玩家的兴趣。

技术:
  • 强化学习(Reinforcement Learning, RL)

    • NPC通过与环境交互,基于奖励机制学习最优行为策略。例如,AI可以通过反复尝试不同战术,并根据成功与否进行调整。
  • 遗传算法(Genetic Algorithms, GA)

    • 通过模拟自然选择和进化,AI可以优化行为策略。AI会生成多个行为“个体”,选择表现最好的进行“繁殖”和“变异”,逐渐优化行为模式。
  • 神经网络(Neural Networks)

    • 通过大规模数据训练,AI可以学会复杂的行为和决策模式,特别是在动态和复杂的游戏环境中,如动作识别、策略优化等。

6. 情感模拟与社交互动(Emotion Simulation & Social Interaction)

功能:

通过情感模拟和社交互动,使NPC的行为更加人性化,使玩家能够感受到NPC的情感变化和个性特点,增强游戏的沉浸感。

技术:
  • 情感模型(Emotion Models)

    • 模拟NPC的情感状态,如快乐、愤怒、恐惧等,并根据这些情感状态调整NPC的行为。例如,NPC在感到恐惧时可能会逃跑,而在愤怒时可能会攻击。
  • 社交行为树(Social Behavior Trees)

    • 扩展行为树,使NPC能够进行复杂的社交互动,如谈话、合作、竞争等。NPC可以根据与玩家和其他NPC的关系调整其行为。
  • 基于规则的情感表达(Rule-based Emotion Expression)

    • 使用预设规则来控制NPC的情感表达,如面部表情、语音语调、肢体语言等。

三、Game AI 的使用场景

  1. 战斗系统(Combat Systems)

    在动作游戏和射击游戏中,Game AI用于控制敌人的攻击、防御、协作策略,使战斗更加激烈和富有挑战性。
  2. 策略与模拟游戏(Strategy & Simulation Games)

    在策略游戏中,AI负责管理资源、制定战术、执行战略决策;在模拟游戏中,AI用于模拟复杂的生态系统或社会结构。
  3. 冒险与RPG游戏(Adventure & RPG Games)

    AI用于生成任务、控制对话和故事发展,管理玩家与NPC的互动,提升游戏的沉浸感。
  4. 体育与竞速游戏(Sports & Racing Games)

    AI用于控制对手队伍或赛车手,模拟人类玩家的决策和反应,使游戏更具挑战性和真实性。

相关文章:

Game AI ——游戏人工智能(逻辑及剧情生成)

一、Game AI 的介绍 "Game AI"(游戏人工智能)通常指的是在电子游戏中使用的各种人工智能技术和算法,用于控制游戏中的非玩家角色(NPC)、敌人、队友等,以及为玩家提供有挑战性的对手或有趣的互动…...

算法基础知识——核函数

简介:个人学习分享,如有错误,欢迎批评指正 核函数(Kernel Function)是机器学习中一种重要的工具,特别是在支持向量机(SVM)、核岭回归、核主成分分析(KPCA)等核…...

安卓xml乱码/加密转换:abx2xml和xml2abx使用及源码介绍

背景: 上一篇文章 android系统中data下的xml乱码无法查看问题剖析及解决方法 发布后,想要寻找一个可以直接把二进制xml和普通xml进行相互转换的,当时还写了相关的方案,但是当时没有找到现成的开源工具,后来经过相关粉…...

slice 截取

JavaScript中的一个数组方法。然而,在Vue 3的应用开发中,slice 方法经常被用于处理数组数据,特别是在需要实现分页、数据截取或数据展示等场景时。 slice 方法的基本用法 slice() 方法返回一个新的数组对象,这一对象是一个由 be…...

XReparentWindow踩坑分析

X11是Linux发行系统中广泛采用的显示协议,各个系统基本上都支持XLib库,作为底层接口,XReparentWindow接口的功能就是重新设置父窗口,注意这个可以跨进程设置父窗口,例如将已经运行的进程的父窗口设置自己的程序Wid&…...

OpenAI动荡,将走向何方、GPT5或许将近、毒舌AI轻松破防网友、最新版 GPT-4o AI 模型得满分 | AGI视界周刊第 4 期

AI 视界周刊由战场小包维护,每周一更新,包含热点聚焦、应用破局、学术前沿、社区热议、智见交锋、跨界 AI、企业动态和争议 AI 八大板块,后续板块划分和内容撰写在周刊迭代过程中持续优化,欢迎大家提出建议。 欢迎大家来到《AI 视…...

RCE---无字母数字webshell

<?php if(isset($_GET[code])){$code $_GET[code];if(strlen($code)>35){die("Long.");}if(preg_match("/[A-Za-z0-9_$]/",$code)){die("NO.");}eval($code); }else{highlight_file(__FILE__); } 分析代码&#xff1a;传参不大于35&…...

有意思的漏洞复现与分析一

目录 一、Linux命令长度限制突破方法 1.在二进制漏洞利用中&#xff0c;某师傅遇到可控数据只有8字节的情况&#xff0c;去掉字符 串尾的\0&#xff0c;限制在7个字符。 一、Linux命令长度限制突破方法 1.在二进制漏洞利用中&#xff0c;某师傅遇到可控数据只有8字节的情况&a…...

力扣题解(按身高排序)

2418. 按身高排序 给你一个字符串数组 names &#xff0c;和一个由 互不相同 的正整数组成的数组 heights 。两个数组的长度均为 n 。 对于每个下标 i&#xff0c;names[i] 和 heights[i] 表示第 i 个人的名字和身高。 请按身高 降序 顺序返回对应的名字数组 names 。 思路&…...

Redis的六种淘汰策略详解

Redis作为一种高性能的键值对存储系统&#xff0c;其数据全部存储在内存中&#xff0c;因此内存管理对Redis的性能至关重要。当Redis的内存使用达到上限时&#xff0c;就需要通过淘汰策略来释放内存空间&#xff0c;以便存储新的数据。Redis提供了六种不同的淘汰策略&#xff0…...

vue3中 ref 和 reactive 的区别

相同&#xff1a;均是声明响应式对象。且声明的响应式对象是深层的 1. 数据类型不同&#xff1a;ref用于包装JavaScript基本类型的数据&#xff08;如字符串、数字、布尔值等&#xff09;&#xff0c;而reactive可以用于包装JavaScript对象和数组等复杂类型的数据。 2.访问方式…...

《单例模式的深度解读:实现方式、破坏情况与利弊权衡》

单例模式 一、单例模式的定义 ​ 单例模式&#xff08;Singleton Pattern&#xff09;是一种常见的软件设计模式&#xff0c;确保一个类只有一个实例存在&#xff0c;并提供一个全局访问点来获取该实例。 二、单例模式的实现方式 ​ 1.懒汉式单例 public class LazySingle…...

010607电压源和电流源受控源

电源的理论部分 1.6电压源和电流源1.理想电压源&#xff1a; 1.6电压源和电流源 1.理想电压源&#xff1a; 其两端电压总能保持定值或一定的时间函数&#xff0c;其值与流过它的电流i无关的元件叫理想电压源。 电路符号&#xff1a;中间与导线直通的圆圈 电压源&#xff1a…...

快乐数求解

编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不到 1。如果这个过程 结果为 1&#xff0c…...

运维高级内容--为端口做标记、制定调度规则

rs: yum install mod_ssl -y #安装mod_ssl模块 让rs支持https systemctl restart http lvs: cd /boot/ ls less config-5.14.0-427.13.1.el9_4.x86_64 ipvsadm -A -t 192.168.0.200:80 -s rr ipvsadm -a -t 192.168.0.200:80 -r 192.168.0.10:80 -g -w 1 #轮询调度一次…...

后端Web之HTTP协议基础介绍

目录 1.HTTP概念 2.HTTP请求协议 3.HTTP响应协议 4.HTTP协议解析 1.HTTP概念 HTTP&#xff08;HyperText Transfer Protocol&#xff0c;超文本传输协议&#xff09;是一种用于分布式、协作式和超媒体信息系统的应用层协议。它是万维网数据通信的基础&#xff0c;允许将超…...

深入解析Nginx限流策略:如何高效控制访问频率

摘要&#xff1a;本文将详细介绍Nginx限流模块的使用方法&#xff0c;包括基于IP地址的限流、基于并发连接的限流以及如何应对突发流量。通过实际案例&#xff0c;帮助读者掌握Nginx限流策略&#xff0c;确保服务器在高并发场景下的稳定运行。 一、引言 在高并发场景下&#x…...

锂电池剩余寿命预测 | Matlab基于Transformer-GRU的锂电池剩余寿命预测

目录 预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Matlab基于Transformer-GRU的锂电池剩余寿命预测&#xff0c;Transformer结合门控循环单元。 Matlab基于Transformer-GRU的锂电池剩余寿命预测&#xff08;单变量&#xff09; 运行环境Matlab2023b及以上。 首先从…...

深入理解Spring的IOC容器与依赖注入

深入理解Spring的IOC容器与依赖注入 引言 Spring框架的核心功能之一就是它的IOC容器&#xff0c;它为开发人员提供了强大的依赖管理和控制反转的能力。本文将详细介绍Spring的IOC容器以及依赖注入的基本概念和实现方式&#xff0c;并通过示例展示如何在实际项目中应用这些技术…...

Qt读写sysfs

本文介绍Qt读写sysfs。 在嵌入式Linux系统上开发Qt应用程序&#xff0c;经常会涉及到外设的控制&#xff0c;比如GPIO&#xff0c;PWM的控制&#xff0c;Linux环境下可以像操作文件一样操作它们&#xff0c;这通常会涉及到sysfs的读写。本文以读写GPIO为例&#xff0c;简要介绍…...

实景三维:解锁地理信息新维度,引领未来城市智慧之钥

在这个信息爆炸与科技日新月异的时代&#xff0c;地理信息与遥感技术正以前所未有的速度改变我们认知世界的方式。在推动“实景三维平台”这一前沿科技的构建上&#xff0c;它不仅是地理信息的立体呈现&#xff0c;更是智慧城市的基石&#xff0c;打开了通往未来城市规划、管理…...

汽车免拆诊断案例 | 2010款劳斯莱斯古斯特车中央信息显示屏提示传动系统故障

故障现象  一辆2010款劳斯莱斯古斯特车&#xff0c;搭载N74发动机&#xff0c;累计行驶里程约为11万km。车主反映&#xff0c;起动发动机后组合仪表和中央信息显示屏均提示传动系统故障。用故障检测仪检测&#xff0c;发现发动机控制模块2&#xff08;DME2&#xff09;中存储…...

监督学习和无监督学习是什么?

监督学习和无监督学习是机器学习中的两种基本学习方式&#xff0c;它们在处理数据和训练模型时有着显著的区别。 监督学习 定义&#xff1a; 监督学习是指利用一组已知类别的样本&#xff08;即标记的数据&#xff09;来调整分类器的参数&#xff0c;使其达到所要求性能的过程…...

YII2的errorHandler.errorAction失效原因

<?phpreturn [components => [errorHandler => [errorAction => site/error,],] ]; 这段配置存在错误,导致错误处理无法生效。为了解决这个问题,我们需要对配置进行优化。 代码查看:yii\web\ErrorHandler::renderException <?phpprotected function ren…...

已知p指向双向循环链表中的一个结点,其结点结构为data、prior、next三个域,写出算法change(p),交换p所指向的结点和它的前缀结点的顺序。

#include<assert.h> typedef struct SLnode {int data;struct SLnode* prior;struct SLnode* next; }SLnode,*SLnodelist; //创建结点 SLnode* createhead(int data) {SLnode* newnode (SLnode*)malloc(sizeof(SLnode));newnode->data data;newnode->next newno…...

什么是Tensor???为什么人工智能领域论文中经常出现这个名词

文章目录 什么是Tensor&#xff1f;&#xff1f;数学符号表示 什么是Tensor&#xff1f;&#xff1f; Tensor&#xff0c;中文叫张量。Tensor实际上就是一个多维数组&#xff08;multidimensional array&#xff09;。 而Tensor的目的是能够创造更高维度的矩阵、向量。 数学符…...

爬虫练习_01

前言 基础爬虫小练习01 一、requests板块使用 demo_01 import requests from lxml import etreeurl "https://movie.douban.com/top250" headers {"authority": "movie.douban.com","method": "GET","path"…...

Datawhale X 魔搭 AI夏令营第四期 魔搭-AIGC方向 task02笔记

从零入门AI生图原理&实践 是 Datawhale 2024 年 AI 夏令营第四期的学习活动&#xff08;“AIGC”方向&#xff09;&#xff0c;基于魔搭社区“可图Kolors-LoRA风格故事挑战赛”开展的实践学习。 Datawhale官方的Task2链接&#xff1a;Task02 往期Task1链接&#xff1a;Ta…...

多模态大语言模型的免训练视觉提示学习 ControlMLLM

ControlMLLM: Training-Free Visual Prompt Learning for Multimodal Large Language Models github paper 在本研究中&#xff0c;提出了一种无需进行训练的方法&#xff0c;通过可学习的潜变量优化将视觉提示注入到多模态大型语言模型&#xff08;MLLMs&#xff09;中。 在…...

Oracle|DM 常用|不常用 SQL大口袋

目录 一、前言 二、SQL写法 1、sql获取某一条数据中的前一条和后一条 2、实现like多个值的查询&#xff08;Oracle和dm支持&#xff0c;MySQL未试过&#xff09; 3、start with connect by prior 使用方法 4、用hextoraw解决select、update、delete语句执行慢 5、ORA-00…...