Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >一篇AI打麻将的论文,理科生眼中的麻将是这样的

一篇AI打麻将的论文,理科生眼中的麻将是这样的

作者头像
IT派
发布于 2019-06-10 06:29:05
发布于 2019-06-10 06:29:05
9220
举报
文章被收录于专栏:IT派IT派

额……报道了下围棋、打德州扑克的 AI 程序之后,小编终于看到了 AI 打麻将的一篇研究,两位作者分别来自悉尼科技大学和陕西师范大学。不过,自信麻将技术不错的小编翻译地一脸懵逼。本文强行为大家介绍了这篇 AI 麻将论文,感兴趣的同学可以查看原英文文章。

从 AI 研究的早期阶段,游戏就开始充当许多 AI 技术和想法的试验台,从跳棋、国际象棋、围棋、扑克到星际争霸 II。在过去的几十年里,AI 程序已经在跳棋、国际象棋、围棋等完整信息游戏中接连打败最优秀的人类棋手。在这些游戏中,玩家在做出决策之前可以知道所有信息。相比较而言,非完整信息游戏更加具有挑战性。最近,AI 在两人对决有限制和无限制德州扑克游戏中都取得了重要进展,这是人类在竞争中玩的最小的扑克变体。在本文中,研究者对更流行、更复杂的麻将游戏展开了数学和 AI 研究。

麻将是一种风靡全世界的多人对抗游戏。一套麻将有 144 张牌,牌面上有汉字或符号(见图 1),其出牌规则、得分灵活多变。开始的时候,每个玩家都有 13 张牌。接下来,他们会摸牌、出牌,直到攒够 14 张可以胡的牌型。

在这篇论文中,研究者对麻将进行数学和 AI 方面的研究,尝试回答两个最基本的问题:当前 14 张牌的牌面到底有多好;我们该打出哪一张牌?作者定义了缺牌数的概念,并提出最优策略来确定当前该打的牌,以在 k 次牌面变换(k ≥ 1)的条件下增加胡牌的概率。

在此论文中,为了简化问题,我们只考虑麻将最基础的打法 Mahjong-0。其他的打法可以用类推的方式处理。在 Mahjong-0 打法中,只有三类牌:

  • 条:从 B1 至 B9 表示一条到九条,每类 4 张;
  • 万:从 C1 至 C9 表示一万到九万,每类 4 张;
  • 筒:从 D1 至 D9 表示一筒到九筒,每类 4 张。

此论文把牌面称为条(B)、万(C)、筒(D),把整副麻将记为 M_0,总共 108 张。

麻将规则

定义 1:将牌(eye)指一对同样的牌,碰(杠)指三张或者四张同样的牌。吃(chow)指同类牌组成连续的三张牌。杠子、刻子或者顺子都称之为组(meld)。

在此论文中,作者也给出了一些非标准概念。

定义 2:待吃(pseudochow,缩写为 pchow)是指一对同花色的牌,吃了一张牌之后能够成为一组顺子。待组(pseudomeld,缩写为 pmeld)是指一个待吃或者对。牌 c 能够和 ab 组成一组,就是一摊(abc)。类似的,一张牌 t 加上另一张 t 就是一将。

例如,B3B4B5 就是吃,C1C1 是将,B7B7B7 是碰,D9D9D9D9 是杠,B1B3 和 C2C3 都可以吃。

论文的第二部分介绍了很多形式化的麻将规则,包括什么是清一色,怎么样才算完整的牌面(胡牌)等等。例如定义 4 展示了 14 张牌的标准形式,其中作者将条(B)、万(C)、筒(D)表示为 0、1、2,因此 (0, 3) 就表示 B3:三条。

定义牌面的组合后,我们需要一种度量方法以确定到底当前 14 张牌离胡牌还有多远,这里作者引入了缺牌数(deficiency)。简单而言,缺牌数表示的就是当前牌面到胡牌还差多少张牌。

理科生怎样看待牌面?

