登录 | 地图 欢迎访问【UZ导航】
当前位置:网站首页 > 推荐 > 游戏 > 正文

为了研究蜘蛛纸牌的规则,我玩了200局!

admin 2020-08-25 80 浏览 0 评论

认真阅读下面的文章,并思考文末互动提出的问题,严格按照 互动:你的答案格式在评论区留言,就有机会获得由机械工业出版社提供的优质科普书籍《天才与算法》一本。

单人蜘蛛接龙(以下简称为“蜘蛛纸牌”)是人们经常在电脑上在线或者离线玩的一款很受欢迎的游戏。由名字可以看出,这个游戏是只有一个玩家的。游戏中一共有两套标准扑克牌,玩家需要按顺序把扑克牌排列成完整的八组(两套牌,各四种花色),从而进一步把它们从台面上消除。牌可以从牌组中提取或者按照特定规则从一列移动到另一列。我们这里不再详细地讨论游戏规则,假设我们的读者已经了解游戏的规则了。要是你需要回忆一下,可以看这里。在这里我们只讨论这个游戏的四组的版本。

蜘蛛纸牌中含有两套标准扑克牌

玩家们一直在抱怨说不同的软件存在偏差。具体来讲,就是如果程序探测到了玩家的胜率很高,它可能就暗中操纵后面的牌的次序来降低胜率。玩家本身也有可能被偏向从而发挥出最好水平。不过,通过一些基本的统计学手段,我们有可能对这种“偏向的指控”进行证实或者驳斥。这一点也可以作为一个很好的练习,来看看一个人是如何使用在现实世界观察到的数据并配合统计学手段来判断一个假说(比如“蜘蛛纸牌程序是有偏向性的”)是真的还是假的。

基础知识

从本文的角度出发,我们这里假设玩家在玩蜘蛛纸牌的时候不使用“撤销”“重来”“加步”(把游戏削减为一个简陋的初始版本),这样玩家就不用考虑计分、花费的时间以及移动的步数了。很多人都认为在这样的条件下游戏几乎赢不了,但是加州州立大学长滩分校的史蒂夫·布朗在他出色的著作《蜘蛛纸牌获胜策略》中给出了一些详细的策略,并且提到在306局游戏中可以取得48.7%的胜率。同时他也指出自己的玩法还不是完美的,那些专业玩家可以做得更好,甚至达到超过60%的胜率。我利用了布朗的这些策略进行了实验,结果表明确实能够达到超过48.7%的胜率。

理想情况下,电脑端蜘蛛纸牌游戏能够模拟真实情况下且洗牌充分的纸牌游戏。如果在游戏的任何一个节点,有 N 张牌还没被看过,那么每张牌都有 1/N 的可能性作为下一张翻面的牌出现(为了叙述的方便,我们忽略了具有相同花色和大小的纸牌之间的等价性)。举个例子,在起始位置我们知道有 10 张牌被亮了出来。因为总共的 104 张牌里一共有 8 张 K,所以单张亮出来的牌是 K 的概率是 8/104=1/13,因此亮出来的牌是 K 的期望张数是 10×1/13=10/13。如果在玩了相当多局数的游戏之后,我们发现亮出来K的数目平均下来接近 11/13,我们就有理由相信这款蜘蛛牌程序是有偏向性的。

1.png

对于每一局游戏来说我们都希望记录一组能够反映牌运气好坏的数据,数值越高,证明获胜的几率越大。我们想到的一个方案是评估在一局绝对公平、无偏袒性的游戏里,这些测试数据的取值,再和我们怀疑可能存在偏向性的游戏中记录的数据值进行比较。

一旦最初的十张牌都确定下来,我们就能计算出“保证轮数(guaranteed turns,GT)”,即玩家在被迫更换至另一排之前能够确定亮出的牌的最少数目。无论何时,当新的一排的十张牌已经确定下来后,我们都可以做一个类似的计算,假装它是新的一局游戏的开始。这样一来我们就可以计算出GT的平均值(AGT)。如果几轮下来GT的值很小,那么玩家就要有麻烦了。要说明的是AGT和玩家本身无关,所以很容易通过进行很多次实验(即确定很多排)来模拟出AGT的概率分布。

经验来谈,如果卡牌的整体分布比较糟糕的时候,玩家同样会陷入麻烦。比如说有七张Q但是只有两张J没有打出来的时候,即使你有一列或者多列已经清空,仍然会有问题出现。因此在这里定义一个整体方差(total square variation,TSV),取值为相邻大小的牌的数目的负的平方之和。在刚才的例子里,七张 Q 和两张 J 在求和时会贡献出 -(7-2)2=-25 一项。这里取负值是为了确保 TSV 的增减性与获胜概率的增减性一致,就和AGT一样。每亮出一张新牌我们就计算一下TSV,这样我们可以算出来单局游戏的平均TSV(ATSV)。要提起注意的是ATSV同样与玩家无关,我们假定玩游戏的玩家会按照一个随机顺序把所有扣着的牌都亮出来(尽管玩家可以选择先亮哪张牌,但是亮出的每张牌概率是一样的)。幸运的是这一点可以通过模拟很容易就做到。

