El agrupamiento difuso (en inglés, fuzzy clustering) es una clase de algoritmos de agrupamiento
donde cada elemento tiene un grado de pertenencia difuso a los grupos.
Este tipo de algoritmos surge de la necesidad de resolver una deficiencia del agrupamiento exclusivo,
que considera que cada elemento se puede agrupar inequívocamente con los elementos de su cluster y
que, por lo tanto, no se asemeja al resto de los elementos. Tras la introducción de la lógica difusa por
Zadeh en 1965 surgió una solución para este problema, caracterizando la similitud de cada elemento a cada uno de los grupos.
[1]
Esto se logra representando la similitud entre un elemento y un grupo por una función,
llamada función de pertenencia, que toma valores entre cero y uno. Los valores cercanos
a uno indican una mayor similitud, mientras que los cercanos a cero indican una menor similitud.
Por lo tanto, el problema del agrupamiento difuso se reduce a encontrar una caracterización de este tipo que sea óptima.
Los algoritmos de agrupamiento difuso se han aplicado ampliamente en diferentes áreas como el procesamiento
de imágenes, sistemas de ingeniería, estimación de parámetros, entre otras.
[2]
Partición difusa
Una partición difusa es una partición que caracteriza la participación de cada muestra en todos
los grupos utilizando funciones de pertenencia que toman valores entre cero y uno. Además, cumplen que
para cada muestra la suma de sus participaciones en cada grupo es uno.
De esta forma, es posible traducir el problema del agrupamiento difuso en encontrar una partición difusa óptima.
A continuación se encuentra una definición más formal de este concepto.
Sea X = (x1,...,xn) un subconjunto de un espacio euclidiano de dimensión s
y c un entero positivo mayor que uno.
Una partición difusa de X en c grupos es una tupla de c funciones de pertenencia
que cumplen que:
Las particiones difusas se representan como una matriz asociando cada fila a uno de los c grupos
y cada columna a uno de los elementos de X, de forma tal que el valor en la fila i y la columna j
indique la pertenencia del elemento j al grupo i.
Más formalmente, el conjunto de las particiones difusas se puede definir como:
Algoritmos Fuzzy c-Means
Los algoritmos Fuzzy c-Means son algunos de los principales algoritmos utilizados en el
agrupamiento difuso y pertenecen a una clase de algoritmos basados en funciones objetivo.[2]
Estos algoritmos definen un criterio de agrupamiento en la forma de una función objetivo que depende de la partición difusa.
El procedimiento, en sentido general, consiste en minimizar iterativamente esta función hasta
obtener una partición difusa óptima.
Se han propuesto varios criterios de agrupamiento para obtener la partición difusa óptima para X,
pero el más popular hasta el momento está asociado con la función de error mínimo cuadrático:[1]
El valor indica la distancia cuadrada entre los elementos de X y
los centros de los grupos y puede calcularse utilizando la siguiente fórmula:
donde:
- son los datos,
- es el vector centro del grupo i,
- || ||A es la norma inducida por A
- A es una matriz definida positiva de pesos de dimensiones .
En particular, si A es la matriz identidad, es el cuadrado de la distancia euclidiana.
El peso asociado a cada distancia cuadrada, , es
la m-ésima potencia del grado de pertenencia del k-ésimo dato al grupo i.
Cuando la partición óptima es cada vez más cercana
a una partición exclusiva, mientras que cuando la
partición óptima se aproxima a la matriz con todos sus valores iguales a (1/c).
Los valores de m que normalmente se utilizan son valores en el intervalo [1,30].
Cada selección de un valor particular de m marca un algoritmo Fuzzy c-Means específico.[1]
Teniendo esto en cuenta, el procedimiento general de los algoritmos Fuzzy c-Means
puede formalizarse en los siguientes pasos:
- Fijar c, m, A y ||k||A. Elegir una matriz inicial .
- Calcular los centros de los grupos con la fórmula .
- Actualizar la matriz de partición difusa U = [uik] con .
- Si se alcanzó el criterio de parada, terminar. En caso contrario, regresar al paso 2.
Algunos de los criterios de parada más utilizados son:[1]
- Un número máximo de iteraciones
- Que la variación en la matriz U sea muy pequeña:
.
Algoritmos Possibilistic c-Means
Los algoritmos Possibilistic c-Means aparecen con el objetivo de resolver el mal comportamiento
de los algoritmos Fuzzy c-Means al ser utilizados en conjuntos de datos con mucho ruido.
[3]
Estos algoritmos se caracterizan por interpretar los valores uij como grados de compatibilidad con
los grupos, en lugar de probabilidades de pertenencia. Para ello, se relaja la restricción de las particiones
difusas que obliga a que la suma de los grados de pertenencia de un elemento hacia todos los grupos sea uno,
exigiendo solamente que al menos uno de los grados de pertenencia sea positivo.
Por lo tanto, las restricciones en la definición de partición difusa podrían reescribirse como:
Una de las funciones objetivos más utilizadas por estos algoritmos es la siguiente:[3]
Esta es la misma función objetivo de los algoritmos Fuzzy c-Means con un término añadido que impide
que la partición obtenida sea la solución trivial donde todos los valores de pertenencia sean iguales a cero.
El vector es un vector de valores positivos, donde sus valores
denotan la distancia desde el centro del grupo i a la que el grado de pertenencia de un
elemento es 0.5. Estos valores determinan el tamaño y forma de sus grupo correspondiente y generalmente se calculan
utilizando la siguiente fórmula:[3]
donde K es normalmente uno.
El procedimiento general para estos algoritmos es:
- Fijar c, m, A y ||k||A. Elegir una matriz inicial . Estimar los valores de .
- Calcular los centros de los grupos con la fórmula .
- Actualizar la matriz de partición difusa U = [uik] con .
- Si se alcanzó el criterio de parada, terminar. En caso contrario, regresar al paso 2.
Los criterios de parada utilizados por estos algoritmos son similares a los utilizados
por los algoritmos Fuzzy c-Means.
Puede consultar también
Referencias
- ↑ a b c d Bezdek, James C.; Ehrlich, Robert; Full, William (1984). «FCM: The Fuzzy c-Means Clustering Algorithm». Computers & Geosciences 10 (2-3): 191-203.
- ↑ a b Yang, M. S. (1993). «A Survey of Fuzzy Clustering». Mathl. Comput. Modelling 18 (11): 1-16. Archivado desde el original el 15 de diciembre de 2013. Consultado el 6 de diciembre de 2013.
- ↑ a b c Krishnapuram, Raghu; Keller, James M. (mayo de 1993). «A Possibilistic Approach to Clustering». IEEE Transactions on Fuzzy Systems 1 (2).