[机器学习]t-SNE聚类算法实践指南

作者介绍: Saurabh .jaju2

  Saurabh是一名数据科学家和软件工程师,熟练分析各种数据集和开发智能应用程序。他目前正在加州大学伯克利分校攻读信息和数据科学硕士学位,热衷于开发基于数据科学的智能资源管理系统。

Linkedin:https://in.linkedin.com/in/saurabh-jaju

Github:https://github.com/saurabhjaju2

介绍

    许多数据科学家经常面对的问题之一:假设有一个包含数百个特征(变量)的数据集,对数据所属的域没有任何了解,需要对该数据集识别隐藏状态、探索并分析。本文将介绍一种非常强大的方法来解决该问题。

关于PCA

  现实中大多数人会使用PCA进行降维和可视化,但为什么不选择比PCA更先进的东西呢?关于PCA的介绍可以阅读该文献。本文讲解比PCA(1933)更有效的算法t-SNE(2008)。

本文内容

1 什么是t-SNE?

2 什么是降维?

3 t-SNE如何在维数降低算法空间中拟合

4 t-SNE算法的细节

5 t-SNE实际上是做什么?

6 用例

7 t-SNE与其他降维算法相比

8 示例实现

        R语言

         Python语言

9应用方面

   数据科学家

   机器学习骇客

   数据科学爱好者

10 常见错误

1 什么是t-SNE

 (t-SNE)t分布随机邻域嵌入 是一种用于探索高维数据的非线性降维算法。它将多维数据映射到适合于人类观察的两个或多个维度。

46439e36cf281fdeb199dcb16c2b723b9a08194b

2 什么是降维?

   简而言之,降维就是用2维或3维表示多维数据(彼此具有相关性的多个特征数据)的技术利用降维算法,可以显式地表现数据。

3 t-SNE如何在降维算法空间中拟合

   常用的降维算法有:

1 PCA(线性)

2 t-SNE(非参数/非线性)

3 Sammon映射(非线性)

4 Isomap(非线性)

5 LLE(非线性)

6 CCA(非线性)

7 SNE(非线性)

8 MVU(非线性)

9 拉普拉斯特征图(非线性)

   只需要研究上述算法中的两种——PCA和t-SNE。

PCA的局限性

  PCA是一种线性算法,它不能解释特征之间的复杂多项式关系。而t-SNE是基于在邻域图上随机游走的概率分布来找到数据内的结构。

  线性降维算法的一个主要问题是不相似的数据点放置在较低维度表示为相距甚远。但为了在低维度非线性流形表示高维数据,相似数据点必须表示为非常靠近,这不是线性降维算法所做的。

4 t-SNE算法的细节

 4.1 算法

  步骤1:

随机邻接嵌入(SNE)通过将数据点之间的高维欧几里得距离转换为表示相似性的条件概率而开始,数据点xixj之间的条件概率pj|i由下式给出:

7865f9e80ece98a016f0e310ea8fa8e14c3a9db9

其中σi是以数据点xi为中心的高斯方差。

  步骤2:

  对于高维数据点xixj的低维对应点yiyj而言,可以计算类似的条件概率qj|i

      def3073e7fff9a1f12327ef0914efb8a889da3b7

SNE试图最小化条件概率的差异。

  步骤3:

    为了测量条件概率差的和最小值,SNE使用梯度下降法最小化KL距离。而SNE的代价函数关注于映射中数据的局部结构,优化该函数是非常困难的,而t-SNE采用重尾分布,以减轻拥挤问题和SNE的优化问题。

  步骤4:

   定义困惑度:

51f1f11d693d4b520d5d74182ccb79e9dd39a8a1

   其中H(Pi)是香农熵

    160b3cbd31d9015af253dc1ee1d260d27f47d363

4.2 时间和空间复杂性

   算法计算对应的是条件概率,并试图最小化较高和较低维度的概率差之和,这涉及大量的计算,对系统资源要求高。t-SNE的复杂度随着数据点数量有着时间和空间二次方。

5 t-SNE实际上是做什么?

t-SNE非线性降维算法通过基于具有多个特征的数据点的相似性识别观察到的簇来在数据中找到模式。本质上是一种降维和可视化技术。另外t-SNE的输出可以作为其他分类算法的输入特征。

6用例

 t-SNE几乎可用于所有高维数据集,广泛应用于图像处理,自然语言处理,基因组数据和语音处理。实例有:面部表情识别[2]、识别肿瘤亚群[3]、使用wordvec进行文本比较[4]等。

7 t-SNE与其他降维算法相比

  基于所实现的精度将t-SNE与PCA和其他线性降维模型相比,结果表明t-SNE能够提供更好的结果。这是因为算法定义了数据的局部和全局结构之间的软边界。

8示例实现

  在MNIST手写数字数据库上实现t-SNE算法。

 1 R语言

  “Rtsne”包在R中具有t-SNE的实现。“Rtsne”包可以使用在R控制台中键入的以下命令安装在R中:

 
  

    超参数调整

