Fit是对于数据进行拟合,所谓拟合,就是根据数据,计算获得数据里面的一些指标,比如均值,方差;下一步很多API都是需要这些参数来进行后续对数据的操作,比如下面要讲到的transform。

Transform,对于数据进行变形;常见的变形是标准化和归一化。标准化是需要均值和方差的,标准化本质上将数据进行正态分布化;

很多时候,当需要依次对训练数据和测试数据进行变形处理的时候,首先处理训练数据,这个时候需要调用fit,再调用tranform,或者直接使用fit_transform;然后再处理测试数据,这个时候,直接transform就可以了,因为处理训练数据的时候,其实已经通过fit获取了均值方差等指标;

 rnd.seed(42)

 m = 100

 X = 6 * rnd.rand(m, 1) - 3

 y = 2 + X + 0.5 * X**2 + rnd.randn(m, 1)

 X_train, X_val, y_train, y_val = train_test_split(X[:50], y[:50].ravel(), test_size=0.5, random_state=10)

 poly_scaler = Pipeline((

 ("poly_features", PolynomialFeatures(degree=90, include_bias=False)),

 ("std_scaler", StandardScaler()),

 ))

 X_train_poly_scaled = poly_scaler.fit_transform(X_train)

 X_val_poly_scaled = poly_scaler.transform(X_val)

这里牵涉一个对象就是标准化的伸缩,这个处理是为了避免单个数据过大,进而导致了数据处理异常;于是为了降低单个特征对于整体的影响,对于数据集合进行求导,然后对于所有的数据除以导数;将数据缩小到一定程度,降低了个别数值的影响。Numpy里面是有原始实现的:

 >>> from sklearn import preprocessing

 >>> import numpy as np

 >>> X_train = np.array([[ 1., -1., 2.],

 ... [ 2., 0., 0.],

 ... [ 0., 1., -1.]])

 >>> X_scaled = preprocessing.scale(X_train)

 >>> X_scaled

 array([[ 0. ..., -1.22..., 1.33...],

 [ 1.22..., 0. ..., -0.26...],

 [-1.22..., 1.22..., -1.06...]])

 >>> X_scaled.mean(axis=0)

 array([0., 0., 0.])

 >>> X_scaled.std(axis=0)

 array([1., 1., 1.])

最后看到经过伸缩数据满足了,均值为0,标准差为1(注意这里指定了参数为0,代表是对列求标准差,最后返回的一行数据;如果是1,则代表对行求标准差,最后返回的一列),后面还会以后给予axis的处理。

这个是sklearn中原始的处理;还有一个封装的类专门用于这个处理:StandardScale。

 >>> scaler = preprocessing.StandardScaler().fit(X_train)

 >>> scaler

 StandardScaler(copy=True, with_mean=True, with_std=True)

 >>> scaler.mean_

 array([1. ..., 0. ..., 0.33...])

 >>> scaler.scale_

 array([0.81..., 0.81..., 1.24...])

 >>> scaler.transform(X_train)

 array([[ 0. ..., -1.22..., 1.33...],

 [ 1.22..., 0. ..., -0.26...],

 [-1.22..., 1.22..., -1.06...]])

这个形式变成了我们上面描述的fit-transform,在fit之后,将可以获取到mean以及std;然后将会进行一下数据变形;获取到了最后的矩阵,下面我们要查看一下这个矩阵到底是不是满足均值为0,标准差为1的正态分布呢?

 import numpy as np
formated_data =scaler.transform(X_train)
print(np.mean(formated_data, 0))
print(np.std(formated_data))

返回信息:

[0. 0. 0.]

1.0

注意,在np.mean的时候,传递了第二个参数,且值为0(对列进行均值,返回一行);注意这个有值和没有值结果是完全不一样,没有传递参数只是返回一个值,应该是对于行列统一做了一下均值;

上面的描述中提到了transform的时候,内部执行的是标准化,到底对数据做了什么,到底为什么要做标准化呢?

首先将归一化/ 标准化,就是将数据缩放(映射)到一个范围内,比如[0,1],[-1,1],还有在图形处理中将颜色处理为[0,255];归一化的好处就是不同纬度的数据在相近的取值范围内,这样在进行梯度下降这样的算法的时候,曲线将会更加简单(由原始的椭圆变成了圆形),如下图所示:

至于缩放的原理就是量纲代表,比如身高和指甲宽度,如果统一都是厘米那么两者不是一个数量级,如果把身高的量纲改为米,那么你会发现身高取值范围和指甲宽度其实是相近的取值范围,这样避免了某个维度成为了影响学习结果的主导。

常见的归一化/ 标准化

1. Standard Scala(z-score standardization):是标准化处理;将元素通过下面的公式进行处理:

