zoukankan      html  css  js  c++  java
  • 机器学习(六)K-means聚类、密度聚类、层次聚类、谱聚类

    本文主要简述聚类算法族。聚类算法与前面文章的算法不同,它们属于非监督学习。

    1、K-means聚类

    记k个簇中心,为(mu_{1}),(mu_{2}),...,(mu_{k}),每个簇的样本数为(N_{i})
    假设每个簇中的数据都满足分布(N(mu_{i},sigma)),即方差相同,均值不同的GMM。
    则每一个样本点的分布函数为:$$phi_{i}=dfrac{1}{sqrt{2pisigma2}}exp(-dfrac{({x_{i}-mu})2}{2sigma^2})$$
    可求出其似然函数

    [L_{mu}=phi_{1} imesphi_{2} imes... ]

    且可求其对数似然为(以三个点为例)

    [l_{mu}=dfrac{1}{2}sum^{k}_{j=1}sum^{i=1}_{N_{j}}(x_{I}-mu_{j})^2 ]

    求驻点有:$$mu_{j}=dfrac{1}{N_{j}}sum^{N}{i=1}x{i}$$
    因此,以均方误差为目标函数的时候肯定是收敛的。用其他函数作为目标函数不一定收敛。

    注:(k)的选择采用“手肘法”,注意不是交叉验证,它连标签都没有!

    2、密度聚类

    代表算法:DBSCAN

    K-means对噪声敏感,密度聚类对噪声不敏感。

    3、层次聚类

    按层次聚类,由上至下或由下至上,优点是可以任意选择聚类数

    4、谱聚类

    Step1:对样本点俩俩计算相似度(S_{ij}),组成相似度矩阵,又称权值矩阵$$W_{n imes n}=[S_{ij}]$$

    Step2:将(W_{n imes n})的主对角线元素全部置为0,把每行元素的值相加,第(i)行的和为(d_{i})。将(d_{i})作为主对角线元素组成(D_{n imes n})

    Step3:令$$L_{n imes n}=D_{n imes n}-W_{n imes n}$$,称为拉普拉斯矩
    阵。这个(L)是半正定的,它最小的特征值为0。

    Step4:求L矩阵的特征值和特征向量,将所有特征值从小大排列,取出前k个(聚类数为k),将其对应的特征向量如下排列:$$[u_{1},u{2},...,u_{k}]$$该矩阵的第一行即为第一个样本点转换后的特征,第二行为第二个样本点转换后的特征。将这些特征扔入K_means,其聚类结果即是谱聚类结果。

  • 相关阅读:
    预处理命令
    函数
    结构体
    字符数组
    数组
    文件
    用 typedef 定义类型
    枚举类型
    联合
    位运算
  • 原文地址:https://www.cnblogs.com/Yolanda7171/p/7242344.html
Copyright © 2011-2022 走看看