Contents
leer la imagen
I=imread('Tuto_1.bmp'); figure; imshow(I); title('imagen original')
data:image/s3,"s3://crabby-images/3e409/3e40953c417da10bb10c7b683634fae63a2ba6ae" alt=""
Obtenemos el threshold en el calculo de los contornos
[Iedge, threshold] = edge(I, 'sobel'); figure; imshow(Iedge); title('contornos')
data:image/s3,"s3://crabby-images/0555e/0555e0759539fba5088e27238918fac3edf868f4" alt=""
Reducimos el nivel de umbral y repetimos el calculo
Iedge2 = edge(I,'sobel', threshold * 0.75); figure; imshow(Iedge2); title('contornos reduciendo thres el 75%')
data:image/s3,"s3://crabby-images/d799a/d799a378518a47b91927aaaf4183b394176f31b9" alt=""
Definimos los elementos estructurales para limpiar la imagen
BW=Iedge2; % Una linea vertical de 3 pixels se90 = strel('line', 3, 90); % Una linea horizontal de 3 pixels se0 = strel('line', 3, 0);
Hacemos una dilaticion
BWdilate = imdilate(BW, [se90 se0]);
figure; imshow(BWdilate); title('imagen dilatada')
data:image/s3,"s3://crabby-images/f4175/f41758ec491d0bfe8c23763834e29ab886fe82dc" alt=""
Limpiamos el borde de la imagen
BWnobord = imclearborder(BWdilate, 4);
figure; imshow(BWnobord); title('limpiar el borde')
data:image/s3,"s3://crabby-images/e943b/e943bf1433e6a5052297b9929b0db56f9cea89aa" alt=""
Eliminamos elementos menores de 200 pixels
BWopen = bwareaopen(BWnobord,200);
figure; imshow(BWopen); title('eliminar objetos pequeños')
data:image/s3,"s3://crabby-images/8d8e7/8d8e7dd2b8a8dc34a813d3b00927aeb53fc4c21c" alt=""
Aplicamos un cierre
BWclose = bwmorph(BWopen,'close'); figure; imshow(BWclose); title('aplicar un cierre')
data:image/s3,"s3://crabby-images/7c093/7c0934fc901fbfa7155ab41de8b1413bde153da3" alt=""
Rellenamos los huecos
BWfill = imfill(BWclose, 'holes'); figure; imshow(BWclose); title('rellenar huecos');
data:image/s3,"s3://crabby-images/c17aa/c17aae4ea32f849c8f2753552f10a53ae52671ac" alt=""
Nos quedamos con el perimetro de los objetos
BWoutline = bwperim(BWfill);
imshow(BWoutline)
figure; imshow(BWoutline); title('quedarnos con el perimetro')
data:image/s3,"s3://crabby-images/fe1d2/fe1d23bf24f8275cd55bbf8f6297952e57ff8382" alt=""
data:image/s3,"s3://crabby-images/3f067/3f067773784bc2d07cddfb658ae66554113cf8aa" alt=""
Sobre la imagen original superponemos el perimetro
segmentedCells = I;
segmentedCells(BWoutline) = 255;
figure; imshow(segmentedCells); title('resultado final')
data:image/s3,"s3://crabby-images/7ffad/7ffadad1f97dd6a926474cf6897e0f15995f1fb7" alt=""