模糊C均值聚类简述

模糊C均值聚类简述

By:Yang Liu
1.什么是模糊C均值聚类
模糊c-均值聚类算法 fuzzy c-means algorithm (FCMA)或称( FCM)。通过优化目标函数得到每个样本点对所有类中心的隶属度,从而决定样本点的类属以达到自动对样本数据进行分类的目的。无监督机器学习的主要技术之一。
2.模糊C均值聚类涉及的数学方法——拉格朗日乘数法
设给定二元函数z=ƒ(x,y)和附加条件φ(x,y)=0,为寻找z=ƒ(x,y)在附加条件下的极值点,先做拉格朗日函数 F ( x , y , λ ) = f ( x , y ) + λ φ ( x , y ) F(x,y,\lambda ) = f(x,y) + \lambda \varphi (x,y) F(x,y,λ)=f(x,y)+λφ(x,y),其中λ为参数。
令F(x,y,λ)对x和y和λ的一阶偏导数等于零,即
F’(x)=ƒ’x(x,y)+λφ’x(x,y)=0
F’(y)=ƒ’y(x,y)+λφ’y(x,y)=0
F’(λ)=φ(x,y)=0
由上述方程组解出x,y及λ,如此求得的(x,y),就是函数z=ƒ(x,y)在附加条件φ(x,y)=0下的可能极值点。
若这样的点只有一个,由实际问题可直接确定此即所求的点。
3.模糊C均值聚类的过程简述
隶属度函数是表示一个对象x隶属于集合A的程度的函数,其自变量范围是所有可能属于集合A的对象,取值范围是[0,1]。用 u u u表示。
模糊C均值聚类,需要两个参数一个是聚类数目,另一个是一个控制算法的柔性的参数
算法的输出是聚类中心点向量和一个模糊划分矩阵,这个矩阵表示的是每个样本点属于每个类的隶属度。根据这个划分矩阵按照模糊集合中的最大隶属原则就能够确定每个样本点归为哪个类,聚类中心表示的是每个类的平均特征,可以认为是这个类的代表点。
步骤1:用值在0,1间的随机数初始化隶属矩阵U,使其满足约束条件
步骤2:计算c个聚类中心ci,i=1,…,c。
步骤3:计算价值函数。如果它小于某个确定的阀值,或它相对上次价值函数值的改变量小于某个阀值,则算法停止。
步骤4:计算新的U矩阵。返回步骤2。
在这里插入图片描述
4.数学推导过程
此时要求的就是价值函数的最小值;进而变成求在隶属度函数的和为1的条件下,价值函数最小的条件极值问题。
价值函数J: J = ∑ i = 1 c ∑ j = 1 n u i j m d i j J = \sum\limits_{i = 1}^c {\sum\limits_{j = 1}^n {u_{ij}^m{d_{ij}}} } J=i=1cj=1nuijmdij 其中c表示分成了几簇,n表示n个样本,d表示样本到对应样本中心的距离,u表示隶属度函数。
条件极值的条件是: u i = 1 {u_i} = 1 ui=1
构造拉格朗日函数: J = ∑ i = 1 c ∑ j = 1 n u i j m d i j + ∑ j = 1 n λ j ( ∑ i = 1 c u i j − 1 ) J = \sum\limits_{i = 1}^c {\sum\limits_{j = 1}^n {u_{ij}^m{d_{ij}}} } + \sum\limits_{j = 1}^n {{\lambda _j}(\sum\limits_{i = 1}^c {{u_{ij}} - 1} )} J=i=1cj=1nuijmdij+j=1nλj(i=1cuij1)
对变量u和c求导;
对c求导有: ∂ J ∂ c k = ∑ i = 1 c ∑ j = 1 n ∂ u i j m d i j ∂ c k − ∂ ∑ j = 1 n λ j ( ∑ i = 1 c u i j − 1 ) ∂ c k \frac{{\partial J}}{{\partial {c_k}}} = \sum\limits_{i = 1}^c {\sum\limits_{j = 1}^n {\frac{{\partial u_{ij}^m{d_{ij}}}}{{\partial {c_k}}} - \frac{{\partial \sum\limits_{j = 1}^n {{\lambda _j}(\sum\limits_{i = 1}^c {{u_{ij}} - 1} )} }}{{\partial {c_k}}}} } ckJ=i=1cj=1nckuijmdijckj=1nλj(i=1cuij1)
其中 ∂ ∑ j = 1 n λ j ( ∑ i = 1 c u i j − 1 ) ∂ c k = 0 \frac{{\partial \sum\limits_{j = 1}^n {{\lambda _j}(\sum\limits_{i = 1}^c {{u_{ij}} - 1} )} }}{{\partial {c_k}}} = 0 ckj=1nλj(i=1cuij1)=0