x =(x -

关于fit和transform的更多相关文章

  1. SimpleImputer 中fit和transform方法的简介

    sklearn.impute.SimpleImputer 中fit和transform方法的简介 SimpleImputer 简介 通过SimpleImputer ,可以将现实数据中缺失的值通过同一列 ...

  2. sklearn中各算法类的fit,fit_transform和transform函数

    在使用PCA和NFC中有三个函数fit,fit_transform,transform区分不清各自的功能.通过测试,勉强了解各自的不同,在这里做一些笔记. 1.fit_transform是fit和tr ...

  3. sklearn fit transform fit_transform

    scikit-learn提供了一系列转换库,他们可以清洗,降维,提取特征等. 在数据转换中有三个很重要的方法,fit,fit_transform,transform ss=StandardScaler ...

  4. fit_transform和transform的区别

    来自:泡泡糖nana 来自:俞驰 1. fit_transform是fit和transform的组合. 2. fit(x,y)传两个参数的是有监督学习的算法,fit(x)传一个参数的是无监督学习的算法 ...

  5. 【原】Spark之机器学习(Python版)(二)——分类

    写这个系列是因为最近公司在搞技术分享,学习Spark,我的任务是讲PySpark的应用,因为我主要用Python,结合Spark,就讲PySpark了.然而我在学习的过程中发现,PySpark很鸡肋( ...

  6. 【原】Spark之机器学习(Python版)(一)——聚类

      kmeans聚类相信大家都已经很熟悉了.在Python里我们用kmeans通常调用Sklearn包(当然自己写也很简单).那么在Spark里能不能也直接使用sklean包呢?目前来说直接使用有点困 ...

  7. KNN算法

    1.算法讲解 KNN算法是一个最基本.最简单的有监督算法,基本思路就是给定一个样本,先通过距离计算,得到这个样本最近的topK个样本,然后根据这topK个样本的标签,投票决定给定样本的标签: 训练过程 ...

  8. spark 基本操作

    读取文件的数据 使用的数据:https://codeload.github.com/xsankar/fdps-v3/zip/master 读取单个文件的数据 case class Employee(E ...

  9. 使用sklearn优雅地进行数据挖掘【转】

    目录 1 使用sklearn进行数据挖掘 1.1 数据挖掘的步骤 1.2 数据初貌 1.3 关键技术2 并行处理 2.1 整体并行处理 2.2 部分并行处理3 流水线处理4 自动化调参5 持久化6 回 ...

随机推荐

  1. 字典和json 的区别 和转换

    前言:字典和json非常像.接下来比较一下两者的异同 先看一下字典的写法: a = {', ', ' } 再看一下json的写法: { "studentInfo": { " ...

  2. HDU 2147 kiki's game(博弈经典题)

    题目传送:http://acm.hdu.edu.cn/showproblem.php?pid=2147 Problem Description Recently kiki has nothing to ...

  3. 大数据-02-Scala入门

    Scala 简介 它是一门基于JVM的面向函数和面向对象的编程语言, 它包含了求值表达式,闭包,切片操作,模式匹配,隐式转换等特性. 可变量/不可变量 可变集合/不可变集合.集合操作 函数 值函数 求 ...

  4. H5之localStorage,sessionStorage

    在以前的时候也听说过一些h5缓存技术,具体也没有去使用过,就在前两三个礼拜我用了localStorage和sessionStorage这两个存储方式, 我使用这些存储技术,也是想减少访问服务器的请求, ...

  5. 机器学习: 共轭梯度算法(PCG)

    今天介绍数值计算和优化方法中非常有效的一种数值解法,共轭梯度法.我们知道,在解大型线性方程组的时候,很少会有一步到位的精确解析解,一般都需要通过迭代来进行逼近,而 PCG 就是这样一种迭代逼近算法. ...

  6. php 中 ">>" "<<" 的含义

    运算符  说明 <<<    管道,引入自c++.将被其后标记括起来的内容视为一个字符串处理,其中的变量会被展开 <<     左移,位操作算符 >>     ...

  7. [LeetCode&Python] Problem 122. Best Time to Buy and Sell Stock II

    Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...

  8. Bagging-Adaboost-RF的粗糙理解

    三种方法都是组合方法,组合方法是使用多个分类器进行投票[构造每个分类器的样本都是通过有放回抽样得到的] 1.Bagging(装袋):k次抽样,训练k次,得到k个模型(分类器),等权重投票 2.Adab ...

  9. javascript的this多种场景用法

    作者:刘志祥 时间:2017.11.10 参考:阮一峰的官方网站 this 是javaScript中的一个关键字,只能在函数内使用.随着场合的不同,this的值会发生变化. 1. 单纯的全局函数调用, ...

  10. 最长公共子序列与最长公共字串 (dp)转载http://blog.csdn.net/u012102306/article/details/53184446

    1. 问题描述 子串应该比较好理解,至于什么是子序列,这里给出一个例子:有两个母串 cnblogs belong 比如序列bo, bg, lg在母串cnblogs与belong中都出现过并且出现顺序与 ...