蜘蛛纸牌的典型散点图(○=获胜,×=落败)

一个典型的散点图如上图,这里蓝色圆圈和红色叉叉依次表示获胜和落败。

模拟结果显示对于没有偏袒的游戏程序而言,在大量局数的游戏之后,AGT应该等于3.96而ATSV应该等于-32.29。在下面这个示例的起始位置中,GT=1,TSV=-42,因为这局游戏还没结束,我们还不知道AGT和ATSV的值是多少。

假设检验

为了检验一个蜘蛛纸牌游戏是不是有偏向性,我们采用一种叫假设检验的手段。我们先制定一个零假设(意思就是我们怀疑的效应可能不存在),在我们这里是指“蜘蛛纸牌程序并不存在偏向性”,那互补的假设就是“蜘蛛纸牌程序故意使绊子使得玩家的胜率下降”。

首先选取一个较大的数N作为待检测的蜘蛛纸牌游戏的局数,然后每一局我们计算一次AGT和ATSV。接下来的总体思路是求出我们要比对的观察结果的概率(即P值),或者更极端一点说,零假设为真(即程序没有偏向性)的概率。如果概率低于某一个阈值(即显著性水平),一个没有偏向性的程序就不太可能产生我们在N局游戏中观察到的这种AGT和ATSV值,那我们就拒绝零假设并且得到“游戏有偏向性”的结论。

那我们如何计算得到 p 值,即观察到我们已经观察到的AGT和ATSV值(这证明游戏没有偏向性)的概率呢?在模拟中我们已经得到了在无偏向性的游戏中AGT和ATSV的期望值,依次是3.96和-32.9。更有意思的是,概率论会告诉我们,在无偏向性的游戏中AGT和ATSV的值是如何分布的,换句话说,它可以帮助我们计算出观察到某一特定AGT和ATSV值的概率。所谓的“学生 t 检验”可以把所有这些数值考虑进去并得出我们想要的p值。详细内容这里略过,有兴趣的可以参照概率与统计的相关内容。

从本文的角度出发我们选择 N=100 作为我们玩这个待检验的游戏程序的局数,得到了显著性水平值为 0.05。

胜率估计

除了AGT和ATSV之外,我们也想评估一下对于“无偏向性”的蜘蛛纸牌程序来讲,“真正的”获胜概率。一个明显的困难在于胜率是和玩家有关的,所以很难验证“一个玩家能赢50%的游戏”这种说法。另一个情况是我在不同的蜘蛛纸牌游戏程序中得到了从45%到60%的胜率,而且没有证据显示我在使用这些程序的过程中胜率有所提高(也就是说,我的胜率并不随着时间增加而呈现出正相关)。

一个比较有意思的免费在线纸牌游戏网站 Pipkin's Idiot's Delight Solitaire Server,这里面包含了许许多多的纸牌游戏。它允许玩家在从1到999999的数字中指定一个“种子数”。举例来说,如果种子数为142857,起始的10张牌就总是2J56J9JQ59这几张,但是组合方式会不同。要注意的是,要是玩家在游戏之前随机生成一长串种子数,那么程序就不能根据玩家的胜率来调整难度水平了。正是因为这个原因,可以选择这个网站来估计胜率。

在零假设为真的时候拒绝零假设被称为第一类错误,它出现的概率等于显著性水平。假说检验中的另一类错误被称为第二类错误,它是指在零假设为假的情况下接受零假设。

我在Idiot's Delight上玩了100局游戏,使用了从1到100的种子数。最终我赢了59局,输了41局。所以我估计我在玩“无偏向性”的蜘蛛纸牌游戏的时候胜率会在59%左右。

估计值

我在Free Spider Solitaire上玩了100局蜘蛛纸牌游戏。虽然选择了在这里玩游戏但是试验之后,这里的游戏体验真的很“糟糕”:尽管可以赢,但是就算高手玩家玩起来也会很困难。每一局游戏记录下游戏的输赢结果以及AGT和ATSV数据。我观察到AGT和ATSV的p值依次是 0.115 和 0.201。这意味着AGT和ATSV的数据都要低于预期(也就是说,玩家会吃亏),但是因为这两个数值都高于我们的0.05的阈值,它们在统计上都不显著:这可能是因为偶然变化导致了较低的值的出现

