楼主: ada89k
4934 61

用机器学习预测谁将夺得世界杯冠军?附完整代码   [推广有奖]

  • 3关注
  • 72粉丝

院士

99%

还不是VIP/贵宾

-

威望
2
论坛币
538792 个
通用积分
14.7458
学术水平
123 点
热心指数
149 点
信用等级
82 点
经验
46289 点
帖子
1667
精华
3
在线时间
2443 小时
注册时间
2017-2-7
最后登录
2024-4-22

楼主
ada89k 在职认证  发表于 2018-6-15 14:56:51 |只看作者 |坛友微信交流群|倒序 |AI写论文
相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

用机器学习预测谁将夺得世界杯冠军?附完整代码



2018 年 FIFA 世界杯即将拉开帷幕,全世界的球迷都热切地想要知道:谁将获得那梦寐以求的大力神杯?

如果你不仅是个足球迷,而且也是高科技人员的话,我猜你肯定知道机器学习和人工智能也是目前的流行词。

让我们结合两者来预测一下本届俄罗斯 FIFA 世界杯哪个国家将夺冠。

0_TS9yYkdL98sQKELf.jpg


免责声明:请不要以本文为依据投注或做财务决定。如果你非买不可的话,我也没法阻止你,只是如果你中了大奖的话,别忘了我哦:)

以下为译文:

足球比赛涉及的因素非常繁多,我无法将所有因素都融入机器学习模型中。本文只是一个黑客想用数据尝试一些很酷的东西。本文的目标是:

1.用机器学习来预测谁将赢得2018 FIFA世界杯的冠军;
2.预测整个比赛的小组赛结果;
3.模拟四分之一决赛、半决赛以及决赛。

这些目标代表了独一无二的现实世界里机器学习的预测问题,并将解决机器学习中的各种任务:数据集成、特征建模和结果预测。

数据
我采用了两个来自 Kaggle 的数据集,我们将使用自 1930 年第一届世界杯以来所有参赛队的历史赛事结果。

FIFA 排名是于 90 年代创建的,因此这里缺失很大一部分数据,所以我们使用历史比赛记录。点击以下链接获取所有数据:

https://www.kaggle.com/martj42/international-football-results-from-1872-to-2017/data

本文中主要使用的环境和工具有:jupyter notebook、numpy、pandas、seaborn、matplotlib 和 scikit-learn。

首先,我们要针对两个数据集做探索性分析,然后经过特征工程来选择与预测关联性最强的特征,还有数据处理,再选择一个机器学习模型,最后将模型配置到数据集上。

让我们开始动手吧!
首先,导入所需的代码库,并将数据集加载到数据框中:

0_bXKg0bN4YvtbtkI5.png


导入代码库:

0_nfowjaVzfZCEXgHl.png


下一步是加载数据集。通过调用 world_cup.head() 和 results.head() ,务必将两个数据集都加载到数据框中,如下所示:

0_lHRcFby7nyPulhYb.png


探索性分析

在分析了两组数据集后,所得的数据集包含了以往赛事的数据——这个新的(所得的)数据集对于分析和预测将来的赛事非常有帮助。

探索性分析和特征工程:需要建立与机器学习模型相关的特征,在任何数据科学的项目中,这部分工作都是最耗时的。

现在我们把目标差异和结果列添加到结果数据集:

0_SKjQScHRi7lc0N-v.png


检查一下新的结果数据框:

0_0yBBTt_WMkmN8Ekb.png


然后我们着手处理仅包含尼日利亚参加比赛的一组数据(这可以帮助我们集中找出哪些特征对一个国家有效,随后再扩展到参与世界杯的所有国家):

0_sBeSQbcTX1AZdZ8V.png


第一届世界杯于 1930 年举行。我们为年份创建一列,并选择所有 1930 年之后举行的比赛:

0_PoGK7Bz5y7aj_6Jv.png


现在我们可以用图形表示这些年来尼日利亚队最普遍的比赛结果:

0_YXjJOV4BUhmXdO5K.png


每个参加世界杯的国家的胜率是非常有帮助性的指标,我们可以用它来预测此次比赛最可能的结果。

比赛的举行地点无关紧要。

锁定参加世界杯的队伍

我们为所有参赛队伍创建一个数据框:

0_vqV9xha0SqSDbwKg.png


然后从该数据框中进一步筛选出从 1930 年起参加世界杯的队伍,并去掉重复的队伍:

0_SuU31_Shc-VTCmFJ.png


为年份创建一列,去掉 1930 年之前的比赛,并去掉不会影响到比赛结果的数据列,比如 date(日期)、home_score(主场得分)、away_score(客场得分)、tournament(锦标赛)、city(城市)、country(国家)、goal_difference(目标差异)和 match_year(比赛年份):

0_zhlGjYfWdaxdTZcU.png


0_Rdtd4w3tnlA5Rrfk.png


为了简化模型的处理,我们修改一下预测标签。

如果主场队伍获胜,那么 winning_team(获胜队伍)一列显示“2”,如果平局则显示“1”,如果是客场队伍获胜则显示“0”:

0_OVM3pce_lKsabcHF.png

0_4Lu1Nux9JEH91k9j.png


通过设置哑变量(dummy variables),我们将 home_team(主场队伍)和away _team(客场队伍)从分类变量转换成连续的输入。

这时可以使用 pandas 的get_dummies() 函数,它会将分类列替换成一位有效值(one-hot,由数字‘1’和‘0’组成),以便将它们加载到Scikit-learn 模型中。

接下来,我们将数据按照 70% 的训练数据集和 30% 的测试数据集分成 X 集和 Y集:

0_ZaDFapNjHkjg0C8_.png