则有 ∂ J ∂ c k = ∑ i = 1 c ∑ j = 1 n ∂ u i j m d i j ∂ c k = ∑ i = 1 c ∑ j = 1 n u i j m ∂ d i j ∂ c k = u k j m ∑ j = 1 n ∂ d i j ∂ c k = 0 \frac{{\partial J}}{{\partial {c_k}}} = \sum\limits_{i = 1}^c {\sum\limits_{j = 1}^n {\frac{{\partial u_{ij}^m{d_{ij}}}}{{\partial {c_k}}} = } } \sum\limits_{i = 1}^c {\sum\limits_{j = 1}^n {u_{ij}^m\frac{{\partial {d_{ij}}}}{{\partial {c_k}}} = } } u_{kj}^m\sum\limits_{j = 1}^n {\frac{{\partial {d_{ij}}}}{{\partial {c_k}}} = } 0 ckJ=i=1cj=1nckuijmdij=i=1cj=1nuijmckdij=ukjmj=1nckdij=0
由于d是c和x的距离,且倒数最后为0,则非零的系数可以去掉。
最后变成关于c和x的等式,有 ∑ j = 1 n u k m c k − ∑ j = 1 n u k m x j = 0 \sum\limits_{j = 1}^n {u_k^m{c_k}} - \sum\limits_{j = 1}^n {u_k^m{x_j}} = 0 j=1nukmckj=1nukmxj=0,
最终得到 c k = ∑ j = 1 n u k j m x j ∑ j = 1 n u k j m {c_k} = \frac{{\sum\limits_{j = 1}^n {u_{kj}^m{x_j}} }}{{\sum\limits_{j = 1}^n {u_{kj}^m} }} ck=j=1nukjmj=1nukjmxj
对隶属函数u进行求导: ∂ J ∂ u i j = ∑ j = 1 n ∑ i = 1 c m u i j m − 1 d i j + ∑ j = 1 n c λ j = ∑ j = 1 n ( ∑ i = 1 c m u i j m − 1 d i j + c λ j ) = 0 \frac{{\partial J}}{{\partial {u_{ij}}}} = \sum\limits_{j = 1}^n {\sum\limits_{i = 1}^c {mu_{ij}^{m - 1}{d_{ij}} + \sum\limits_{j = 1}^n {c{\lambda _j}} } } = \sum\limits_{j = 1}^n {(\sum\limits_{i = 1}^c {mu_{ij}^{m - 1}{d_{ij}}} + c{\lambda _j}) = 0} uijJ=j=1ni=1cmuijm1dij+j=1ncλj=j=1n(i=1cmuijm1dij+cλj)=0
∑ i = 1 c m u i j m − 1 d i j + c λ j = ∑ i = 1 c ( m u i j m − 1 d i j + λ j ) = 0 \sum\limits_{i = 1}^c {mu_{ij}^{m - 1}{d_{ij}}} + c{\lambda _j} = \sum\limits_{i = 1}^c {(mu_{ij}^{m - 1}{d_{ij}}} + {\lambda _j}) = 0 i=1cmuijm1dij+cλj=i=1c(muijm1dij+λj)=0因为上式中括号函数大于等于零,
所以 m u i j m − 1 d i j + λ j = 0 mu_{ij}^{m - 1}{d_{ij}} + {\lambda _j} = 0 muijm1dij+λj=0
u i j = ( − λ j m d i j ) 1 m − 1 {u_{ij}} = {(\frac{{ - {\lambda _j}}}{{m{d_{ij}}}})^{\frac{1}{{m - 1}}}} uij=(mdijλj)m11
由于 ∑ k = 1 c u k j = 1 \sum\limits_{k = 1}^c {{u_{kj}} = 1} k=1cukj=1
可得 ∑ k = 1 c ( − λ j m d k j ) 1 m − 1 = 1 \sum\limits_{k = 1}^c {{{(\frac{{ - {\lambda _j}}}{{m{d_{kj}}}})}^{\frac{1}{{m - 1}}}}} = 1 k=1c(mdkjλj)m11=1
进而有 ( − λ i m ) 1 m − 1 = 1 ∑ k = 1 c ( 1 d k j ) 1 m − 1 {(\frac{{ - {\lambda _i}}}{m})^{\frac{1}{{m - 1}}}} = \frac{1}{{\sum\limits_{k = 1}^c {{{(\frac{1}{{{d_{kj}}}})}^{\frac{1}{{m - 1}}}}} }} (mλi)m11=k=1c(dkj1)m111
最终可得 u i j = 1 ∑ k = 1 c ( d i j d k j ) 1 m − 1 {u_{ij}} = \frac{1}{{\sum\limits_{k = 1}^c {{{(\frac{{{d_{ij}}}}{{{d_{kj}}}})}^{\frac{1}{{m - 1}}}}} }} uij=k=1c(dkjdij)m111.
参考文献:
(1)https://wenku.baidu.com/view/ee968c00eff9aef8941e06a2.html
(2)https://blog.csdn.net/shaoyu_hlq/article/details/56488204
(3)https://www.cnblogs.com/wxl845235800/p/11046248.html

  • 5
    点赞
  • 52
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值