原作:Justin Gage
虚无之栗 编译自 Algorithmia
量子位 出品 | 公众号 QbitAI

如果你的一大坨数据,怎么办?

无监督学习是机器学习算法里非常扑朔迷离的一个类别,负责解决这些“没有真实值 (no-ground-truth) ”的数据。

本文会讲到,无监督学习到底是什么,和机器学习的其他算法有何本质区别,用的时候有哪些难点,以及推荐阅读的传送门。

无监督学习是什么?

最简单的理解方式,就是把算法想象成考试。卷子上的每道题对应一个答案,得分高低就要看你的答案和标准答案有多接近。不过,如果没有答案只有问题,你要怎么给自己打分?

把这一套东西挪到机器学习上来。传统的数据集都有标签 (相当于标答) ,逻辑是“X导致Y”。比如,我们想要知道,推特上粉丝更多的人,是不是收入也更高。那么,input是粉丝数,output是收入,要试着找出两组数据之间的关系。

每颗星是一个数据点,机器学习就是要画出差不多能连起那些点的一条线,以此解释input和output之间的关系。但在无监督学习里,并没有output这个东西

我们要做的是分析input,也就是粉丝数。但没有收入,或者Y。就像是考试只有题,没有标答一样。

其实,也不一定是没有Y,可能我们只是没有办法获得收入数据。不过这都不要紧,重要的是不需要画出X和Y之间的那条线了,不需要找它们之间的关系了。

那么,无监督学习的目标是什么?如果只有input没有output,我们到底该怎么办?

无监督学习分几种

聚类(Clustering)

任何行业都需要对用户的理解:他们是谁?是什么促使他们做出购买的决定?

通常,用户可以按照某些标准分为几组。这些标准可简单如年龄如性别,也可复杂如用户画像、如购买流程。无监督学习可以帮我们自动完成这个任务。

聚类算法会跑过我们的数据,然后找出几个自然聚类 (Natural Clusters) 。以用户为例,一组可能是30多岁的艺术家,另一组可能是家里养狗的千万富翁。我们可以自己选择聚类的数量,这样就能调整各个组别的粒度 (Granularity) 。

有以下几种聚类方法可以选用:

· K-Means聚类,把所有数据点划分到K个互斥组别里。复杂之处在于如何选取K的大小

· 层次聚类 (Hierarchical Clustering) ,把所有数据点划分到一些组别、和它们的子组别里,形成像族谱一样的树状图。比如,先把用户按年龄分组,然后把各个组别按照其他标准再细分。

· 概率聚类 (Probabilistic Clustering) ,把所有数据点按照概率来分组。K-Means其实就是它的一种特殊形式,即概率永远为0或1的情况。所以这种聚类方式,也被亲切地称为“模糊的K-Means”。

这几种并无本质区别的方法,写成代码可能就长这样——

任何聚类算法的output,都会是所有的数据点、以及它们所对应的组别。这就需要我们自己来判断,output代表怎样的含义,或是算法到底发现了什么。数据科学的魅力即在于,output加上人类的解读,便会产生价值。

数据压缩 (Data Compression)

在过去的十年间,设备的计算能力和存储能力都增强了许多。不过,即便在今天我们依然有理由,让数据集尽可能小、并尽可能高效。这意味着,只要让算法去跑一些必要的数据,而不要做过多的训练。

无监督学习可以用一种名为数据降维 (Dimentionality Reduction) 的方式做到这一点。

数据降维的“”,就是指数据集有多少列。这个方法背后的概念和信息论 (Information Theory) 一样:假设数据集中的许多数据都是冗余的,所以只要取出一部分,就可以表示整个数据集的情况了。

在实际应用中,我们需要用某种神秘的方式,把数据集里的某些部分结合到一起,来传达某些意义。这里有我们比较常用的两种降维方式——

· 主成分分析算法 (PCA) ,找出能够把数据集里的大多数变化联系起来的线性组合
· 奇异值分解 (SVD) ,把数据的矩阵分解成三个小矩阵