如果我们定义了随机 14 张牌的牌面表示和缺牌数,现在只需要知道怎样评估当前牌面的好坏,并通过打牌来把缺牌数降低到 0 就行了。首先对于清一色的 14 张牌,它的缺牌数少于等于 3 张,论文的第三章主要就在讨论和证明这一点。

如下对于清一色的牌,只有在以下情况才会令缺牌数为 3:

对于常规牌,最大的缺牌数为 6,论文的第四章主要就在讨论和证明这一点。

现在根据缺牌数的定义与证明,我们就能度量当前牌面的好坏。我们首先需要定义根据缺牌完善后的完整牌面,然后计算缺牌和胡牌之间的成本。

这里我们可以举个栗子,如果我们摸上来的 14 张牌为:T = (B1B1B2B2B2B2B3B3)(C1C2C8)(D2D2D8),其中 C2 表示二万。那么现在 p-decompositions 可以表示为:

π_0 中的 (B1 B3) 并不能组成顺,因为π_0 中已经有 4 张 B2 了。π_1 和 π_2 都是饱和与可被组合完全的,例如π_1 缺少的牌为:

它的成本 cost (π_1) = 4。确定最优成本后我们就需要寻找最优策略,并尽可能在最小的轮数下将成本或缺牌数降低为 0。当然,如果需要对打牌的过程建模,并找到最优策略,我们还需要更多的研究。

结语与讨论

在此论文中,作者开启了对麻将的数学和 AI 研究。在设计玩麻将的计算机程序时,本文先描述了缺牌数的定义,知识库的概念和步骤 k 值扮演者重要角色。

尽管麻将是个非常流行的棋牌游戏,但少有专门研究麻将的数学或者 AI 论文。据我们所知,Yuan Cheng 等人的论文 [4] 是首个使用数学技术(主要是基本组合理论)严肃研究麻将的论文。在那篇论文中,作者们研究了麻将中一组特殊的组合问题,也就是 k-gate 问题。

清一色的 13 张牌 T 可以称为 nine-gate,其中我们可以向 T 中添加任意同类牌而胡牌。对于 1 ≤ k ≤ 9,如果存在不同值的 K 张牌,且只能由这 k 张牌补全 T,那么 T 就可以称为 k-gate 问题。很容易看出,k-gate 问题能通过这篇论文构建的形式化表达进行描述。为了找到所有的 k-gate,我们只需要为每一个清一色的 13 张牌做决策,而不需要管是否正好有 k 张牌使得 T 加上 i 就能补全。

至少有三个可以扩展上述研究的方向。首先,我们可以在 M_0 中囊括更多牌,例如,东南西北这些风牌,红中、发财、白板这些箭牌,以及花牌。其次,我们可以增加或者减少 14 张手牌的规定,例如可以允许任意 7 对,或者要求至少两个花色。第三,不同的 14 张牌可以有不同的得分,例如,清一色比杂牌得分多。未来研究可以尝试解决这些问题。

论文:Let's Play Mahjong!

论文地址:https://arxiv.org/pdf/1903.03294.pdf

作者:Sanjiang Li、Xueqing Yan

