《游戏开发中的人工智能43657.pptx》由会员分享,可在线阅读,更多相关《游戏开发中的人工智能43657.pptx(23页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、FACULTY OF SOFTWARE1游戏开发中的人工智能-脚本AI 及脚本引擎FACULTY OF SOFTWARE2 脚本概述 脚本引擎 实例AI 脚本语言的危险 开发脚本语言的注意事项脚本AI 及脚本引擎FACULTY OF SOFTWARE3脚本概述 脚本概述 概述 开发脚本语言的动机 脚本语言剖析 编译器FACULTY OF SOFTWARE4 脚 本 是 为 了 简 化 某 种 特 定 程 序 的 复 杂 任 务 而 设 计 的 一种 编 程 语 言。因 此,脚 本 是 根 据 程 序 的 特 点 定 制 的,它 的 使 用 范 围 在 很 大 程 度 上 取 决 于 所 需 要
2、 解 决 的 问题。脚 本 机 制 可 以 说 是 游 戏 开 发 过 程 中 不 可 或 缺 的 一 部 分,它 可 以 让 游 戏 设 计 师 而 不 是 游 戏 程 序 员 撰 写 出 游 戏的 巧 妙 之 处,并 予 以 精 细 化。玩 家 也 可 以 利 用 脚 本语言,建立或修改其所处的游戏世界或等级。脚 本 系 统 怎 样 及 如 何 操 作,主 要 取 决 于 该 系 统 的 使 用者。开 发 脚 本 系 统 时 还 应 该 考 虑 其 他 因 素,例 如:加 密、开发描述编译器等,使得最后的结果难以让人阅读。脚本概述FACULTY OF SOFTWARE5 并 行 开 发:脚
3、 本 语 言 可 以 允 许 设 计 人 员 在 独 立 于 程 序开发人员的情况下构造很多新的特性并做修改。易 于 使 用:脚 本 语 言 提 供 了 一 种 比 专 业 编 程 语 言 更 简单,开发环境更受保护的工具。数据驱动的设计 开发速度快 安 全 性:脚 本 语 言 在 一 个 受 保 护 的 环 境 中 运 行,可 以保 证 脚 本 内 的 致 命 错 误 不 会 使 游 戏 崩 溃,最 坏 的 情况就是脚本被停止执行。可扩展性:允许游戏使用者扩展AI开发脚本语言的动机FACULTY OF SOFTWARE6 一个脚本语言通常由两部分组成:语言和引擎 脚 本 语 言 与 任 何
4、一 种 编 程 语 言 一 样,规 定 了 一 组 特定 的 语 法,脚 本 语 言 可 以 通 过 转 化 或 编 译 变 换 为 引擎可以处理的格式。脚本引擎也称为解释器,用来执行经过编译的脚本。经 过 编 译 的 脚 本 称 为 字 节 码 流(bytecode stream),它 包 含 了 脚 本 需 要 解 释 器 所 执 行 的 所 有 内容。脚本语言的剖析FACULTY OF SOFTWARE7编译器 概述 词法分析器 语法分析器 代码生成器 语法分析树FACULTY OF SOFTWARE8编译器概述 编译器负责把开发人员编写的源文件转化为计算机可以执行的代码。脚本语言的编译
5、器与传统的编译器直接产生可执行代码不同,它生成字节码流,字节码流包含了脚本需要解释器所执行的所有内容。FACULTY OF SOFTWARE9 编译器转换步骤:词法分析器首先用来处理词组,读入源代码,然后把它们分解为一些基本的单元,即脚本语言中任何一个单独的结构(construct),称为Token。例如:-,*,=,if,void,MyFunction。Token 被传送给语法分析器。语法分析器负责定义语言的合理结构,确保当前的脚本是一段合理的程序,负责把脚本源代码转换为编译器可以理解的结构,即语法分析树。语法分析树被交给代码生成器生成字节码流。代码生成器递归地遍历整个语法分析树以处理其中每
6、一个节点,并生成相应的可以执行的命令。FACULTY OF SOFTWARE10语法分析树 语法分析树是程序员所写的脚本源代码的另一种表现形式,它能被编译器所理解。由于绝大多数编程语言都是高度结构化的,所以它们能被表示为一种树状结构。树上的每一个节点都对应了语言中的一种结构类型(例如,条件语句,函数调用,表达式等),这些节点的子节点是相应的语言结构所需要的操作数。FACULTY OF SOFTWARE11语法分析树FACULTY OF SOFTWARE12脚本引擎 堆栈机 堆栈机的执行 控制代码流FACULTY OF SOFTWARE13脚本引擎堆栈机 任何一种脚本语言都需要一个用来执行程序员
7、所编写脚本的引擎,即翻译器,负责脚本执行的各个方面的工作。由于翻译器执行的指令集并不是特定的汇编代码,因此称之为虚拟机(VM),负责执行编译器所生成的字节码流。堆栈机是脚本语言虚拟机技术中普遍采用的一种基本形式。堆栈机的操作码首先从堆栈中弹出将被操作的数据,然后把得到的答案压入同一个堆栈中。不断重复该过程,直到整个字节码流都被执行后结束。由此可知,操作仅需要堆栈和指令指针(用来指向字节码流中将被执行的下一条指令)。FACULTY OF SOFTWARE14 实现堆栈机最直接的方法就是构造一个类,包括堆栈数据,指令指针以及用来处理各种操作码的逻辑过程(操作码处理器)。操作码处理器是构造堆栈机的关
8、键,它负责处理每一个操作码所需要的工作。由于每一个操作码处理器是类中唯一的一个成员函数,可以通过一个函数指针表来正确地调用。操作码的值由堆栈机定义,它需要定义从0 开始的连续的整数,来作为函数指针表的索引。每个操作码处理器都返回一个布尔变量来表明操作码所定义的操作是否成功,若操作失败则停止对字节码流的执行,调用错误恢复程序后清空。脚本引擎堆栈机FACULTY OF SOFTWARE15堆栈机例如:Class VM bool HandlePush(Opeode op)/.typedef bool(VM:*OpcodeHandler)(opcode);OpcodeHandler m_opHandl
9、ersNnm_opcode;每个函数处理器被OpcodeHandler 定义,都以一个操作码为参数。通过把当前指令的操作码传递给处理器,对应不同操作就分别调用某个固定的处理器来执行。FACULTY OF SOFTWARE16 堆栈机中还包括一个堆栈数据成员,用来存放各种操作所需的操作数。由于STL 容器向量提供了常数时间的插入和删除操作,而且对于每一个数据项的随机访问操作都是常数时间的,所以非常适合用来构造这种堆栈。堆栈机中还包括一个指令指针,指令指针始终指向所需执行的下一条指令,表现为指向字节码流的操作码指针。脚本引擎堆栈机FACULTY OF SOFTWARE17 初始化,即清空堆栈、将指
10、令指针指向字节码流的起始位置。进入循环,依次执行每条指令。首先,指令指针所指向的操作码被获得,作为索引传递给操作码处理器用来调用正确的操作处理函数。循环直到整个字节流码被执行完毕后结束。操作码处理器完成堆栈操作的所有细节,例如:出栈、入栈、相加操作等。堆栈机的执行FACULTY OF SOFTWARE18控制代码流条件语句 对于简单条件语句,即只具有条件为真时所执行的程序块。首先得到条件表达式的取值,然后把它压入堆栈的顶部,接着执行“为0 时跳转”操作,即首先把堆栈顶部的操作数弹出,若值为假,则按照字节流码中给出的偏移量进行跳转(跳到条件语句后的第一条语句);若值为真,则执行条件语句中的程序块
11、。对于具有条件为真和为假的程序块而言,偏移量指向条件表达式为假时所需执行的程序块的第一句。编译器会在条件表达式为真时,所需执行的程序块结束的地方,生成一条相对跳转语句,用来跳过紧跟在后面的条件为假时所需执行的程序块。FACULTY OF SOFTWARE19控制代码流循环语句 循环语句执行时混合使用条件转移和相对转移指令。例如:C 风格的for 循环会生成以下伪汇编代码:Perform preloop expression.A:Perform loop conditional expression.Jump to label B if top-stack element is zero.Per
12、form loop body statements.Perform loop incremental expression.Jump to label A.B:First statement after the for-loop.FACULTY OF SOFTWARE20控制代码流函数 由于当函数执行完毕时需要返回到调用它的代码所在的位置,所以虚拟机需要通过维护一个指令指针的地址堆栈来对函数调用的状态进行跟踪,以便当函数返回时对指令指针的值进行更新。即当函数被调用时,当前指令指针的值被压入这个堆栈的顶部,然后函数中第一条指令的地址值被赋给指令指针。当函数执行完毕时,函数堆栈顶部的数据被用来重置
13、指令指针的值,以便程序执行回到函数调用的地方。虚拟机用堆栈帧(stack frames)来存放函数的返回值、参数和局部变量。通过帧指针(frame pointer)指向第一个局部变量来访问堆栈帧中的任何参数和局部变量。处于激活状态的堆栈帧都维护在一个链表中,并且被保存在调用堆栈(call stack)中,调用堆栈中包含每个堆栈帧的指针和指令指针。FACULTY OF SOFTWARE21实例 指定对手属性:决定因素是游戏类型 脚本的基本分析 影响对手行为 增 加 预 先 定 义 好 的 全 局 变 量,并 由 游 戏 引 擎 赋 值,以 评 估游戏世界里的特殊情况。AI 角色的移动 口语互动
14、口语嘲讽 辅助暗示 触发事件及增加气氛FACULTY OF SOFTWARE22AI 脚本语言的缺陷 语言的成熟性:改进、开发工具、参考手册 缺乏具有完全特性的开发、调试和统计工具 脚 本 都 是 在 运 行 时 进 行 解 释 的,因 此 具 有 更 大 的 性能负担 固定性的AI 脚本会使得游戏重玩性大大降低 设计正确的界面(编辑器)设计者与AI 交互 决 定AI 实 体 的 初 始 位 置、提 供 附 加AI 实 体 参 数、指 定 运 动路 径、指 定AI 实 体 之 间 或AI 实 体 和 游 戏 中 对 象 的 关 系、设计偶然被触发的事件FACULTY OF SOFTWARE23开发脚本语言的注意事项 注 意 被 固 化 在AI 中 的 能 力,如 果AI 能 独 立 地 做 越 多工作,则脚本语言所需补充的东西就越少 脚本语言是否合适需求 是 否 需 要 一 个 特 性 完 备 的 编 程 语 言 还 是 一 个 简 单 的触发系统 考虑使用已有的编程语言 考虑设计者可以使用的调试工具 考虑运行时的性能问题 注意所开发出脚本的灵活性