一、为什么要独热编码?

独热编码(哑变量 dummy variable)是因为大部分算法是基于向量空间中的度量来进行计算的,为了使非偏序关系的变量取值不具有偏序性,并且到圆点是等距的。使用one-hot编码,将离散特征的取值扩展到了欧式空间,离散特征的某个取值就对应欧式空间的某个点。将离散型特征使用one-hot编码,会让特征之间的距离计算更加合理。离散特征进行one-hot编码后,编码后的特征,其实每一维度的特征都可以看做是连续的特征。就可以跟对连续型特征的归一化方法一样,对每一维特征进行归一化。比如归一化到[-1,1]或归一化到均值为0,方差为1。

为什么特征向量要映射到欧式空间?
  • 将离散特征通过one-hot编码映射到欧式空间,是因为,在回归,分类,聚类等机器学习算法中,特征之间距离的计算或相似度的计算是非常重要的,而我们常用的距离或相似度的计算都是在欧式空间的相似度计算,计算余弦相似性,基于的就是欧式空间。

二、独热编码优缺点

优点:独热编码解决了分类器不好处理属性数据的问题,在一定程度上也起到了扩充特征的作用。它的值只有0和1,不同的类型存储在垂直的空间。
缺点:当类别的数量很多时,特征空间会变得非常大。在这种情况下,一般可以用PCA来减少维度。而且one hot encoding+PCA这种组合在实际中也非常有用。

三、什么情况下(不)用独热编码?

用:独热编码用来解决类别型数据的离散值问题,==
不用==:将离散型特征进行one-hot编码的作用,是为了让距离计算更合理,但如果特征是离散的,并且不用one-hot编码就可以很合理的计算出距离,那么就没必要进行one-hot编码。 有些基于树的算法在处理变量时,并不是基于向量空间度量,数值只是个类别符号,即没有偏序关系,所以不用进行独热编码。 Tree Model不太需要one-hot编码: 对于决策树来说,one-hot的本质是增加树的深度。

总的来说,要是one hot encoding的类别数目不太多,建议优先考虑。

四、 什么情况下(不)需要归一化?

需要: 基于参数的模型或基于距离的模型,都是要进行特征的归一化。
不需要:基于树的方法是不需要进行特征的归一化,例如随机森林,bagging 和 boosting等。

五、ne-hot编码为什么可以解决类别型数据的离散值问题

首先,one-hot编码是N位状态寄存器为N个状态进行编码的方式

  • eg:高、中、低不可分,→ 用0 0 0 三位编码之后变得可分了,并且成为互相独立的事件
    类似 SVM中,原本线性不可分的特征,经过project之后到高维之后变得可分了
    GBDT处理高维稀疏矩阵的时候效果并不好,即使是低维的稀疏矩阵也未必比SVM好

六、Tree Model不太需要one-hot编码

对于决策树来说,one-hot的本质是增加树的深度
  tree-model是在动态的过程中生成类似 One-Hot + Feature Crossing 的机制

  1. 一个特征或者多个特征最终转换成一个叶子节点作为编码 ,one-hot可以理解成三个独立事件
  2. 决策树是没有特征大小的概念的,只有特征处于他分布的哪一部分的概念
  • one-hot可以解决线性可分问题 但是比不上label econding
  • one-hot降维后的缺点:

降维前可以交叉的降维后可能变得不能交叉

