Silhouette plot and fuzzy c-means

2 visualizaciones (últimos 30 días)
med-sweng
med-sweng el 31 de Dic. de 2013
Comentada: Walter Roberson el 31 de Dic. de 2013
I'm trying to use Silhouette plot with fuzzy c-means in a way similar to the example here.
The case is that my data is in the form of an image.
When I did the following:
I=imread('img.png');
[center,U,obj_fcn] = fcm(I, 2);
I got the following error:
Error using *
MTIMES is not fully supported for integer classes. At least one input
must be scalar.
To compute elementwise TIMES, use TIMES (.*) instead.
Error in stepfcm (line 25)
center = mf*data./((ones(size(data, 2), 1)*sum(mf'))'); % new center
Error in fcm (line 88)
[U, center, obj_fcn(i)] = stepfcm(data, U, cluster_n, expo);
Thanks.
EDIT
The example link is here: http://www.mathworks.com/help/stats/silhouette.html (create Silhouette plot)

Respuestas (1)

Walter Roberson
Walter Roberson el 31 de Dic. de 2013
[center,U,obj_fcn] = fcm(double(I), 2);
  2 comentarios
med-sweng
med-sweng el 31 de Dic. de 2013
Editada: Walter Roberson el 31 de Dic. de 2013
I'm trying to follow the example here. http://www.mathworks.com/help/stats/silhouette.html (Create silhouette plot). This is why I showed the way I showed in my example.
But, when I use the way you have showed, are there any changes to do in order to plot the Silhouette?
Walter Roberson
Walter Roberson el 31 de Dic. de 2013
The sample code you are looking at creates data using rand(), which generates floating point data. You created your data using imread(), which is going to result in some integer data type, typically uint8. fcm() is not designed to be able to operate on integer data types, so pass in the double precision equivalent of the integers by calling double() on the data as I showed.
You might have to pass double(I) into silhouette() but you could try it.

Iniciar sesión para comentar.

Categorías

Más información sobre Fuzzy Logic Toolbox en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by