这两种方法,以及另外一些更复杂的降维方式,都用了线性代数的概念,把矩阵分解成容易消化的样子,便于传递信息。

数据降维可以在机器学习算法里,起到非常重要的作用。以图像为例,在计算机视觉里,一幅图像就是一个巨大的数据集,训练起来也很费力。而如果可以缩小训练用的数据集,模型就可以跑得更快了。这也是为什么,PCA和SVD都图像预处理时常见的工具。

无监督深度学习

无监督学习,把领地扩张到了神经网络和深度学习里,这一点也不奇怪。这个领域还很年轻,不过已经有了自编码器 (Autoencoder) 这样的先行者。

自编码器和数据压缩算法背后的逻辑差不多,用一个子集来反映原始数据集的特征。像神经网络一样,自编码器利用权重把input转换成理想的output。不过在这里,output和input并不是两种不同的东西,output只是input的一种更轻便的表示方式。

在计算机视觉中,自编码器被用在图像识别算法里。现在,它也已经把触角伸向声音和语音识别等更多的领域。

实战难点有哪些

除了寻找合适的算法和硬件,这样常见的问题之外,无监督学习自带一种神秘的气质——不知道任务到底完成了没有

在监督学习里,我们会定下一套标准,以做出模型调试的决策。精确度 (Precision) 和查全率 (Recall) 这样的指标会告诉我们,现在的模型有多准确,然后我们可以调整参数来优化模型。分数低,就要继续调。

可是,无监督学习的数据没有标签,我们就很难有理有据地定下那套衡量标准。以聚类为例,怎么知道K-Means的分类好不好 (比如K值取的合不合适) ?没有标准了,我们可能就需要有点创造力。

“无监督学习在我这里管用么?”是人们经常提出的问题。这里,具体问题要具体分析。还以用户分组为例,只有当你的用户真的和自然聚类相匹配的时候,聚类的方法才有效。

虽然有些风险,但最好的测试方法,可能就是把无监督模型放到现实世界里,看看会发生什么——让有聚类的和没有聚类的算法做对比,看聚类能不能得出更有效的信息。

当然,研究人员也在尝试编写,自带 (相对) 客观评判标准的无监督学习算法。那么,栗子在哪里?

友好的传送门:

https://blog.algorithmia.com/introduction-to-unsupervised-learning/

下拉至Reading and Papers,栗子可能要从那里开始吃。

 祝您消化顺畅

活动报名

诚挚招聘

量子位正在招募编辑/记者,工作地点在北京中关村。期待有才气、有热情的同学加入我们!相关细节,请在量子位公众号(QbitAI)对话界面,回复“招聘”两个字。

量子位 QbitAI · 头条号签约作者

վ'ᴗ' ի 追踪AI技术和产品新动态