为什么要独热编码、优缺点、相关推荐

  1. OneHotEncoder独热编码和 LabelEncoder标签编码——机器学习

    学习sklearn和kagggle时遇到的问题,什么是独热编码?为什么要用独热编码?什么情况下可以用独热编码?以及和其他几种编码方式的区别. 首先了解机器学习中的特征类别:连续型特征和离散型特征 拿到 ...

  2. 【小代码讲解】独热编码(One-Hot编码)

    独热编码(One-Hot编码) 独热编码介绍 独热编码表示 独热编码实现 使用sklearn 不使用sklearn 独热编码介绍 在机器学习中,标签的处理总是需要进行独热编码的处理,因为独热编码有以下 ...

  3. OneHotEncoder独热编码

    首先了解机器学习中的特征类别:连续型特征和离散型特征. 拿到获取的原始特征,必须对每一特征分别进行归一化,比如,特征A的取值范围是[-1000,1000],特征B的取值范围是[-1,1].如果使用lo ...

  4. 机器学习:数据预处理之独热编码(One-Hot)详解

    一. 什么是独热编码? ---------------------------------------- 在机器学习算法中,我们经常会遇到分类特征,例如:人的性别有男女,祖国有中国,美国,法国等. 这 ...

  5. 数据处理与特征工程:One-Hot Encoder独热编码、Label Encoder标签编码、Binary Encoder二进制编码

    目录 一  OneHotEncoder独热编码 1.1 OneHotEncoder独热编码原理 2.1. 为什么要独热编码OneHotEncoder? 2.3 独热编码优缺点 2.4 什么情况下(不) ...

  6. 独热编码(One-Hot Encoding)介绍、代码实现应用与优缺点

    一.独热编码(One-Hot Encoding)介绍 One-hot在数字电路中被用来表示一种特殊的位元组合,该字节里,仅容许单一位元为1,其他位元都必须为0.之所以称为one-hot就是因为只能有一 ...

  7. 数据预处理之独热编码(One-Hot)

    1.前言 在机器学习算法中,我们经常会遇到分类特征,例如:人的性别有男女,祖国有中国,美国,法国等. 这些特征值并不是连续的,而是离散的,无序的.通常我们需要对其进行特征数字化. 那什么是特征数字化呢 ...

  8. 数据预处理之One-Hot(独热编码)编码

    数据预处理之One-Hot(独热编码)编码 为什么使用One-Hot编码 对于机器学习任务中,特征并不总是连续值,很多是分类值.这些分类值本身没有大小的意义.为了将数据集中一个分类变量替换为一个或多个 ...

  9. 学习笔记 | 独热编码(One-Hot Encoding)

    最近学习机器学习,接触到独热编码相关内容,参考了一些资料,加上自己的思考,做出了如下总结. 一.什么是独热编码 独热编码,即 One-Hot 编码,又称一位有效编码,其方法是使用N位状态寄存器来对N个 ...

最新文章

  1. 北大读博手记:怎样完成自己的博士生涯?非常具有指导性!
  2. OKR简单通俗易懂的介绍,1分钟了解什么是OKR工作法
  3. python代码实现二叉树的镜像树
  4. web-5. 超链接的使用
  5. 计网 - 流和缓冲区:缓冲区的 flip 是怎么回事?
  6. ubuntu下gcc的安装与使用
  7. matplotlib布局_Matplotlib多列,行跨度布局
  8. 大公司稳定工作和创业之间如何选择?
  9. 网络流专题(完结撒花)
  10. “玲珑杯”郑州轻工业学院第八届ACM程序设计大赛Problem G: 蛤玮点菜
  11. 《数字视频和高清:算法和接口》一3.3感知均匀性
  12. java垃圾回收机制介绍
  13. 无人驾驶之硬件平台详解
  14. Linux安装文件报错configure: error: no acceptable C compiler found in $PATH
  15. 【综述】A Comprehensive Survey on Graph NeuralNetworks(2)
  16. html的method属性,HTML中的form标签的method属性怎么用?这里有method属性的用法介绍...
  17. JavaScript中文与阿拉伯数字互相转换
  18. 怎样隐藏计算机中的文件夹,电脑上的文件夹不想被别人看到怎么办?如何隐藏电脑文件夹?-电脑文件夹怎么加密...
  19. 自己对PID控制算法的一点见解
  20. win10增大任务栏图标尺寸教程

热门文章

  1. 在测试VPN时候的惊天大坑,命令行查到的ip与百度搜索的ip不一致
  2. 细数Ajax技术的先进性与局限性
  3. STM32MP157驱动开发——Linux并发与竞争
  4. Spring的初体验-2
  5. python制作英汉词典_python如何制作英文字典
  6. CNTK学习笔记(一)
  7. python程序设置头像_Django+JS 实现点击头像即可更改头像的方法示例
  8. 别让老板杀了你——中国职场冷思考
  9. Hello MySQL(九)——视图
  10. 时空伴随者:拒绝“被弹窗”,如何通过提升数据质量来确定我们一起吹过风