机器学习的框架偏向于Python的13个原因


Posted in Python onDecember 07, 2017

13个机器学习的框架偏向于Python的原因,供大家参考,具体内容如下

机器学习的框架偏向于Python的13个原因

前言

主要有以下原因:

1. Python是解释语言,程序写起来非常方便

写程序方便对做机器学习的人很重要。
因为经常需要对模型进行各种各样的修改,这在编译语言里很可能是牵一发而动全身的事情,Python里通常可以用很少的时间实现。

举例来说,在C等编译语言里写一个矩阵乘法,需要自己分配操作数(矩阵)的内存、分配结果的内存、手动对BLAS接口调用gemm、最后如果没用smart pointer还得手动回收内存空间。Python几乎就是import numpy; numpy.dot两句话的事。

当然现在很多面向C/C++库已经支持托管的内存管理了,这也让开发过程容易了很多,但解释语言仍然有天生的优势——不需要编译时间。这对机器学习这种需要大量prototyping和迭代的研究方向是非常有益工作效率的。

2. Python的开发生态成熟,有很多有用的库可以用

除了上面说到的NumPy,还有SciPy、NLTK、os(自带)等等不一而足。Python灵活的语法还使得包括文本操作、list/dict comprehension等非常实用的功能非常容易高效实现(编写和运行效率都高),配合lambda等使用更是方便。这也是Python良性生态背后的一大原因。相比而言,Lua虽然也是解释语言,甚至有LuaJIT这种神器加持,但其本身很难做到Python这样,一是因为有Python这个前辈占领着市场份额,另一个也因为它本身种种反常识的设计(比如全局变量)。不过借着Lua-Python bridge和Torch的东风,Lua似乎也在寄生兴起。

3. Python的效率很高。

解释语言的发展已经大大超过许多人的想象。很多比如list comprehension的语法糖都是贴近内核实现的。除了JIT[1]之外,还有Cython可以大幅增加运行效率。最后,得益于Python对C的接口,很多像gnumpy, theano这样高效、Python接口友好的库可以加速程序的运行,在强大团队的支撑下,这些库的效率可能比一个不熟练的程序员用C写一个月调优的效率还要高。

4.数据存储方便

有sql,hadoop,mangodb,redis,spark等

5.数据获取方便

有Scrapy,beautifulsoup,requests,paramiko等

6.数据运算方便

有pandas,Numpy,scipy等

7.输出结果方便

有matplotlib,VisPy等

8.和其他语言交互方便

有ctypes,rpy2,Cython,SWIG,PyQt,boost.python

9.加速方便

有pypy,Cython,PyCUDA

10.图形图像方便

有PyOpenGL,PyOpenCV,mayavi2

11.信号处理方便

PyWavelets,scipy.signal

12.云系统支持方便

github,sourceforge,EC2,BAT,HPC

13.python开源

python支持的平台多,包括windows,linux,unix,macos。而matlab太贵,只能调用其api,用python省钱,省钱就是赚钱。
python 和 c++ 做个比较。

c++ 的cpu效率是远远高于 python 的.不过 python 是一门胶水语言,它可以和任何语言结合,基于这个优点,很多数据处理的python 库底层都是 c++ 实现的,意思就是说:你用python写code,但效率是c++的。只有那些for 循环,还是用python的效率高。

近年来机器学习最要是深度学习,而深度学习使用cuda gpu加速远比cpu要快,而cuda 是c++写的。
所以现在TensorLayer、theano 等深度学习库都是 python 编程、底层c++。

相关书籍推荐:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
跟老齐学Python之有容乃大的list(4)
Sep 28 Python
在Linux上安装Python的Flask框架和创建第一个app实例的教程
Mar 30 Python
Python中模块与包有相同名字的处理方法
May 05 Python
Python基于pandas实现json格式转换成dataframe的方法
Jun 22 Python
详解Python做一个名片管理系统
Mar 14 Python
python实现飞机大战游戏
Oct 26 Python
Python自动化之数据驱动让你的脚本简洁10倍【推荐】
Jun 04 Python
python+requests接口压力测试500次,查看响应时间的实例
Apr 30 Python
Python爬虫爬取新闻资讯案例详解
Jul 14 Python
利用python对excel中一列的时间数据更改格式操作
Jul 14 Python
解决python便携版无法直接运行py文件的问题
Sep 01 Python
Django中的DateTimeField和DateField实现
Feb 24 Python
python编程线性回归代码示例
Dec 07 #Python
基于Django的ModelForm组件(详解)
Dec 07 #Python
利用python编写一个图片主色转换的脚本
Dec 07 #Python
python八大排序算法速度实例对比
Dec 06 #Python
Python语言实现将图片转化为html页面
Dec 06 #Python
Python实现比较扑克牌大小程序代码示例
Dec 06 #Python
Python3简单实例计算同花的概率代码
Dec 06 #Python
You might like
Yii PHP Framework实用入门教程(详细介绍)
2013/06/18 PHP
深入解析phpCB批量转换的代码示例
2013/06/27 PHP
php+xml编程之xpath的应用实例
2015/01/24 PHP
php文档工具PHP Documentor安装与使用方法
2016/01/25 PHP
解决PHP程序运行时:Fatal error: Maximum execution time of 30 seconds exceeded in的错误提示
2016/11/25 PHP
EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
2017/04/04 PHP
PHP微信H5支付开发实例
2018/07/25 PHP
Javascript 篱式条件判断
2008/08/22 Javascript
JQuery循环滚动图片代码
2011/12/08 Javascript
raphael.js绘制中国地图 地图绘制方法
2014/02/12 Javascript
JavaScript通过this变量快速找出用户选中radio按钮的方法
2015/03/23 Javascript
javaScript中的原型解析【推荐】
2016/05/05 Javascript
javascript弹出窗口中增加确定取消按钮
2016/06/24 Javascript
jQuery联动日历的实例解析
2016/12/02 Javascript
React为 Vue 引入容器组件和展示组件的教程详解
2018/05/03 Javascript
javascript标准库(js的标准内置对象)总结
2018/05/26 Javascript
vue.js基于v-for实现批量渲染 Json数组对象列表数据示例
2019/08/03 Javascript
js实现图片3D轮播效果
2019/09/21 Javascript
vue-cli3中配置alias和打包加hash值操作
2020/09/04 Javascript
python连接sql server乱码的解决方法
2013/01/28 Python
pyqt和pyside开发图形化界面
2014/01/22 Python
python使用正则搜索字符串或文件中的浮点数代码实例
2014/07/11 Python
python实现2048小游戏
2015/03/30 Python
使用Python从有道词典网页获取单词翻译
2016/07/03 Python
使用Python+Splinter自动刷新抢12306火车票
2018/01/03 Python
Python批量将图片灰度化的实现代码
2020/04/11 Python
python简单实现最大似然估计&scipy库的使用详解
2020/04/15 Python
Python面向对象多态实现原理及代码实例
2020/09/16 Python
戴森英国官网:Dyson英国
2019/05/07 全球购物
几道PHP的面试题
2012/05/19 面试题
飞利信loadrunner和软件测试笔试题
2012/09/22 面试题
毕业证丢失证明
2014/01/15 职场文书
农村文化建设标语
2014/10/07 职场文书
Nginx 根据URL带的参数转发的实现
2021/04/01 Servers
Spring mvc是如何实现与数据库的前后端的连接操作的?
2021/06/30 Java/Android
Redis实现订单过期删除的方法步骤
2022/06/05 Redis