Python机器学习工具:Scikit-Learn介绍与实践

简介:

Scikit-learn 简介

官方的解释很简单: Machine Learning in Python, 用python来玩机器学习。

什么是机器学习
机器学习关注的是:计算机程序如何随着经验积累自动提高性能。而最大的吸引力在于,不需要写任何与问题相关的特定代码,泛型算法就能告诉你一些关于数据的秘密。

Scikit-learn的优点
1、构建于现有的NumPy(基础n维数组包),SciPy(科学计算基础包), matplotlib(全面的2D/3D画图),IPython(加强的交互解释器),Sympy(Symbolic mathematics), Pandas(数据结构和分析)之上,做了易用性的封装。
2、简单且高效的数据挖掘、数据分析的工具。
3、对所有人开放,且在很多场景易于复用。
4、BSD证书下开源。

Scikit-learn的生态
Python
python是一门简单易学的语言,语法要素不多,对于只关心机器学习本身非软件开发的人员,python语言层面的东西基本是不需要关心的。

Jupyter
http://nbviewer.jupyter.org/ 提供了一种便利的方式去共享自己或是别人的计算成果,以一种之前单单共享代码不同的交互的方式。scikit-learn官网上面大量的例子也是以这种方式展示,使用者不仅看到了代码的使用方式,还看到了代码的结果,如果自己搭建了jupyter server的话,导入notebook还可以直接在浏览器中在其中上下文任意处修改,大大增加了学习效率。

Scikit-learn 的主要内容
Scikit-learn的算法地图

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

按照上图 scikit-learn提供的主要功能主要关注与数据建模,而非加载、操作、总结数据,这些任务可能NumPy、Pandas就已经足够了。为此scikit-learn 主要提供了以下功能:

1、测试数据集,sklearn.datasets模块提供了乳腺癌、kddcup 99、iris、加州房价等诸多开源的数据集
2、降维(Dimensionality Reduction):为了特征筛选、统计可视化来减少属性的数量。
3、特征提取(Feature extraction): 定义文件或者图片中的属性。
4、特征筛选(Feature selection): 为了建立监督学习模型而识别出有真实关系的属性。
5、按算法功能分类,分为监督学习:分类(classification)和回归(regression),以及非监督学习:聚类(clustering)。sklearn提供了很全面的算法实现,详细算法清单http://scikit-learn.org/stable/modules/classes.html
6、聚类(Clustring):使用KMeans之类的算法去给未标记的数据分类。
7、交叉验证(Cross Validation):去评估监督学习模型的性能。
8、参数调优(Parameter Tuning):去调整监督学习模型的参数以获得最大效果。
9、流型计算(Manifold Learning):去统计和描绘多维度的数据

常用算法的大致介绍

分类 Classification

1、适用范围:用作训练预测已经标记的数据集的类别. 监督学习的代表。
2、常用算法对比

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

3、文章测试了179种分类模型在UCI所有的121个数据上的性能,发现Random Forests 和 SVM 性能最好。

回归 Regression

1、适用范围:
回归是用于估计两种变量之间关系的统计过程,回归分析可以帮助我们理解当任意一个自变量变化,另一个自变量不变时,因变量变化的典型值。
最常见的是,回归分析能在给定自变量的条件下估计出因变量的条件期望。 (举个例子,在二维的坐标系中,根据已有的坐标点去推导x、y轴的函数关系,既一元n次方程。)

2、常用算法对比:

优点:直接、快速,知名度高
缺点:要求严格的假设,需要处理异常值

集成算法 Ensemble Algorithms

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

上图是单独用决策树来做回归任务去预测数据,但是反映了决策树虽然易于解释理解之外会有一些预测上的缺点,总结而言是趋向过拟合,可能或陷于局部最小值中、没有在线学习,所以下图引入了AdaBoost集成算法来增加预测的可靠性,由此引出了集成算法的优点:

1、集成方法是由多个较弱的模型集成模型组,其中的模型可以单独进行训练,并且它们的预测能以某种方式结合起来去做出一个总体预测。
2、当先最先进的预测几乎都使用了算法集成。它比使用单个模型预测出来的结果要精确的多。

但是如何找出可结合的弱模型、以及结合的方式又称为了繁重的维护工作。

聚类 Clustering

1、适用范围:
是在没有标记的情况下去分类数据,使数据变得有意义, 如果已知分类分类的个数,Kmeans算法会更容易得出效果。

2、常用算法对比:

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

该图中颜色是聚类的结果,而非标记, 各算法的分类结果都可以根据输入参数调优,只是为了展示聚类的适用范围适合有特征的数据类型,对于最下一行的几乎均匀的数据几乎没有任何意义。

Scikit-learn进行计算的主要步骤

1、数据获取、预处理。
2、可选的降维过程.因为原始数据的维度比较大, 所以需要先找出真正跟预测目标相关的属性。
3、学习以及预测的过程。
4、反复学习的过程。增加样本、调优参数、换算法各种方式去提供预测的准确率。

Scikit-learn 的简单使用示例

