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

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

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

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

蜘蛛卡包含两套标准卡

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

基本知识

从本文的角度出发,我们这里假设玩家在玩蜘蛛纸牌的时候不使用“撤销”“重来”“加步”(把游戏削减为一个简陋的初始版本),这样玩家就不用考虑计分、花费的时间以及移动的步数了。很多人都认为在这样的条件下游戏几乎赢不了,但是加州州立大学长滩分校的史蒂夫·布朗在他出色的著作《蜘蛛纸牌获胜策略》中给出了一些详细的策略,并且提到在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,我们就有理由相信这款蜘蛛牌程序是有偏向性的。

测试数据

对于每一场比赛,我们都想记录一组反映牌运的数据。 价值越高,获胜的机会越大。 我们想到的一种选择是在一个绝对公平和无偏的游戏中评估这些测试数据的值,然后将它们与在我们怀疑可能存在偏见的游戏中记录的数据进行比较。

一旦最初的十张牌都确定下来,我们就能计算出“保证轮数(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同样与玩家无关,我们假定玩游戏的玩家会按照一个随机顺序把所有扣着的牌都亮出来(尽管玩家可以选择先亮哪张牌,但是亮出的每张牌概率是一样的)。幸运的是这一点可以通过模拟很容易就做到。

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

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

上面显示了一个典型的散点图,其中蓝色圆圈和红色叉子依次表示胜 莱斯和失败。

仿真结果表明,对于无偏的游戏程序,经过大量的游戏后,AGT应等于3.96,ATSV应等于-32.29。 GT=1,TSVGT=-42在下面的例子的开始位置,因为游戏还没有结束,我们不知道AGT和ATSV的价值是多少。

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

样品,起始位置GT=1,TSVGT=-42

计算如下:

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

假设检验

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

首先选取一个较大的数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%的胜率,而且没有证据显示我在使用这些程序的过程中胜率有所提高(也就是说,我的胜率并不随着时间增加而呈现出正相关)。

一个有趣的免费在线纸牌游戏网站皮普金的白痴的愉快纸牌服务器,其中包含了许多纸牌游戏。 它允许玩家指定从1到999999的数字中的“种子号”。 例如,如果种子的数量是142857,最初的10张卡片总是2J56J9JQ59,但组合将是不同的。 注意,如果玩家在游戏前随机产生一长串种子,程序不能根据玩家的获胜率调整难度水平。 正是由于这个原因,你可以选择这个网站来估计中奖率。

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

当零假设为真时拒绝零假设称为第一类错误,其概率等于显著性水平。 假设检验中的另一种错误称为第二种错误,它是指在零假设为假时接受零假设。

我玩了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局的胜局数是有一点让人沮丧,但是确实,这次这个程序经受住了考验。然而其他的蜘蛛纸牌程序可能就没这么幸运了。

作者:陶德文

翻译:丹尼斯

审校:诺

原链接:

https://plus.maths.org/content/spider-solitaire

tian

福福

tian

莱斯

xiang

shang

今天我们将送出由机械工业出版社提供的优质科普书籍《天才与算法》

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

美英院士马库斯·杜索托伊的巅峰作品。 当我们进入一个由算法主导的世界时,人工智能将在绘画、音乐、写作等方面挑战人类。 作者用数学帮助我们理解算法和创造力的本质,帮助人类创造一个人与机器共存的美好未来。

读这本书,你会惊叹于思维的美,知识的广度,也会惊叹于人类创造力有如此严密的逻辑和音符般的节奏。

【互动问题:你在生活中还运用过哪些具体的统计学知识?

请大家严格按照 互动:问题答案的格式在评论区留言参与互动,格式不符合要求者无效。

*活动仅限于“我们聊天”平台

编辑:aki

↓单击标题查看↓

1.套? 看看这个岛,中岛,中湖,中岛

2.都是依靠天才科学家20岁时的论文,所以你可以用你的手机拍照和发送朋友

3.射向天空,子弹落下来杀人了吗? |没有。 206

4. 乐高还能悬浮在半空中吗? 千万人都懵了!

5.古装片的射箭给物理学家笑,导演我们能专业吗?

6.不能窒息,即使它被淹没了。 这是什么神奇的液体?

7.数学课上捡了一块橡皮,勾股定理听不懂

8.物理给你

9.唯一两次获得诺贝尔奖的人,你不一定认识他

妈妈问我为什么我的桌子这么乱!