zoukankan      html  css  js  c++  java
  • 数据处理——One-Hot Encoding

    一、One-Hot Encoding

        One-Hot编码,又称为一位有效编码,主要是采用位状态寄存器来对个状态进行编码,每个状态都由他独立的寄存器位,并且在任意时候只有一位有效。
        在实际的机器学习的应用任务中,特征有时候并不总是连续值,有可能是一些分类值,如性别可分为“male”和“female”。在机器学习任务中,对于这样的特征,通常我们需要对其进行特征数字化,如下面的例子:
    有如下三个特征属性:
    • 性别:["male","female"]
    • 地区:["Europe","US","Asia"]
    • 浏览器:["Firefox","Chrome","Safari","Internet Explorer"]
    对于某一个样本,如["male","US","Internet Explorer"],我们需要将这个分类值的特征数字化,最直接的方法,我们可以采用序列化的方式:[0,1,3]。但是这样的特征处理并不能直接放入机器学习算法中。

    二、One-Hot Encoding的处理方法

        对于上述的问题,性别的属性是二维的,同理,地区是三维的,浏览器则是思维的,这样,我们可以采用One-Hot编码的方式对上述的样本“["male","US","Internet Explorer"]”编码,“male”则对应着[1,0],同理“US”对应着[0,1,0],“Internet Explorer”对应着[0,0,0,1]。则完整的特征数字化的结果为:[1,0,0,1,0,0,0,0,1]。这样导致的一个结果就是数据会变得非常的稀疏。

    三、实际的Python代码

    [python] view plain copy
     
    1. from sklearn import preprocessing  
    2.   
    3. enc = preprocessing.OneHotEncoder()  
    4. enc.fit([[0,0,3],[1,1,0],[0,2,1],[1,0,2]])  
    5.   
    6. array = enc.transform([[0,1,3]]).toarray()  
    7.   
    8. print array  

    结果:[[ 1.  0.  0.  1.  0.  0.  0.  0.  1.]]
  • 相关阅读:
    四组API
    常用的辅助类(必会
    时间戳
    SpringMVC JSON乱码解决
    数据显示到前端
    ubuntu vim字体高亮
    vi编辑文件保存后,提示""vimrc" E212: Can't open file for writing Press ENTER or type command to continu"
    C语言程序设计100例之(25):确定进制
    C语言程序设计100例之(24):数制转换
    C语言程序设计100例之(23):数列求和
  • 原文地址:https://www.cnblogs.com/antflow/p/7279400.html
Copyright © 2011-2022 走看看