机器学习的最佳入门学习资源
文章里到底写什么、不写什么,这个问题真的让我很烦恼。我必须把自己当做一个程序员和一个的初学者,站在这个角度去考虑最合适的资源。
我找出了每个类型中最适合的资源。如果你是一个真正的初学者,并且乐意于开始了解领域的相关知识,我希望,你可以在我的文章中找到有用的资料。我的建议是,从中挑出一件来,一本书或者是一个库,反复阅读或者认真学习所有的相关教程。挑出一个并且坚持学习,直到你完全掌握,再重新选择一个,重复这个学习过程。现在就让我们开始吧!
Programming Libraries 编程库资源
我是一个“学习要敢于冒险和尝试”观念的倡导者。这是我学习编程的方式,我相信很多人也是这样学习程序设计的。先了解你的能力极限,然后去拓展你的能力。如果你了解如何编程,可以将编程经验很快借鉴到深入学习上。在你实现一个实际的产品系统之前,你必须遵循一些规则、学习相关数学知识。
找到一个库并且仔细阅读相关文档,根据教程,开始尝试实现一些东西。下面列出的是开源的库中最好的几种。我认为,并不是他们中的每一种都适合用在你的系统中,他们是你学习、探索和实验的好材料。
你可以从一个由你熟悉的语言编写的库开始学习,然后再去学习其他功能强大的库。如果你是一个优秀的程序员,你会知道怎样从一种语言,简单合理地迁移到另一种语言。语言的逻辑都是相同的,只是语法和API稍有不同。
- R Project for Statistical Computing这是一个开发环境,采用一种近似于的脚本语言。在这个库中,所有你想要的与统计相关的功能都通过R语言提供,包括一些复杂的图标。CRAN(你可以认为是机器学弟的第三方包)中的目录下的代码,是由统计技术方法和其他相关领域中的领军人物编写的。如果你想做实验,或是快速拓展知识,R语言都是必须学习的。但它可能不是你学习的第一站。
- WEKA这是一个数据挖掘工作平台,为用户提供数一系列据挖掘全过程的API、命令行和图形化用户接口。你可以准备数据、可视化、建立分类、进行回归分析、建立聚类模型,可以通过第三方插件执行其他算法。除了WEKA之外,Mahout是Hadoop中为提供的一个很好的框架,你可以自行学习。如果你是和学习的新手,那么坚持学习WEKA,并且全心全意地学习一个库。
- Scikit Learn:这是用Python编写的,基于NumPy和SciPy的库。如果你是一个Python或者Ruby语言程序员,这是适合你用的。这个库很用户接口友好,功能强大,并且配有详细的文档说明。如果你想试试别的库,你可以选择Orange。
- Octave:如果你很熟悉MatLab,或者你是寻求改变的NumPy程序员,你可以考虑 Octave。这是一个数值计算环境,与MatLab像是,借助Octave你可以很方便地解决线性和非线性问题,比如算法底层涉及的问题。如果你有工程背景,那么你可以由此入手。
- BigML:可能你并不想进行编程工作。你完全可以不通过代码,来使用 WEKA那样的工具。你通过使用BigMLS的服务来进行更加深入的工作。BigML通过Web页面,提供了的接口,你可以通过浏览器来建立模型。
挑选出一个平台,并且在你实际学习的时候使用它。不要纸上谈兵,要去实践!
Video Courses视频课程
很多人都是通过视频资源开始接触的。我在YouTube和VideoLectures上看了很多于相关的视频资源。这样做的问题是,你可能只是观看视频而并不实际去做。我的建议是,你在观看视频的时候,应该多记笔记,及时后来你会抛弃你的笔记。,我建议你将学到的东西付诸实践。
坦白讲,我没有看见特别合适初学者的视频资源。视频资源都需要你掌握一定的线性代数、概率论等知识。Andre Ng在斯坦福的讲解可能是最适合初学者的,下面是我推荐的一些视频资源。
- Stanford Machine Learning斯坦福的课程可以在Coursera上观看,这门课是由 Andre Ng讲解的。只要注册,你可以随时观看所有的课程视频,从Stanford CS229 course下载讲义和笔记。这门课包括了家庭作业和小测试,课程主要讲解了线性代数的知识,使用Octave库。
- Caltech Learning from Data加利福尼亚理工学院的数据分析课程你可以在edX上学习这门课程,课程是由Yaser Abu-Mostafa讲解的。所有的课程视频和资料都在加利福尼亚理工学院的网站上。与斯坦福的课程类似,你可以根据自己的情况安排学习进度,完成家庭作业和小论文。它与斯坦福的课程主题相似,关注更多的细节和数学知识。对于初学者来说,家庭作业可能稍有难度。
- Machine Learning Category on VideoLectures.Net网站中的目录这是个很容易令人眼花缭乱的资源库。你可以找出比较感兴趣的资源,并且深入学习。不要纠结于不适合你的视频,或者对于感兴趣的内容你可以做笔记。我自己会一直重复深入学习一些问题,发现新的话题进行学习。,在这个网站上你可以发现是这个领域的大师是什么样的。
- “Getting In Shape For The Sport Of Data Science” – 由Jeremy Hoard讲授这是与竞赛者的对话,他们是一些实践中的R语言用户。这是非常珍贵的资源,因为很少有人会讨论研究一个问题的完整过程和究竟怎样做。我曾经幻想过在网上找到一个TV秀,记录竞赛的全过程。这就是我开始学习的经历!
Overvie Papers综述论文
如果你并不习惯阅读科研论文,你会发现论文的语言非常晦涩难懂。一篇论文就像是一本教科书的片段,论文会介绍一个实验或者是领域中其他的前沿知识。,如果你准备从阅读论文开始学习的话,你还是可以找到一些很有意思的文章的。
- The Discipline of Machine Learning中的规则这是由Tom Mitchell编著的白皮书,其中定义了的规则。Mitchell在说服CMU总裁为一个百年内都存在的问题建立一个独立的部门时,也用到了这本书中的观点。
- A Fe Useful Things to Kno about Machine Learning这是一篇很好的论文,因为它以详细的算法为基础,又提出了一些很重要的问题,比如选择特征的一般化,模型简化等。
我只是列出了两篇重要的论文,因为阅读论文会让你陷入困境。
Beginner Machine Learning Books给初学者的书
关于的书有很多,几乎没有为初学者量身定做的。什么样的人才是初学者呢?最有可能的情况是,你从一个完全不同的领域比如计算机科学、程序设计或者是统计学,来到领域。那么,大部分的书籍要求你有一定的线性代数和概率论的基矗
,还有一些书通过讲解最少的算法来鼓励程序员学习,书中会介绍一些可以使用工具、编程函数库来让程序员尝试。其中最有代表性的书是《Programming Collective Intelligence》,《Machine Learning for Hackers》,《HackersandData Mining: Practical Machine Learning Tools and Techniques》(Python版, R版, 以及Java版)。如果感到迷惑的话,你可以选择其中一本开始学习。
- Programming Collective Intelligence: Building Smart Web 2.0 Applications这本书是为程序员写的。书中简略介绍相关理论,重点以程序为例,介绍eb中的实际问题和解决办法。你可以买来这本书,阅读,并且做一些练习。
- Machine Learning for Hackers (中文版:实用案例解析)我建议你在阅读了《Programming Collective Intelligence》一书之后,再阅读这本书。这本书中也提供了很多实践练习,涉及更多的数据分析,并且使用R语言。我个人很喜欢这本书!
- Machine Learning: An Algorithmic Perspective这本书是《Programming Collective Intelligence》的高级版本。它们目的相同(让程序员开始了解),这本书包括一些数学知识,参考样例和phython程序片段。如果你有兴趣的话,我建议你在看完《Programming Collective Intelligence》之后来阅读这本书。
- 数据挖掘实用工具与技术(英文版·第3版)我自己是从这本书开始了解的,那时是2000年这本书还是第一版。我那时是Java程序员,这本书和WEKA库为我的学习和实践提供了一个很好的环境。我通过这样的平台和一些插件,实现我的算法,并且真正开始实践和数据挖掘的过程。我强烈推荐这本书,和这样的学习过程。
- Machine Learning(中文版计算机科学丛书:)这是一本很老的书,包括了一些规则和很多参考资料。这是一本教科书,为每个算法提供了相关讲解。
有一些人认为那些经典的教科书很了不起。 我也赞同,那些书的确非常好。,我认为,对于初学者来说,这些书可能并不合适。
Further Reading 继续阅读
在写这篇文章时,我认真思考了相关问题,也参考了其他人推荐的资料,以确保我没有遗漏任何重要参考资料。为了确保文章的完整性,下面也列出了一些网上流行的,可以供初学者使用的材料。.
- A List of Data Science and Machine Learning Resources:这是一份仔细整理的列表。你可以花一些时间,点击链接,仔细阅读作者的建议。值得一读!
- What are some good resources for learning about machine learning Why这个问题的第一个答案令人吃惊。每次我阅读这篇文章的时候,都会做好笔记,并且插入新的书签。答案中对我最有启发的部分是课程列表,以及相应的课程笔记和问答网站。
- Overhelmed by Machine Learning: is there an ML101 book这是StackOverflo上的问题。并且提供了一系列推荐书籍。Jeff Moser提供的第一个答案是很有用的,其中有课程视频和讲座的链接。
你是不是以及读过或者用过上面的一些资源了呢?你怎么看这个问题?
我是不是如愿为那些对有兴趣的初学者提供了重要、有用的资源呢?请留下你的建议,让我们分享!
机器人培训
- 达芬奇机器人献爱心 将主刀公益手术
- 亚马逊将在英国招聘2000多人 重点开发Alexa和无人
- 美、德、英、日、中5国机器人发展全景大盘点
- 国产机器人窗口期 不可错失制造2025弯道超车机会
- 一个小时,这只机械狗“自学”会了走路!
- 三穗长吉镇:无人机飞防作业 稳粮增豆保丰收
- 依靠静电着陆的新型机器人
- 工业机器人推广应用座谈会
- 在苹果的智能机器人软件公司是一种怎样的体验
- 四大家族之KUKA工业机器人应用案例分析
- 万事俱备只欠东风?机器人产业的东风到底在哪
- 欧洲 6 轮送货机器人开始在美国大学推广
- 芜湖:考核第一!6项冠军!
- 人工智能有望打破医疗资源不均衡
- 立讯精密:已进军新能源汽车市场,目标成为全
- 90后用机器人炒菜周入10万,炒菜机器人真的有可