how can imfill an image with a lot of edge?
Mostrar comentarios más antiguos
hi
I want to imfill an image of lung to have an image that shows me just left and right lung.. I obtain boundary of lung wit this cod that I attach
if true
function [perimImage] = filling( I )
s = uint8(255 * mat2gray(I));
s = im2bw(s);
perimImage = xor(s,imerode(s, true(3)));
figure, imshow(perimImage)
end end
when I use this code my result is like the image that I put.

I think it is a good result but when I use imfill, the result is this:

do you have any suggestion for me to have an image like this after using imfill?

be black or white is not important for me I just want to segment lung to the result that I say.. thanks
2 comentarios
Sean de Wolski
el 8 de Sept. de 2014
Editada: Sean de Wolski
el 8 de Sept. de 2014
Show us the original image; it might be easier to start with that for the original segmentation.
sara
el 8 de Sept. de 2014
Respuestas (2)
Image Analyst
el 8 de Sept. de 2014
Draw lines around the border of your binary image:
binaryImage(:,1) = true;
binaryImage(:,end) = true;
binaryImage(1,:) = true;
binaryImage(end,:) = true;
Now do a fill to fill the region between the border and the body.
binaryImage = imfill(binaryImage, 'holes');
Now do an imclearborder to get rid of all that and leave just the lung edges
binaryImage = imclearborder(binaryImage);
Now do a fill again to get the lungs filled.
lungsMask = imfill(binaryImage, 'holes');
And you're basically done. If there is any small blobs remaining, use my ExtractNLargestBlobs function (attached) to extract just the 2 largest blobs, which will be the lungs.
14 comentarios
Image Analyst
el 8 de Sept. de 2014
sara: Try the m-file attached below this image that it creates:

sara
el 9 de Sept. de 2014
Editada: Image Analyst
el 9 de Sept. de 2014
Image Analyst
el 9 de Sept. de 2014
There is no reason why my code, or yours, should not read in a jpg image and use it the way we coded. For your code, what does this show in the command window:
recalledImage = imread('fullFileName.tiff');
min(recalledImage) % No semicolon.
max(recalledImage)
Image Analyst
el 9 de Sept. de 2014
So it's a 16 bit image. Why is it all black? Where is it all black? Because when we see that the max is around 65 thousand, that's clearly not saying it's all black. Attach your tiff image.
sara
el 9 de Sept. de 2014
sara
el 10 de Sept. de 2014
Image Analyst
el 11 de Sept. de 2014
Editada: Image Analyst
el 11 de Sept. de 2014
You'll have to come up with a way to threshold it properly, but other than that it should work. I don't know why you have jpg images though. Who degraded the original images by storing as jpg? And WHY? Why do that? It's best to do image analysis on high quality images, not ones with compression artifacts in them.
Do you think the answer was good enough for you to officially "Accept"?
Image Analyst
el 12 de Sept. de 2014
It should not be too hard since there should be a huge hump around black. Let me know if you have trouble.
Image Analyst
el 14 de Sept. de 2014
It's not a "hole" but more of a "bay" because that region is actually a white region that is an incursion from the bright outer body into the lung. If you want to smooth the boundary you need to use active contours. This will "cut off" that bay. I'm attaching an example.
sara
el 11 de Sept. de 2014
0 votos
2 comentarios
Salma Hassan
el 20 de Mayo de 2017
how did you get figure 4 (lungs only )
Image Analyst
el 20 de Mayo de 2017
Categorías
Más información sobre Convert Image Type en Centro de ayuda y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