无监督学习才不是“不要你管”相关推荐

  1. 机器学习(3)——无监督学习

    什么是无监督学习? 顾名思义,无监督学习就是不受监督的学习.同监督学习建立在人类标注数据的基础上不同,无监督学习不需要人类进行数据标注,而是通过模型不断地自我认知.自我巩固,最后进行自我归纳来实现其学 ...

  2. CVPR 2022|MLP才是无监督学习比监督学习迁移性能好的关键因素

    ©作者 | 王逸舟 单位 | 浙江大学 研究方向 | 计算机视觉,无监督学习 在这里和大家分享一下我们被 CVPR 2022 录用的工作"Revisiting the Transferabi ...

  3. CVPR 2022 | MLP才是无监督学习比监督学习迁移性能好的关键因素

    点击下方卡片,关注"CVer"公众号 AI/CV重磅干货,第一时间送达 作者:王逸舟   |  已授权转载(源:知乎)编辑:CVer https://zhuanlan.zhihu. ...

  4. NeurIPS 2020 :ReID任务大幅领先,港中文开源自步对比学习框架,充分挖掘无监督学习样本...

    作者丨葛艺潇 来源丨https://zhuanlan.zhihu.com/p/269112325 编辑丨极市平台 导语:本文介绍一篇作者发表于NeurIPS-2020的论文: <Self-pac ...

  5. 图灵奖得主Geoffrey Hinton:脱缰的无监督学习,将带来什么

    与6位图灵奖得主和100多位专家 共同探讨人工智能的下一个十年 北京智源大会倒计时:4天 在即将举行的第二届北京智源大会上(官网:https://2020.baai.ac.cn),图灵奖获得者Geof ...

  6. 吴恩达:无监督学习很重要!

    # 吴恩达:无监督学习很重要!# Peter是我的我第一个博士生,他有着评判性思维,当时他的博士学位研究主题是用强化学习控制无人直升机,直到现在你都可以在斯坦福网站上看到这些视频.这项研究非常难,有一 ...

  7. 监督学习和无监督学习

    自理解机器学习的概念时,没有深刻理解监督学习和无监督学习的区别,在网上查找了部分资料,现在总结如下: 总的来说,机器学习任务将根据训练样本是否有label,可以分为监督学习和无监督学习,这是最简单直接 ...

  8. 无监督学习与有监督学习的本质区别是什么_吴恩达老师课程笔记系列第三节-无监督学习定义...

    第三节-无监督学习定义 我们将介绍第二种主要的机器学习问题.叫做无监督学习. 上个课程中,已经介绍了监督学习.回想当时的数据集,如图表所示,这个数据集中每条数据都已经标明是阴性或阳性,即是良性或恶性肿 ...

  9. 【机器学习算法-python实现】K-means无监督学习实现分类

    1.背景         无监督学习的定义就不多说了,不懂得可以google.因为项目需要,需要进行无监督的分类学习.         K-means里面的K指的是将数据分成的份数,基本上用的就是算距 ...

最新文章

  1. tcp、udp协议连接的建立和释放
  2. eclipse开发项目关于内存是如何分配的
  3. Spatial Transformer Networks(STN)代码分析
  4. java中有ClockPane类吗,JavaFX实现简易时钟效果(二)
  5. java将日期作为文件名_获取当前时间作为文件名
  6. 一些关于ROS中move_base的理解
  7. java se 1335,1335.逼退法王
  8. PXE自动化安装系统工具介绍与部署
  9. 前端性能监控方案window.performance 调研(转)
  10. matlab2c使用c++实现matlab函数系列教程-ones函数
  11. asp2.0 GridView OnRowDataBound event
  12. python雷达图的相似度_Python教程:matplotlib实现雷达图和柱状图
  13. 一篇介绍OpenJDK字体的文章
  14. idea展现目录清晰方式
  15. 基于FPGA的关于flash一些学习记录
  16. linux-postgresql客户端操作实例
  17. TFS2010升级至TFS2013完全指南(更换服务器)
  18. destoon 中国银联在线支付接口修改
  19. 组合恒等式1 五个基本的组合恒等式 基础与简单例子
  20. 个人物联网(目前用到了树莓派、PMS7003攀藤g7传感器、DHT11温湿度传感器)

热门文章

  1. 2017 年度编程语言榜,Java 最流行、JavaScript 最没价值?
  2. 在浏览器上,我们的隐私都是如何被泄漏的?
  3. 苹果发布无人驾驶研究最新进展,应用机器学习等人工智能热门技术
  4. 会员登录 php,php $_SESSION会员登录实例分享
  5. php中throw的作用,php – GOTO和THROW之间的区别?
  6. Windows 定时执行脚本
  7. php 如果判断是utf,php 判断网页是否是utf8编码的方法_PHP教程
  8. python程序可以在任何安装了解释器_Windows安装多个python解释器
  9. 可视化查看依赖关系_图可视化分析解决方案KeyLines介绍
  10. java socket 异常处理_socket编程报异常java.io.EOFException