介绍

参加Kaggle比赛,我必须有哪些技能呢?

你有没有面对过这样的问题?最少在我大二的时候,我有过。过去我仅仅想象Kaggle比赛的困难度,我就感觉害怕。这种恐惧跟我怕水的感觉相似。怕水,让我无法参加一些游泳课程。然而,后来,我得到的教训是只要你不真的跨进水里,你就不知道水有多深。相同的哲学对Kaggle也一样适用。没有试过之前不要下结论。

Kaggle,数据科学的家园,为竞赛参与者,客户解决方案和招聘求职提供了一个全球性的平台。这是Kaggle的特殊吸引力,它提供的竞赛不仅让你站到不同的高度思考问题,还提供了可观的奖金。

然而,人们总是犹豫到底要不要参加竞赛。其中有以下几个原因:

1.他们小看了自己的技能,知识和掌握的技术的水平。

2.不管自己一连串技能的水平如何,他们都选择奖金最高的问题。

3.在问题的困难度水平上,他们没有充分发挥出自己的技能水平。

我估计,这个问题可能要归咎于Kaggle自身。Kaggle.com没有提供任何信息来帮助人们选择哪些是对于他们自身技能水平而言是最适合的比赛。结果就是对于新手或者中间水平的人来说,选择一个适合自己的问题来开始成为一个艰苦的工作。

你能从这篇文章中学到什么?

本文中,我们会解开根据自身技能,工具和技术组合来选择合适的Kaggle问题的死锁状态。这里我们会详细说明每个kaggle问题的困难度,以及要解决这些问题需要的技能水平。

在后面的部分,我们针对下面的一些情况,定义了正确的方法来选择kaggle问题:

Case 1:我有编程背景,但是是机器学习的初学者。

Case 2:我在数据分析行业以及有两年以上经营,但是不擅长R或者python。

Case 3:我擅长编码和机器学习,需要找一下有挑战的工作。

Case 4:我对于机器学习和编程语言都是新手,但是我想学。

目录

Kaggle问题列表

1.泰坦尼克:机器从灾难中学习

2.Julia初步

3.数字识别

4.当词袋遇上爆米花袋

5.脏文件去噪声

6.旧金山犯罪分类

7.出租车轨迹预测:时间/地点

8.Facebook招聘——人还是机器人


1.泰坦尼克:机器从灾难中学习

目标:一个开始你的机器学习之旅的经典流行问题。给你一套在船上的乘客属性,让你来预测在船沉没后谁会生存下来。

困难度:

◆ 机器学习技巧:容易

◆ 编程技巧:容易

◆ 专业知识要求:容易

◆ 可用教程:完善

2.Julia初步

目标:这是一个用即将推出的工具Julia来识别谷歌街景图片中的人物的问题。

困难度:

◆ 机器学习技能:容易

◆ 编程技能:中

◆ 专业知识要求:容易

◆ 可用教程:完善

3.数字识别

目标:给你的是一个手写数字的像素数据(图片),你需要判断这是哪个数字。这是隐马尔可夫模型的经典问题。

各种属性的困难度:

◆ 机器学习技能:中

◆ 编程技能:中

◆ 专业知识需求:容易

◆ 可用教程:有但不是手把手教学

4.当词袋遇上爆米花袋

目标:给你一组影评,你需要在这些叙述中找出其中潜在的情感(情感分析问题)。这个问题的目标是向你介绍谷歌软件包——Word2Vec。

这是一个令人惊异的软件包,能帮助你将单词转换到有限维空间。用这种方法我们可以仅关注向量就能在词与词之间建立相似性。一个非常简单的例子就是你的算法可以找出相似性如:King – Male + Female结果是Queen。

困难度:

◆ 机器学习技能:难

◆ 编程技能:中

◆ 专业知识要求:容易

◆ 可用教程:有但是不是手把手教学

5.脏文件去噪声

