K-means for a grayscale image

5 ビュー (過去 30 日間)
anusha reddy
anusha reddy 2016 年 5 月 29 日
編集済み: Image Analyst 2021 年 6 月 27 日
I've tried the below code to cluster the grayscale image,
I = imread('sym_059.tif');
I = im2double(I);
c = kmeans(I, 3);
p = reshape(c, size(I));
executing this code, I am getting error as follows "Error using reshape-To RESHAPE the number of elements must not change." How can I debug this.? Help appreciated.
  8 件のコメント
Walter Roberson
Walter Roberson 2018 年 10 月 24 日
imshow(uint8(p))
Image Analyst
Image Analyst 2018 年 10 月 24 日
Try my code (hidden in the comments above), NOT the code that anusha says there is a problem with.

サインインしてコメントする。

採用された回答

Walter Roberson
Walter Roberson 2016 年 5 月 29 日
kmeans returns a vector of cluster indices, one index per row of input. You are trying to reshape that as if it had as many entries as the number of pixels in your image.
Possibly you want to try
c = kmeans(I(:), 3);
  21 件のコメント
Salma Hassan
Salma Hassan 2021 年 6 月 27 日
編集済み: Image Analyst 2021 年 6 月 27 日
What about several images? How can I cluster them into k clusters?
Walter Roberson
Walter Roberson 2021 年 6 月 27 日
Provided the images are the same number of pixels, and are all RGB or are all grayscale, then construct an array in which each row is reshape() of an image into a single row, and the rows correspond to different images. Then kmeans() .
This would attempt to cluster the images as a whole into clusters.

サインインしてコメントする。

その他の回答 (1 件)

Image Analyst
Image Analyst 2021 年 4 月 16 日

カテゴリ

Help Center および File ExchangeImages についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by