不幸的是我只赢了其中的46局,比预期少了13局。这说明可能还需要进一步测试验证。然而要知道每个玩家的胜率都不一样,我很有可能在这100局里还没有发挥出最佳状态。

从中我给出的结论是没有足够的证据证明Free Spider Solitaire上的程序是有偏向性的。46局的胜局数是有一点让人沮丧,但是确实,这次这个程序经受住了考验。然而其他的蜘蛛纸牌程序可能就没这么幸运了。

相关推荐

《博德之门3》抢先体验版宣布跳票一周 官方改名自嘲
《博德之门3》抢先体验版宣布跳票一周 官方改名自嘲

此前拉瑞安工作室曾宣布,《博德之门3》会在8月开启抢先体验,不过后来游戏跳票了。官方又宣布将于9月30日开启抢先体验,眼看就没几天了,玩家们终于等到头了。但昨晚...

12小时前 admin

B社证实:《上古卷轴6》和《星空》将用新引擎开发
B社证实:《上古卷轴6》和《星空》将用新引擎开发

关于贝塞斯达即将推出的两个项目《星空》和《上古卷轴6》,我们已经有一段时间没有听到任何新消息了。这两款游戏最初是在2018年E3上宣布的,但在过去的两年里,关于...

2天前 admin

「江南百景图」卸载?退游?是什么导致了这些的发生
「江南百景图」卸载?退游?是什么导致了这些的发生

从我第一次接触江南百景图至今,我的游戏时长为两个月,虽然不算长,但是我对江南百景图已经失去了最开始的热情。接下来,就详细说说我想要弃游的原因。一、开地费用应天府...

3天前 admin

《怪物猎人物语2 破灭之翼》2021年夏季登陆Switch
《怪物猎人物语2 破灭之翼》2021年夏季登陆Switch

Switch《怪物猎人物语2破灭之翼》发表,2021年夏季发售。这款RPG中玩家可成为与怪物结下牵绊、加以培育,并与之共存的“怪物骑士”,到访各式各样的地...

4天前 admin

Xbox云游戏服务支持超过150个游戏
Xbox云游戏服务支持超过150个游戏

XboxGamePassUltimate付费用户终于可以在安卓平板和手机上体验云游戏了。微软正在大肆宣传:云游戏服务即将面向XboxGamePass...

5天前 admin

Take-Two CEO聊次世代游戏涨价:现在游戏价格太便宜
Take-Two CEO聊次世代游戏涨价:现在游戏价格太便宜

但你涨的可是NBA2K的价啊……最近,各家主机厂商都开始整军备战,公布了包括新主机的游戏阵容和价格在内的大量信息。在我们昨天的一篇推送里,也聊了聊下世代3A游...

6天前 admin

《泰坦陨落2》游戏推荐——对于跑酷作战,玩家究竟是否买单?
《泰坦陨落2》游戏推荐——对于跑酷作战,玩家究竟是否买单?

说起跑酷,曾经专门收集了关于跑酷的历史和由来,跑酷作为年轻一派的专属运动,对于身体素质和反应能力都有着较高的要求。而且作为小众运动,看的人要比实际体验的人要多的...

7天前 admin

任天堂败诉 英国玩家为Joy-Con漂移要求退款成功
任天堂败诉 英国玩家为Joy-Con漂移要求退款成功

近日英国网友crownshots在Reddit发帖,分享了自己SwitchJoy-Con手柄漂移后,维权成功,获得任天堂赔款的经历。在大约一年半之...

1周前 (09-17) admin

梦幻西游手游:一记暴击打出5000伤害!这只花妖竟如此强悍?
梦幻西游手游:一记暴击打出5000伤害!这只花妖竟如此强悍?

你见过能打出5000伤害的花妖吗?在《梦幻西游》手游中,花妖在经过专属内丹的加强后,一跃成为了精锐组中的人气法宠,在战斗中凭借着自身超高的法术伤害属性面板,能够...

1周前 (09-16) admin

只要320元!任天堂发布复刻版掌机
只要320元!任天堂发布复刻版掌机

游戏老玩家们,还记得Game&Watch游戏机吗?01复刻版Game&Watch掌机来了日前,任天堂在日本发布复刻版Game&...

1周前 (09-15) admin

S10抽签9月15日进行:厂长、微笑、Mlxg担任抽签嘉宾
S10抽签9月15日进行:厂长、微笑、Mlxg担任抽签嘉宾

北京时间9月14日下午,英雄联盟赛事官方发布了关于2020英雄联盟全球总决赛抽签仪式的最新消息,抽签仪式将于9月15日20:00举行。按照往年惯例抽签嘉宾多为东...

1周前 (09-14) admin

取消回复欢迎 发表评论:

off