725ecc927935b13a2f9859a69c0e36cb9139577c

 代码

  MNIST数据可从MNIST网站下载,并可转换为具有少量代码的csv文件。

## calling the installed package
train<‐ read.csv(file.choose()) ## Choose the train.csv file downloaded from the link above
library(Rtsne)
## Curating the database for analysis with both t‐SNE and PCA
Labels<‐train$label
train$label<‐as.factor(train$label)
## for plotting
colors = rainbow(length(unique(train$label)))
names(colors) = unique(train$label)
## Executing the algorithm on curated data
tsne <‐ Rtsne(train[,‐1], dims = 2, perplexity=30, verbose=TRUE, max_iter = 500)
exeTimeTsne<‐ system.time(Rtsne(train[,‐1], dims = 2, perplexity=30, verbose=TRUE, max_iter = 50
0))
## Plotting
plot(tsne$Y, t='n', main="tsne")
text(tsne$Y, labels=train$label, col=colors[train$label])

 实现时间

  6242f88cd410239964ad1bdc3fe8564fc39f0bcd

可以看出,与PCA相比,t-SNE在相同样本大小的数据上执行需要相当长的时间。

 解释结果

  以下图用于探索性分析。输出x和y坐标以及成本可以用作分类算法中的特征。

f7adb3c74a84ba93145761d39e280574950e5a02

d0414d3247882ae47781c11549cdfc629bec7f89

2 Python语言

   t-SNE算法可以从sklearn包中访问。

超参数调整

  fce0dc4f4df4e8c9f523dfb0bc3b9e78ed621054

代码

    以下代码来自sklearn网站上的sklearn示例。

 代码1

实现时间

## importing the required packages
from time import time
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import offsetbox
from sklearn import (manifold, datasets, decomposition, ensemble,
discriminant_analysis, random_projection)
## Loading and curating the data
digits = datasets.load_digits(n_class=10)
X = digits.data
y = digits.target
n_samples, n_features = X.shape
n_neighbors = 30
## Function to Scale and visualize the embedding vectors
def plot_embedding(X, title=None):
x_min, x_max = np.min(X, 0), np.max(X, 0)
X = (X ‐ x_min) / (x_max ‐ x_min)
plt.figure()
ax = plt.subplot(111)
for i in range(X.shape[0]):
plt.text(X[i, 0], X[i, 1], str(digits.target[i]),
color=plt.cm.Set1(y[i] / 10.),
fontdict={'weight': 'bold', 'size': 9})
if hasattr(offsetbox, 'AnnotationBbox'):
## only print thumbnails with matplotlib > 1.0
shown_images = np.array([[1., 1.]]) # just something big
for i in range(digits.data.shape[0]):
dist = np.sum((X[i] ‐ shown_images) ** 2, 1)
if np.min(dist) < 4e‐3:
## don't show points that are too close
continue
shown_images = np.r_[shown_images, [X[i]]]
imagebox = offsetbox.AnnotationBbox(
offsetbox.OffsetImage(digits.images[i], cmap=plt.cm.gray_r),
X[i])
ax.add_artist(imagebox)
plt.xticks([]), plt.yticks([])
if title is not None:
plt.title(title)
#‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐
## Plot images of the digits
n_img_per_row = 20
img = np.zeros((10 * n_img_per_row, 10 * n_img_per_row))
for i in range(n_img_per_row):
ix = 10 * i + 1
for j in range(n_img_per_row):
iy = 10 * j + 1
img[ix:ix + 8, iy:iy + 8] = X[i * n_img_per_row + j].reshape((8, 8))
plt.imshow(img, cmap=plt.cm.binary)
plt.xticks([])
plt.yticks([])
plt.title('A selection from the 64‐dimensional digits dataset')
## Computing PCA
print("Computing PCA projection")
t0 = time()
X_pca = decomposition.TruncatedSVD(n_components=2).fit_transform(X)
plot_embedding(X_pca,
"Principal Components projection of the digits (time %.2fs)" %
(time() ‐ t0))
## Computing t‐SNE
print("Computing t‐SNE embedding")
tsne = manifold.TSNE(n_components=2, init='pca', random_state=0)
t0 = time()
X_tsne = tsne.fit_transform(X)
plot_embedding(X_tsne,
"t‐SNE embedding of the digits (time %.2fs)" %
(time() ‐ t0))
plt.show()

116a56b7db93ebc18b3c34f0003e0a1f6bf1f5a9

468bdfdb8d8163443c8a338717b2519cccb27d72

9 应用方面

9.1数据科学家

对于数据科学家来说,使用t-SNE的主要问题是算法的黑盒类型性质。使用该算法的最佳方法是将其用于探索数据分析。

9.2机器学习骇客

将数据集缩减为2或3维,并使用非线性堆栈器将其堆叠。可以使用XGboost提高t-SNE向量以获得更好的结果。

9.3数据科学爱好者

对于开始使用数据科学的数据科学爱好者来说,这种算法在研究和性能增强方面提供了最好的机会。针对各种NLP问题和图像处理应用方面实施t-SNE的研究是一个尚未开发的领域。

10常见错误