目标:你可能知道一种技术叫OCR。这种技术简而言之就是将手写文档转换成电子文档。然而,这个技术并不完美。这里你的工作就是用机器学习方法让它的结果完美起来。

困难度:

◆ 机器学习技能:难

◆ 编程技能:难

◆ 专业知识要求:难

◆ 可用教程:无

6.旧金山犯罪分类

目标:预测发生在湾区的犯罪的分类类型。

困难度:

◆ 机器学习技能:极难

◆ 编程技能:极难

◆ 专业知识要求:难

◆ 可用教程:无

7.出租车轨迹预测:时间/地点

目标:在同一个数据集上有两个问题。给你一个出租车的控制器,让你来预测出租车将要去哪或者完成一个旅程出租车要花费多少时间。

困难度:

◆ 机器学习技能:容易

◆ 编程技能:难

◆ 专业知识要求:中

◆ 可用教程:有一些可作为比较标准的代码(benchmark code)。

8.Facebook招聘——人还是机器人

目标:如果你有意愿要了解一个新的领域,你必须解决这个问题。给你一些投标数据,期望你能区分投标人到底是人还是机器人。这是当时Kaggle比赛中可以获得数据最丰富的一个数据集。

困难度:

◆ 机器学习技能:中

◆ 编程技能:中

◆ 专业知识要求:中

◆ 可用教程:因为是一个招聘竞赛,没有任何可资利用的支持。

注意:上述说明中没有涵盖提供了奖金的Kaggle竞赛,因为那些竞赛都跟某个领域密切相关。

我们来看看不同的人,拥有不同技术组合,处在人生的不同阶段如何正确选择一个适合自己的方式来开始Kaggle之旅。

Case 1:我有编程背景,但是是机器学习的初学者。

  1. ◆ 第一步:你应该参与第一个Kaggle题目是⑦出租车轨迹预测。原因是,这个问题有一个复杂的数据集,包括JSON格式,其中一列揭示出租车已经访问过的一系列坐标。如果你能解析这个信息,那么在目标目的地或时间上获得一些初步估计就不需要用到机器学习。这样,你可以凭借你的编程能力在工业界找到实现自己价值的机会。
  2. ◆ 第二步:你下一步应该做的是:①泰坦尼克。原因是,你现在应该已经明白如何操作一个复杂数据集。这样,现在正是搞一搞纯粹的机器学习的好时机了。有很丰富的解决方案和脚本可以利用,你应该能创建一个很好的解决方案。
  3. ◆ 第三步:你现在应该尝试大一点的东西了。试试Facebook招聘。这会帮助你意识到理解某个领域的知识如何在机器学习上帮助你得到最好的结果。

一旦你完成了上述所有的尝试,你尝试Kaggle上任何一个问题都没有问题可。

Case 2:我在数据分析行业以及有两年以上经营,但是不擅长R或者python。

  1. ◆ 第一步:你的第一个尝试应该是①泰塔尼克。原因是,你已经了解如何创建预测算法。你现在应该努力学习像R和Python这样的编程语言。有很丰富的解决方案和脚本可以利用的条件下,你应该能用R和Python完成不同的模型。这个问题也可以帮你了解一点更高级的机器学习算法。
  2. ◆ 第二步:下一步是Facebook招聘。原因是,给你简单的数据结构和丰富的数据内容,你将可以结合正确的表,在这个问题上给出预测算法。这会帮助你意识到理解某个领域的知识如何在机器学习上帮助你得到最好的结果。

建议:你现在要准备好离开你待得非常舒服的领域,尝试完全不同的东西。阅读一些问题,比如糖尿病视网膜病变检测,Avinto上下文广告点击,犯罪分类并找到你感兴趣的领域。现在尝试将你学到的任何知识都应用一下。

现在是时候尝试一下对更复杂的东西编程了。试一下出租车轨迹预测问题或者脏文件去噪声问题。一旦你各项准备都齐全了,你可以尝试Kaggle上的任何问题。