决策树示例:

 from sklearn import datasets

  from sklearn import metrics

  from sklearn.tree import DecisionTreeClassifier

    # 读取 iris 数据集

  dataset = datasets.load_iris()

    # 采用CART模型

  model = DecisionTreeClassifier()

  model.fit(dataset.data, dataset.target)

  print(model)

    # 预测

  expected = dataset.target

  predicted = model.predict(dataset.data)

    # 统计

  print(metrics.classification_report(expected, predicted))

  print(metrics.confusion_matrix(expected, predicted))

输出: 

` 
precision recall f1-score support 
0 1.00 1.00 1.00 50 
1 1.00 1.00 1.00 50 
2 1.00 1.00 1.00 50 
avg / total 1.00 1.00 1.00 150 
[[50 0 0] 
[ 0 50 0] 
[ 0 0 50]] 

引用

Quick Start Tutorial:http://scikit-learn.org/stable/tutorial/basic/tutorial.html
User Guide:http://scikit-learn.org/stable/user_guide.html
API Reference:http://scikit-learn.org/stable/modules/classes.html
Example Gallery:http://scikit-learn.org/stable/auto_examples/index.html
Scikit-learn: Machine Learning in Python:http://jmlr.org/papers/v12/pedregosa11a.html
API design for machine learning software: experiences from the scikit-learn project:
http://arxiv.org/abs/1309.0238


原文发布时间为:2017-03-16
本文作者:toyld
本文来自云栖社区合作伙伴“ Python中文社区”,了解相关信息可以关注“ Python中文社区”微信公众号
相关文章
|
1天前
|
程序员 开发者 Python
Python中的装饰器:优雅而强大的函数修饰工具
在Python编程中,装饰器是一种强大的工具,它可以简洁地实现函数的增强、扩展和重用。本文将深入探讨Python中装饰器的工作原理、常见应用场景以及如何自定义装饰器,帮助读者更好地理解和运用这一重要的编程概念。
|
2天前
|
SQL 物联网 关系型数据库
sqlmap工具的使用 (超详细附工具版)_python sqlmap
sqlmap工具的使用 (超详细附工具版)_python sqlmap
|
4天前
|
机器学习/深度学习 算法 算法框架/工具
Python深度学习基于Tensorflow(5)机器学习基础
Python深度学习基于Tensorflow(5)机器学习基础
16 2
|
4天前
|
SQL 测试技术 网络安全
Python之SQLMap:自动SQL注入和渗透测试工具示例详解
Python之SQLMap:自动SQL注入和渗透测试工具示例详解
28 0
|
4天前
|
前端开发 文件存储 Python
python之xhtml2pdf: HTML转PDF工具示例详解
python之xhtml2pdf: HTML转PDF工具示例详解
12 0
|
4天前
|
Python
Python 中的异常处理机制是一种强大的错误处理工具
【5月更文挑战第8天】Python的异常处理机制借助try/except结构管理错误,提高程序健壮性。异常是中断正常流程的问题,可由多种原因引发。基本结构包括try块(执行可能出错的代码)和except块(处理异常)。通过多个except块可捕获不同类型的异常,finally块确保无论是否异常都执行的代码。此外,raise语句用于主动抛出异常,自定义异常通过继承Exception类实现。with语句配合上下文管理器简化资源管理并确保异常情况下资源正确释放。
21 2
|
4天前
|
机器学习/深度学习 算法 Python
深入浅出Python机器学习:从零开始的SVM教程/厾罗
深入浅出Python机器学习:从零开始的SVM教程/厾罗
|
4天前
|
缓存 开发者 Python
《Python中的装饰器:优雅而强大的代码增强工具》
在现代软件开发中,Python语言的灵活性和简洁性备受推崇。其中,装饰器作为一种强大的代码增强工具,为Python开发者提供了优雅的解决方案。本文将深入探讨装饰器的原理、用法以及实际应用场景,帮助读者更好地理解和运用这一技术。
|
4天前
|
机器学习/深度学习 数据采集 监控
Scikit-learn机器学习
【5月更文挑战第3天】Scikit-learn是一个基于NumPy、SciPy和Matplotlib的Python机器学习库,提供数据预处理到模型评估的全套工具。支持监督学习、无监督学习和降维等任务。要安装Scikit-learn,运行`pip install scikit-learn`。流程包括:数据准备(如加载鸢尾花数据集并划分训练测试集)、选择模型(如SVM分类器)、模型训练、模型评估(计算准确度)、特征工程和数据预处理(如特征缩放)、超参数调优(如Grid Search CV)、模型可视化(如混淆矩阵)和部署。
32 3
|
4天前
|
机器学习/深度学习 边缘计算 TensorFlow
【Python机器学习专栏】Python机器学习工具与库的未来展望
【4月更文挑战第30天】本文探讨了Python在机器学习中的关键角色,重点介绍了Scikit-learn、TensorFlow和PyTorch等流行库。随着技术进步,未来Python机器学习工具将聚焦自动化、智能化、可解释性和可信赖性,并促进跨领域创新,结合云端与边缘计算,为各领域应用带来更高效、可靠的解决方案。