以下是在解释 t-SNE 的结果时要避免的几个常见错误:

1 为了使算法正确执行,困惑度应小于点的数量。一般设置为5-50。

2 具有相同超参数的不同运行可能产生不同的结果。

3 任何t-SNE图中的簇大小不得用于标准偏差,色散或任何其他类似的评估。

4 簇之间的距离可以改变。一个茫然性不能优化所有簇的距离。

5 可以在随机噪声中找到模式。

6 不同的困惑水平可以观察到不同的簇形状。

7 不能基于单个t-SNE图进行分析拓扑,在进行任何评估之前必须观察多个图。

 

本文由北邮@爱可可-爱生活老师推荐,阿里云云栖社区组织翻译。

文章原标题《Comprehensive Guide on t-SNE algorithm with implementation in R & Python》,作者:Saurabh,译者:海棠

文章为简译,更为详细的内容,请查看原文

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PyTorch 是一种广泛使用的深度学习框架,用于神经网络模型的构建和训练。而 t-SNE(t-distributed stochastic neighbor embedding)是一种常用的降维和数据可视化方法。在 PyTorch 中,可以使用 t-SNE 对模型的特征进行可视化。 t-SNE 可以将高维特征空间中的数据映射到二维或三维空间,使得数据在可视化上更容易理解。在 PyTorch 中,通过提取模型中的特定层的输出,我们可以获得特征向量。然后,使用 t-SNE 将这些特征向量映射到低维空间。 首先,从模型中选择一个合适的层作为特征提取器。一般来说,选择中间的某一层作为特征提取器,以便获取模型学到的抽象特征。然后,将待可视化的数据输入模型中进行前向传播,获取特定层的输出。 接下来,使用 t-SNE 算法对这些特征进行降维。t-SNE 在计算中考虑样本之间的相似度,将高维特征映射到低维空间,以保留样本间的相对距离。PyTorch 提供了一些实现 t-SNE 算法的库,比如 sklearn 中的 t-SNE。 最后,通过绘制降维后的特征向量,可以在二维或三维空间中可视化数据。可以使用散点图或其他合适的可视化方法展示数据。通过观察可视化结果,可以更好地理解数据的分布和特征之间的关系。 总结来说,使用 PyTorch 和 t-SNE,我们可以将模型的特征可视化,从而更好地理解数据的结构和模型的学习情况。这可以帮助我们分析模型的性能,优化特征选择,以及在数据挖掘和机器学习任务中做出更准确的决策。 ### 回答2: T-SNE是一种降维和可视化的算法,可用于将高维特征映射到二维或三维空间,以便更好地理解和分析数据。 在PyTorch中,我们可以使用T-SNE对特征进行可视化。首先,我们需要获取模型中的特征。通过提取中间层的输出,我们可以获得具有较低维度的特征向量。 接下来,我们使用T-SNE算法将这些特征向量映射到二维平面。PyTorch提供了许多实现T-SNE的库,如scikit-learn或TSNE库。 然后,我们可以使用matplotlib等库将特征可视化。可以使用不同的颜色或符号表示不同的类别或类别之间的差异。 特征可视化可以帮助我们理解数据之间的关系,发现数据中的模式或异常,并为进一步的分析提供指导。例如,我们可以根据特征可视化的结果进行聚类或分类任务。 需要注意的是,T-SNE是一种非确定性算法,因此对于不同的运行,可能会导致稍微不同的结果。因此,在进行分析和解释时,应该综合考虑多次运行的结果。 总之,通过PyTorch和T-SNE,我们可以将高维特征映射到二维空间,并使用可视化来更好地理解和分析数据,辅助我们在机器学习或数据分析中的工作。 ### 回答3: PyTorch是一个流行的开源深度学习框架,而t-SNE则是一种常用的降维和可视化算法。 特征可视化是指将高维数据的特征表示转化为低维空间,并通过可视化工具将其呈现出来,以便更好地理解数据。 在PyTorch中,我们可以使用t-SNE算法对提取的特征进行降维和可视化。首先,我们使用预训练的深度学习模型,如卷积神经网络(CNN),提取数据集中每个样本的特征表示。接下来,我们将这些特征输入到t-SNE算法中,通过迭代计算寻找合适的低维表示。 在PyTorch中实现t-SNE的方法有很多,可以使用sklearn库中的t-SNE算法,或者使用开源的tsne库。这些库都提供了简单易用的接口,可以方便地将特征数据作为输入,得到相应的低维投影结果。 一旦得到了特征的低维表示,我们可以使用各种可视化工具(如Matplotlib或Plotly)来展示这些特征点的分布。例如,我们可以使用散点图将不同类别的特征点呈现在二维平面上,或者使用颜色和形状来表示不同的类别信息。通过可视化,我们可以更好地理解数据的分布情况,发现不同类别之间的关系,甚至发现异常点或噪声。 总之,PyTorch提供了强大的深度学习框架,而t-SNE算法则是特征可视化的一种常用工具。通过将两者结合使用,我们可以更好地理解数据的特征表示,从而为模型训练和数据分析提供更多的洞察。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值