这里我们将使用分类算法:逻辑回归。这个算法的工作原理是什么?该算法利用逻辑函数来预测概率,从而可以测量出分类因变量与一个或多个自变量之间的关系。具体来说就是累积的逻辑分布。

换句话说,逻辑回归可以针对一组可以影响到结果的既定数据集(统计值)尝试预测结果(赢或输)。

在实践中这种方法的工作原理是:使用上述的两套“数据集”和比赛的实际结果,一次输入一场比赛到算法中。然后模型就会学习输入的每条数据对比赛结果产生了积极的效果还是消极的效果,以及影响的程度。

经过充分的(好)数据的训练后,就可以得到能够预测未来结果的模型,而模型的好坏程度取决于输入的数据。

让我们看看最终的数据框:

0_KIZ0pM1ypFuvVuM3.png


看起来很不错。现在我们将这些数据传递到算法中:

0_u5ccKca0NacVjaza.png


我们的模型子训练数据集的正确率为 57%,在测试数据集上的正确率为 55%。虽然结果不是很好,但是我们先继续下一步。

接下来我们建立需要配置到模型的数据框。

首先我们加载 2018 年 4 月 FIFA 排名数据和小组赛分组状况的数据集。由于世界杯比赛中没有“主场”和“客场”,所以我们把 FIFA 排名靠前的队伍作为“喜爱”的比赛队伍,将他们放到“home_teams”(主场队伍)一列。然后我们根据每个队伍的排名将他们加入到新的预测数据集中。下一步是创建默认变量,并部署机器学习模型。

2018 年 4 月 FIFA 排名数据:

https://us.soccerway.com/teams/rankings/fifa/?ICID=TN_03_05_01

小组赛分组状况的数据集:

https://fixturedownload.com/results/fifa-world-cup-2018

比赛结果预测
到这里你可能在想我们究竟什么时候开始预测啊?看了这么多代码和唠叨,究竟什么时候才给我们看预测结果?别着急,我们马上就要开始了……

将模型部署到数据集中

首先,我们将模型部署到小组赛中:

0_r_ffRVtk31sKOjrY.png



以下是小组赛的结果:

QQ图片20180614162519.png

(看不清点击图片放大)



该模型的预测中出现了三场平局,并且获胜队伍会在葡萄牙和西班牙之间,且判定西班牙有更高的获胜概率。我使用该网站(https://ultra.zone/2018-FIFA-World-Cup-Group-Stage)模拟了小组赛。

以下是 16 强淘汰赛的模拟:

0_2s_umRuSM6QPivdb.png



QQ截图20180614162600.png



模型预测的四分之一决赛——葡萄牙vs法国,巴西vs英格兰,西班牙vs阿根廷,德国vs比利时。

下面是结果预测:

QQ截图20180614162614.png


半决赛的阵容是——葡萄牙vs巴西,德国vs阿根廷。

结果预测:

0_P2soHCGBJ_AwCd-P.png


最后的冠军比赛是——巴西vs德国。

结果预测:

0_zeLvgAE3KTSiMyhW.png


根据该模型,巴西将有可能获得本届世界杯的冠军。

进一步的研究和提高领域

为提高数据集的质量,可以利用 FIFA 的比赛数据评估每个球员的水平;

混淆矩阵可以帮助我们分析模型预测的哪场有误;

我们可以尝试将多个模型组合在一起,提高预测准确度。

写在最后
我们可以从很多方面的工作来提高该预测,接下来就让我们来看看真正的比赛结果是否如此啦。

点击此处获取完整的代码:

https://github.com/itsmuriuki/FIFA-2018-World-cup-predictions

最后的声明:我不是资深球迷,此预测没有任何保证。

点击阅读原文

---------------------------------------------------------------------------------------------------------------

CDA为大家推荐人工智能工程师就业班,课程以实战案例出发,从自然语言处理、图像识别、语音识别、专家系统等多种典型应用入手,使CDA人工智能工程师就业班课程更能符合就业要求、企业要求。


了解详情:http://www.cda.cn/kecheng/58.html
咨询电话:18510169390 赵老师

推广二维码.png



二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝


已有 1 人评分经验 收起 理由
cheetahfly + 100 精彩帖子

总评分: 经验 + 100   查看全部评分

沙发
虎虎856 在职认证  发表于 2018-6-15 14:57:13 |只看作者 |坛友微信交流群

回帖奖励 +4

谢谢分享

使用道具

藤椅
厄尔蒙加 在职认证  发表于 2018-6-15 14:58:25 |只看作者 |坛友微信交流群

回帖奖励 +4

哈哈~以前是动物现在是机器学习了

使用道具

板凳
欧伟万峰1324 在职认证  发表于 2018-6-15 14:58:57 |只看作者 |坛友微信交流群

回帖奖励 +4

谢谢分享,支持一下

使用道具

报纸
麦积山都 在职认证  发表于 2018-6-15 15:00:05 |只看作者 |坛友微信交流群

回帖奖励 +4

谢谢分享,厉害了

使用道具

地板
赫然量 在职认证  发表于 2018-6-15 15:02:39 |只看作者 |坛友微信交流群

回帖奖励 +4

会玩会玩,要不是最后一句话我还真信了

使用道具

7
reboo001 发表于 2018-6-15 15:38:05 |只看作者 |坛友微信交流群

回帖奖励 +4

留爪,等待验证

使用道具

8
dumeng201066 发表于 2018-6-15 15:54:28 |只看作者 |坛友微信交流群

回帖奖励 +4

谢谢分享,厉害了

使用道具

9
dumeng201066 发表于 2018-6-15 15:57:51 |只看作者 |坛友微信交流群
这个机器学习用的软件是那个软件呢

使用道具

回帖奖励 +4

还有说法国的

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加JingGuanBbs
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-25 14:27