Binary Image: Count number of pixels that are 1.

9 visualizaciones (últimos 30 días)
Justine Schneider
Justine Schneider el 3 de Jul. de 2017
Comentada: Image Analyst el 1 de Feb. de 2022
The code below is a simplified version of the one part of a longer code that I am running into an error. In the code below, I successfully convert the gray scale image into a binary image. Then I try to count the number of pixels in the image that are 1 (by using the for loop and bin()). However, MATLAB says, "Undefined function or variable 'rows'." Then if I type a number instead of saying rows columns, I get the error, "if bin(i,j) == 1."
I've looked at the syntax of the bin command, and I have tried problem solving this. However, I don't know if the for loop knows to apply itself to the image. Please let me know how I can fix this for loop to work properly.
Code:
I = imread('rice.png');
figure; imshow(I);
bw = imbinarize(I);
figure; imshow(bw);
ctr= 0;
for i = 1 : rows
for j = 1 : columns
if bin(i,j) == 1
ctr = ctr + 1;
end
end
end

Respuesta aceptada

Andrei Bobrov
Andrei Bobrov el 3 de Jul. de 2017
May be so:
I = imread('rice.png');
figure; imshow(I);
bw = imbinarize(I);
figure; imshow(bw);
ctr= 0;
for i = 1 : rows
for j = 1 : columns
if bw(i,j) == 1
ctr = ctr + 1;
end
end
end
  8 comentarios
oussama zayene
oussama zayene el 1 de Feb. de 2022
Did you resolve this, if yes can you please share the code ?
Thanks
Image Analyst
Image Analyst el 1 de Feb. de 2022
I'm sure that after almost 2 years he did. It probably went something like this:
props = regionprops(bw, 'BoundingBox');
for k = 1 : numel(props)
thisBB = props(k).BoundingBox;
croppedImage = imcrop(bw, thisBB);
% Now do something with cropped image.....
end

Iniciar sesión para comentar.

Más respuestas (4)

Jan
Jan el 3 de Jul. de 2017
Alternatively without a loop:
bw = imbinarize(I);
ctr = sum(bw(:) == 1);
or even shorter for a binary image:
ctr = sum(bw(:));

James Tursa
James Tursa el 6 de Abr. de 2020
nnz(bw)

Image Analyst
Image Analyst el 4 de Feb. de 2018
Editada: Image Analyst el 1 de Feb. de 2022
If you want to know why your code didn't work, the problem with your code is that you forgot to define rows and columns for your image. After imread(), you need this:
[rows, columns, numberOfColorChannels] = size(I);
But better, like Jan said, you can simply could the number of white/true/1 pixels with this:
numWhite = sum(BW(:)) % numWhite is what you called ambiguously called ctr ("counter", "centroid"?)
No nested for loop is even needed.
Or even better is @James Tursa's answer:
numWhite = nnz(bw);

bipul
bipul el 23 de Sept. de 2018
Editada: bipul el 23 de Sept. de 2018
function ctr = PixelCounter(bw)
%I = imread('rice.png');
%I = I(4:15, 18:29);
%figure; imshow(I);
%bw = im2bw(I)
%figure; imshow(bw);
ctr= 0;
[rows columns] = size(bw);
for i = 1 : rows
for j = 1 : columns
if bw(i,j) == 1
ctr = ctr + 1;
end
end
end
%fprintf('1 are: %d \n', ctr);
%disp(ctr);
end
  1 comentario
Image Analyst
Image Analyst el 23 de Sept. de 2018
Editada: Image Analyst el 1 de Feb. de 2022
Hopefully you don't also do this. The preferred way is to use nnz() like @James Tursa showed.

Iniciar sesión para comentar.

Categorías

Más información sobre Images en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by