Case 3:我擅长编码和机器学习,需要找一下有挑战的工作。

  1. ◆ 第一步:你在Kaggle上有很多选择。首选是掌握一种新语言比如Julia。你可以开始迈出Julia的第一步。原因是,这将在Python和R之外显示Julia的强大之处。
  2. ◆ 第二步:第二个现在就是发展另一个领域的技能。你可以尝试Avito竞赛、搜索相关或者Facebook——人vs机器人

Case 4:我对于机器学习和编程语言都是新手,但是我想学。

  1. ◆ 第一步:你应该用①泰塔尼克来作为你Kaggle之旅的开始。原因是,你的第一步应该是学习编程语言如R和Python。有很多可资利用的解决方案和脚本的情况下,你应该能用R和Python建立不同的模型。这个问题也帮助你了解一些机器学习算法。
  2. ◆ 第二步:然后你应该着手的是:Facebook招聘。原因是,给你简单的数据结构和丰富的数据内容,你将可以结合正确的表,在这个问题上给出预测算法。这会帮助你意识到理解某个领域的知识如何在机器学习上帮助你得到最好的结果。

一旦你完成了这些,你应该在Kaggle选择任何一个你感兴趣的问题了。

Kaggle上公平竞争中的一些骇客方法

这不是一个骇客方法的完全列表,只不过想要给你一个好的起点。完全的列表值得另开一个帖子来说明。

  • 1.确认你在最后期限之前提交了一个解决方案(即使最简单的提交也算完成任务),如果你未来还希望继续参加这个竞赛的话。
  • 2.在你处理数据之前,了解该领域的专业知识。例如,在机器人vs人的比赛中,开始你的数据之旅前,你需要了解在线竞标平台的知识。
  • 3.自己做一个模拟Kaggle竞赛评分标准的评估算法。一个简单的10折交叉验证通常就可以很好的工作。
  • 4.从训练数据中切割出尽可能多的特征——特征工程通常能将你的成绩从40%的位置推升到前10%。
  • 5.单纯一个模型通常不能把你推升到前10.你需要做很多很多模型,然后将他们集成起来。可以是许多不同模型的集成,也可以是同一算法的不同变量集。

结束语

在参加Kaggle比赛后,我意识到很多好处。我已经习惯了R和python。我相信这是学习编程语言方面最好的方式。另外,在论坛中给人们交互会帮助你加深对机器学习和领域知识的理解。

在本文中,我们介绍了各种Kaggle问题,将他们的基本属性按照难度水平做了区分。我们也列举了真实生活中的各种情形,阐述了参加Kaggle比赛的各种方法。

你怎么参加Kaggle比赛呢?你能否看到参加的各种巨大益处呢?有什么想法,欢迎在之后评论。

作者:

TAVISH SRIVASTAVA

链接:

https://www.analyticsvidhya.com/blog/2015/06/start-journey-kaggle/