来源:arXiv, 机器之心

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 IT派 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Linux 了解内存使用
目前大部分的操作系统和应用程序并不需要16EB( 2^64 )如此巨大的地址空间, 实现64位长的地址只会增加系统的复杂度和地址转换的成本, 带不来任何好处. 所以目前的x86-64架构CPU都遵循AMD的Canonical form, 即只有虚拟地址的最低48位才会在地址转换时被使用, 且任何虚拟地址的48位至63位必须与47位一致(sign extension). 也就是说, 总的虚拟地址空间为256TB( 2^48 )
黄规速
2022/04/14
3.7K0
Linux 了解内存使用
Linux服务器性能评估与优化(一)--CPU和负载
性能调优是找出系统瓶颈并消除这些瓶颈的过程。 很多系统管理员认为性能调优仅仅是调整一下内核的参数即可解决问题, 事实上情况并不是这样。 性能调优是实现操作系统的各个子系统之间的平衡性,这些子系统包括:
黄规速
2022/04/14
5.2K0
Linux服务器性能评估与优化(一)--CPU和负载
性能之内存篇
最近笔者在看性能分析相关的是知识,就特意针对内存整理了这一篇文章,在这里笔者主要从下面三个方面来介绍这方面的知识: 1.内存的作用是什么,他在操作系统中的基础知识都有哪一些? 2.查看内存和内存相关问题涉及到的工具都有哪一些,他们的使用方式是什么样子的? 3.碰到内存问题的时候,我们需要怎么去定位呢?
灰子学技术
2022/06/25
1.2K0
性能之内存篇
Linux服务器性能评估与优化(三)--磁盘i/o
之前文章《Linux服务器性能评估与优化(一)》太长,阅读不方便,因此拆分成系列博文:
黄规速
2022/04/14
3.6K0
Linux服务器性能评估与优化(三)--磁盘i/o
Linux性能调优之内存负载调优的一些笔记
「 原谅和忘记就意味着扔掉了我们获得的最贵经验 -------《人生的智慧》叔本华」
山河已无恙
2023/01/30
2.6K0
Linux性能调优之内存负载调优的一些笔记
Linux服务器那么多参数该如何监控,掌握这些Linux监控命令可以早点下班!
平时我们经常需要监控内存的使用状态,常用的命令有free、vmstat、top、dstat -m等。
网络技术联盟站
2023/03/01
6250
Linux服务器那么多参数该如何监控,掌握这些Linux监控命令可以早点下班!
ODOO12服务器性能评估与监控
load average这个输出值,这三个值的大小一般不能大于系统CPU的个数,例如,本输出中系统有4个CPU,如果load average的三个值长期大于4时,说明CPU很繁忙,负载很高,可能会影响系统性能,但是偶尔大于4时,倒不用担心,一般不会影响系统性能。相反,如果load average的输出值小于CPU的个数,则表示CPU还有空闲的时间片,比如本例中的输出,CPU是非常空闲的。
好派笔记
2021/09/13
1.1K0
3个性能监控和优化命令讲解
整理出了三个有关性能监控和优化命令详细讲解,文章很长,涉及top命令、free命令和vmstat命令,真的是很详细的讲解,希望能帮到大家
PHP开发工程师
2021/05/18
8140
3个性能监控和优化命令讲解
高性能BPF内存分析工具解析
作者简介:许庆伟,Linux Kernel Security Researcher & Performance Developer 众所周知,Linux内核和CPU处理器负责将虚拟内存映射到物理内存。为了提高效率,在一个称为页的内存组中创建一个内存映射,其中每个页的大小根据处理器的实际情况而来。尽管大多数处理器也支持更大的页,但默认通常是4 KB,。内核可以从页空闲列表中为物理内存页的申请提供分配,并且为了提高效率,为每个DRAM组和CPU均设计了维护这些请求的方案。内核程序可以通过分配器(比如slab分配
刘盼
2022/07/12
1.4K0
高性能BPF内存分析工具解析
腾讯一面:内存满了,会发生什么?
先来说说第一个问题:虚拟内存有什么作用?(如果你还不知道虚拟内存概念,可以看这篇:真棒!20 张图揭开内存管理的迷雾,瞬间豁然开朗)
小林coding
2022/10/27
1.3K0
腾讯一面:内存满了,会发生什么?
Linux性能及调优指南(翻译)之Linux内存架构
本文为IBM RedBook的Linux Performanceand Tuning Guidelines的1.2节的翻译 原文地址:http://www.redbooks.ibm.com/redpapers/pdfs/redp4285.pdf 原文作者:Eduardo Ciliendo, Takechika Kunimasa, Byron Braswell 1.2 Linux内存架构 为了执行一个进程,Linux内核为请求的进程分配一部分内存区域。该进程使用该内存区域作为其工作区并执行请求的工作。它与你的
小小科
2018/05/03
1.9K0
Linux性能及调优指南(翻译)之Linux内存架构
Linux内存占用常用的几个分析方法,你确定都知道?
系统内存是硬件系统中必不可少的部分,定时查看系统内存资源运行情况,可以帮助我们及时发现内存资源是否存在异常占用,确保业务的稳定运行。
lyb-geek
2022/11/18
3.9K0
Linux内存占用常用的几个分析方法,你确定都知道?
linux服务器内存
查询日志 显示 内存满了 把mysql服务给杀了 linux 服务器如果 内存满了 会自动清理进程 防止服务器挂掉 选择的话 谁占的的内存大 就先杀谁 我的服务器里面 mysql服务占的内存是最大的 所以就把mysql就给杀了
用户8639654
2021/08/03
33.9K0
linux系统性能监控与优化(3)–memory
虚拟内存以页的方式管理,一般为4K,如果配置了大页,则为2M The Page Frame Reclaim Algorithm.(PFRA) PFRA根据页的类型来释放内存。 1.页类型: 1)不能释放的页:加锁的页,内核页,保留的页 2)可交换的页:匿名内存页 3)同步的页:有对应磁盘文件的页 4)可废弃的页:static pages discarded pages 除了第一种页不能回收,其它都可以被PFRA回收。 2
小小科
2018/05/03
1.4K0
linux系统性能监控与优化(3)–memory
在 4G 内存的机器上,申请 8G 内存会怎么样?
这篇文章其实之前发过,但是最近有位读者跟我反馈,我文章中的实验在 64 位操作系统、2 G 物理内存的场景,申请 8G 内存是没问题的,而他也是这个环境,为什么他就无法申请成功呢?
捡田螺的小男孩
2023/02/23
2.3K0
在 4G 内存的机器上,申请 8G 内存会怎么样?
性能测试必备监控技能linux篇14
前言 如果性能测试的目标服务器是linux系统,在如何使用linux自带的命令来实现性能测试过程的监控分析呢? 对于日常性能测试来讲,在linux下或是类Unix系统,我们必须掌握以下常用的指标查看命令。 ps pstree top free vmstat iostat iotop sar 当然还有其他命令,这里就上述笔者常用的命令推荐大家掌握。 ps ps命令能给出当前系统中进程的快照。下面我们列举几个常用的选项,对于其他的请参考官方文档或是自行搜索相关文档。 使用 -a 参数。-a 代表 all。同时加
苦叶子
2018/04/04
1.4K0
性能测试必备监控技能linux篇14
用十条命令在一分钟内检查Linux服务器性能
注:本文主要参考InfoQ文章用十条命令在一分钟内检查Linux服务器性能,在此基础上对涉及的Linux命令进行整理而成。
九州暮云
2019/08/21
1.4K0
用十条命令在一分钟内检查Linux服务器性能
Linux 系统内存监控:Linux 内存调优之系统内存全面监控
所谓百年功名、千秋霸业、万古流芳,与一件事情相比,其实算不了什么。这件事情就是——用你喜欢的方式度过一生。 ----《明朝那些事儿》
山河已无恙
2025/04/13
2600
Linux 系统内存监控:Linux 内存调优之系统内存全面监控
嵌入式linux综合性能评估
干货福利,第一时间送达! 在嵌入式项目预研前期阶段,我们常常需要对某个平台进行资源和性能方面的评估,以下是最常见的一些评估指标:
杨源鑫
2023/02/16
9990
嵌入式linux综合性能评估
五分钟带你掌握Linux系统查看CPU使用率、内存使用率、磁盘使用率
%us:表示用户空间程序的cpu使用率(没有通过nice调度) %sy:表示系统空间的cpu使用率,主要是内核程序。 %ni:表示用户空间且通过nice调度过的程序的cpu使用率。 %id:空闲cpu %wa:cpu运行时在等待io的时间 %hi:cpu处理硬中断的数量 %si:cpu处理软中断的数量 %st:被虚拟机偷走的cpu 注:99.0 id,表示空闲CPU,即CPU未使用率,100%-99.0%=1%,即系统的cpu使用率为1%。
不吃小白菜
2021/03/02
19.5K0
推荐阅读
相关推荐
Linux 了解内存使用
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档