AI for the Dice game FARKLE

我希望有人能指引我正确的方向。我有一个名为Farkle的骰子游戏。作为两人游戏,它运行得很好。现在我想为单人游戏实现一个AI。基本的要求是,如果当前骰子得分达到或超过300分,就将骰子传回给人类玩家。另外,我还希望AI能够检测一些其他情况,比如所有骰子都已使用且可以重新掷所有6个骰子。

我对整个Java/Android世界很陌生,所以真的不知道从哪里开始或者去哪里寻找骰子AI的例子。我找到了一些关于扑克的例子,但我想它们比我需要的复杂得多,甚至我都无法理解。你们有什么建议吗?

顺便说一下……我愿意将游戏的源代码发送给任何愿意且能够帮助的人。

提前感谢!


回答:

说实话,我不知道有什么AI库可以帮助你。此外,我还得阅读Farkle的规则来理解这个概念以及如何将AI整合进去。所以我想到了两个你需要自己实现的选项:
1.使用神经网络。网络可以使用反向传播进行训练。你可以使用6个骰子的总和与300的差异作为误差。如果你多搜索一下,我相信你不会很难找到Java库或源代码示例。
2.使用遗传算法。实际上有一个很不错的库JGAP。染色体将是掷所有6个骰子的结果,适应度函数将是它们的得分。
当然,上面提到的两种方法都比较通用,可能不太准确。我担心你需要熟悉某些AI概念/算法。Farkle游戏并不像国际象棋那样流行,以至于有专门的AI包,所以我认为你需要自己实现一些东西(可能使用一些库)。希望这对你有帮助。

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注