Kaggle比赛----入门指导相关推荐

  1. 关于做Kaggle比赛入门,看完这篇就够了

    PART 0 : Kaggle 介绍 Kaggle的数据挖掘比赛近年来很火,以至于中国兴起了很多很多类似的比赛 Kaggle 是一个数据科学竞赛的平台,很多公司会发布一些接近真实业务的问题,吸引爱好数 ...

  2. Kaggle 首战拿银总结 | 入门指导 (长文、干货)

    我的比赛代码已经放到github --> Kaggle-Rental-Listing-Inquireies 在这篇博客开始之前,我必须感谢导师给我提供服务器资源,@Fenix Lin学长从他自身 ...

  3. 第四期 | 带学斯坦福CS224n自然语言处理课+带打全球Kaggle比赛(文末重金招募老师!)...

    在未来五年,你认为人工智能领域最具有商业价值的方向是什么? 上个月我和一个算法工程师朋友聊了聊,询问算法岗的行业薪资,他说现在计算机视觉算法岗工程师年薪大约50万左右,正当我感叹如今计算机视觉的火爆时 ...

  4. 【推荐系统】特征工程技巧(kaggle比赛技巧、tx的做法)

    内容总结 前面6点均是常见的特征工程基础知识,第7点时kaggle比赛中常用特征交叉.特征筛选等技巧,第8点从特征提取(数值型.类别型.embedding特征).特征选择(过滤式.封装式.嵌入式).特 ...

  5. 通俗理解kaggle比赛大杀器xgboost

    通俗理解kaggle比赛大杀器xgboost 说明:若出现部分图片无法正常显示而影响阅读,请以此处的文章为准:xgboost 题库版. 时间:二零一九年三月二十五日. 0 前言 xgboost一直在竞 ...

  6. Kaggle新手入门

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/colouroo/article/details/53730011 </div><l ...

  7. Titanic 泰坦尼克号预测-Tensorflow 方法-【Kaggle 比赛】

    本文介绍Kaggle入门比赛Titanic泰坦尼克号幸存预测的解题思路,使用的是神经网络和Tensorflow框架.提交代码附在本文的最后部分. 基本思路为: 导入数据集 对数据预处理 训练 预测并输 ...

  8. Kaggle比赛心得

    正文共5453个字,5张图,预计阅读时间14分钟. 最近参加了两场Kaggle比赛,收获颇多,一直想写篇文章总结一下.接触Kaggle到现在不到一年,比赛成绩一个银牌(5%)一个铜牌(9%),勉强算入 ...

  9. 沐神《动手学深度实战Kaggle比赛:狗的品种识别(ImageNet Dogs)

    沐神<动手学深度学习>飞桨版课程公开啦! hello各位飞桨的开发者,大家好!李沐老师的<动手学深度学习>飞桨版课程已经公开啦.本课程由PPSIG和飞桨工程师共同建设,将原书中 ...

最新文章

  1. 三、6Gbps SAS冲锋队——Cheetah 15K.7、NS.2
  2. Spring Boot - 自动配置实例解读
  3. docker配置data-root:设置镜像存储路径 镜像加速地址 私有仓库
  4. 2019黑龙江大学程序设计竞赛
  5. 16岁高中生的「卷」,用13000+行代码,从头写了一个C++机器学习库
  6. Kafka 集群数据备份 MirrorMaker 详解
  7. 协程-greenlet版(python 版)
  8. jquery学习之1.10-小练习-选中下拉框内容并显示
  9. 程序清单4.1_talkback.c程序_《C Primer Plus》P60
  10. 使用pyLDAvis可视化LDA结果,与解决FileNotFoundError: [Errno 2] No such file or directory: ‘https://cdn.jsdel....
  11. git21天打卡day18-新建远程仓库
  12. 两台设备(手动)设置相同的局域网IP地址会怎么样?
  13. Fiddler简单使用手册
  14. 锦城学院计算机系考研,考研心得分享
  15. kali下载gnuplot步骤
  16. 采样开关的作用计算机控制,计算机控制系统复习要点
  17. html中数字效果,使用css实现电子数字效果
  18. Java的语言基础(一)
  19. 【数据结构和算法】2谈谈算法
  20. 团队协助 开源项目_几款研发团队协作工具对比

热门文章

  1. uniapp 分享缩略图过大怎么办_新版本微信下,如何设置分享到朋友圈的缩略图?...
  2. 基于飞凌RK3588核心板的无人机主控方案
  3. Hive中的几种排序方式
  4. 如何用计算机直接做工资表,在电脑上excel做工资表怎么划线
  5. 以豌豆荚为例,用 Scrapy 爬取分类多级页面
  6. FTP文件传输协议(英文:File Transfer Protocol,缩写:FTP)
  7. 6-3 按要求编写一个类Car,练习类的定义。 (30分)
  8. 253. 会议室 II
  9. mysql怎么添加查询时间限制_mysql如何限制sql查询时间,
  10. Tcl脚本入门笔记详解(一)