AI决策算法 之 GOAP (三)
源码地址:http://pan.baidu.com/s/1dFwzmfB
这篇我们使用上篇文章写的GOAP框架来完成一个实例:
实例内容:
AI有10HP, 需要去站岗,站岗完成扣5HP
当HP<=5必须去补充HP,找到HP球补充HP,每个HP球补充5HP
根据GOAP框架逻辑推断出需要:AI数据提供者,站岗Action,补充HPAction,HP点脚本,站岗点脚本, AI属性脚本
主要脚本:
AI数据提供者
- public class Worker : MonoBehaviour,IGoap{
- private PropertyComponent property; //属性脚本
- public float moveSpeed = 3; //移动速度
- void Start()
- {
- property = GetComponent<PropertyComponent>();
- }
- public System.Collections.Generic.HashSet<System.Collections.Generic.KeyValuePair<string, object>> GetState()
- {
- HashSet<KeyValuePair<string, object>> state = new HashSet<KeyValuePair<string, object>>();
- //当前状态HP是否足够
- state.Add(new KeyValuePair<string, object>("EnoughHP", property.HP > 5));
- return state;
- }
- public System.Collections.Generic.HashSet<System.Collections.Generic.KeyValuePair<string, object>> CreateGoalState()
- {
- HashSet<KeyValuePair<string, object>> goal = new HashSet<KeyValuePair<string, object>>();
- //站岗完成目标
- goal.Add(new KeyValuePair<string, object>("SentryComplete", true));
- return goal;
- }
- public void PlanFailed(System.Collections.Generic.HashSet<System.Collections.Generic.KeyValuePair<string, object>> failedGoal)
- {
- }
- public void PlanFound(System.Collections.Generic.HashSet<System.Collections.Generic.KeyValuePair<string, object>> goal, System.Collections.Generic.Queue<Action> actions)
- {
- }
- public void ActionsFinished()
- {
- Debug.LogError("FinishedSentry");
- }
- public void PlanAborted(Action aborterAction)
- {
- }
- public bool MoveAgent(Action tagetAction)
- {
- //移动
- float step = moveSpeed * Time.deltaTime;
- gameObject.transform.position = Vector3.MoveTowards(gameObject.transform.position, tagetAction.target.transform.position, step);
- if (gameObject.transform.position.Equals(tagetAction.target.transform.position))
- {
- tagetAction.IsInRange = true;
- return true;
- }
- else
- return false;
- }
- }
站岗Action
- public class SentryAction : Action {
- private SentryComponent targetSentry; //站岗目标脚本
- private float SentryTimer = 0; //站岗计时
- public float SentryTime = 3;
- bool isDone = false; //是否完成
- public SentryAction()
- {
- AddPrecondition("EnoughHP", true); //前置条件:必须HP足够
- AddEffect("SentryComplete", true); //完成效果:站岗完成
- }
- public override void Reset()
- {
- targetSentry = null;
- SentryTimer = 0;
- isDone = false;
- }
- public override bool IsDone()
- {
- return isDone;
- }
- public override bool CheckProcedualPrecondition(GameObject agent)
- {
- //得到最近的站岗目标
- SentryComponent[] sentryComponents = GameObject.FindObjectsOfType<SentryComponent>();
- SentryComponent temp = null;
- foreach(var v in sentryComponents)
- {
- if (temp == null)
- {
- temp = v;
- continue;
- }
- if (Vector3.Distance(agent.transform.position, v.transform.position) < Vector3.Distance(agent.transform.position, temp.transform.position))
- temp = v;
- }
- targetSentry = temp;
- target = temp.gameObject;
- return temp != null;
- }
- public override bool Perform(GameObject agent)
- {
- //站岗执行
- SentryTimer += Time.deltaTime;
- if(SentryTimer > SentryTime)
- {
- //站岗完成消耗HP
- agent.GetComponent<PropertyComponent>().HP -= 5;
- isDone = true;
- }
- return true;
- }
- public override bool RequiresInRange()
- {
- return true;
- }
- }
补充HPAction
- public class GetHPAction : Action {
- private HPPointComponent targetHPPoint; //HP点目标脚本
- bool isDone = false;
- void Start()
- {
- AddEffect("EnoughHP", true); //完成效果:HP补充到足够
- }
- public override void Reset()
- {
- targetHPPoint = null;
- isDone = false;
- }
- public override bool IsDone()
- {
- return isDone;
- }
- public override bool CheckProcedualPrecondition(GameObject agent)
- {
- HPPointComponent[] tempComponents = GameObject.FindObjectsOfType<HPPointComponent>();
- HPPointComponent temp = null;
- foreach (var v in tempComponents)
- {
- if (temp == null)
- {
- temp = v;
- continue;
- }
- if (Vector3.Distance(agent.transform.position, v.transform.position) < Vector3.Distance(agent.transform.position, temp.transform.position))
- temp = v;
- }
- targetHPPoint = temp;
- target = temp.gameObject;
- return temp != null;
- }
- public override bool Perform(GameObject agent)
- {
- DestroyImmediate(targetHPPoint.gameObject);
- isDone = true;
- agent.GetComponent<PropertyComponent>().HP += 5;
- return true;
- }
- public override bool RequiresInRange()
- {
- return true;
- }
- }
AI决策算法 之 GOAP (三)的更多相关文章
- AI决策算法 之 GOAP (一)
http://blog.csdn.net/lovethrain/article/details/67632033 本系列文章内容部分参考自:http://gamerboom.com/archives/ ...
- AI决策算法 之 GOAP (二)
http://blog.csdn.net/lovethRain/article/details/67634803 GOAP 的主要逻辑: 1.Agent的状态机初始化Idle状态 2.Idel状态根据 ...
- 贝叶斯公式由浅入深大讲解—AI基础算法入门
1 贝叶斯方法 长久以来,人们对一件事情发生或不发生的概率,只有固定的0和1,即要么发生,要么不发生,从来不会去考虑某件事情发生的概率有多大,不发生的概率又是多大.而且概率虽然未知,但最起码是一个确定 ...
- 贝叶斯公式由浅入深大讲解—AI基础算法入门【转】
本文转载自:https://www.cnblogs.com/zhoulujun/p/8893393.html 1 贝叶斯方法 长久以来,人们对一件事情发生或不发生的概率,只有固定的0和1,即要么发生, ...
- 2018科大讯飞AI营销算法大赛全面来袭,等你来战!
AI技术已成为推动营销迭代的重要驱动力.AI营销高速发展的同时,积累了海量的广告数据和用户数据.如何有效应用这些数据,是大数据技术落地营销领域的关键,也是检测智能营销平台竞争力的标准. 讯飞AI营销云 ...
- 多维算法思考(三):AB组合问题
多维算法思考(三):AB组合问题 题目:x个A,y个B可以组合成多少个不同排列的问题. 首先,我们用数学的方式思考,这个问题属于<组合数学>的问题,我们的第一种方法可以用组合思路来求解. ...
- 算法 排序lowB三人组 冒泡排序 选择排序 插入排序
参考博客:基于python的七种经典排序算法 [经典排序算法][集锦] 经典排序算法及python实现 首先明确,算法的实质 是 列表排序.具体就是操作的列表,将无序列表变成有序列表! 一 ...
- 实践案例丨基于ModelArts AI市场算法MobileNet_v2实现花卉分类
概述 MobileNetsV2是基于一个流线型的架构,它使用深度可分离的卷积来构建轻量级的深层神经网,此模型基于 MobileNetV2: Inverted Residuals and Linear ...
- 五子棋 AI(AIpha-beta算法)
博弈树 下过五子棋的人都应该知道,越厉害的人,对棋面的预测程度越深.换句话讲,就是当你下完一步棋,我就能在我的脑海里假设把我所有可能下的地方都下一遍,然后考虑我下完之后你又会下在哪里,最后我根据每次预 ...
随机推荐
- JMS消息可靠机制
ActiveMQ消息签收机制: 客戶端成功接收一条消息的标志是一条消息被签收,成功应答. 消息的签收情形分两种: 1.带事务的session 如果session带有事务,并且事务成功提交,则消息被自动 ...
- VS调试的问题
调试Vs,使用本地IIS也不行,使用外部服务器也不行,最后运行VS2013以管理员身份就可以了
- CSS3实现自定义Checkbox动画
CSS3实现自定义Checkbox动画是一款CSS3自定义checkbox,而且这款checkbox还带有动画效果,当你选中checkbox的时候,会以动画的方式打上一个大大的勾. 源码下载:http ...
- 分布式锁的实现方式——ACID数据库、缓存或者是zk
针对分布式锁的实现,目前比较常用的有以下几种方案: 基于数据库实现分布式锁 基于缓存(redis,memcached,tair)实现分布式锁 基于Zookeeper实现分布式锁 在分析这几种实现方案之 ...
- 勤于思考:jQuery Validation 在IE7(兼容模式)下出现“找不到成员”的脚本错误
今天在调试IE10下使用IE6判断脚本出现错误,处理后说IE7也不行,调试后则会出现以下错误: SCRIPT3: 找不到成员. jquery171.js, 行2582 字符4 其实开始我认为是jque ...
- 【HDU 4807】Lunch Time 最小费用最大流
题意 在一个有向图当中,现在每一条边带有一个容量,现在有K个人在起点,需要到终点去吃饭,询问这K个人最后一个人到达食堂的最小时间是多少 贴一篇题解:http://blog.csdn.net/u0137 ...
- OpenCV——旋转模糊
参考来源: 学习OpenCV:滤镜系列(5)--径向模糊:缩放&旋转 // define head function #ifndef PS_ALGORITHM_H_INCLUDED #defi ...
- 如何在asterisk中限制呼叫路数
在asterisk中,对于呼叫个数是可以通过call-limit进行限制的.限制办法是通过修改asterisk.conf中maxcalls参数,设置允许的最大呼叫数.这里的最大呼叫数是包括所有的呼 ...
- 【Lintcode】113.Remove Duplicates from Sorted List II
题目: Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct ...
- Html 5 版 电子时钟
效果图: html 5 canvas元素 Html 5的canvas元素可以用于在网页上绘制图形[即canvas的作用]. canvas画布使用JavaScript在网页上绘制图形 其拥有绘制各种路 ...