Segmentación pulmonar de MatLab: 5 pasos
Segmentación pulmonar de MatLab: 5 pasos
Anonim
Segmentación pulmonar MatLab
Segmentación pulmonar MatLab

Por: Phuc Lam, Paul Yeung, Eric Reyes

Reconocer que los errores en la segmentación de los pulmones producirán información falsa con respecto a la identificación de un área patológica y pueden afectar directamente el proceso de diagnóstico. Las técnicas modernas de ayuda informática no lograron obtener resultados precisos cuando las enfermedades pulmonares tienen formas desafiantes. Estas formas anormales pueden ser causadas por derrames pleurales, consolidaciones, etc. Al aplicar la técnica de segmentación pulmonar, en la que los límites del pulmón se aíslan del tejido torácico circundante, nuestra aplicación puede identificar los límites con los umbrales de entrada del usuario para brindar vistas totalmente personalizables. de las formas de los pulmones, El propósito de este proyecto MatLab es crear una aplicación interactiva de segmentación pulmonar fácil de usar para detectar condiciones patológicas de las imágenes de rayos X de los pulmones. Nuestro objetivo es crear una forma más eficaz de ilustrar e identificar pulmones anormales a fin de ofrecer a los médicos y radiólogos una forma más fiable de diagnosticar enfermedades pulmonares. Usando la herramienta de diseño de aplicaciones en MatLab, el programa está diseñado para funcionar específicamente con radiografías de tórax y tomografías computarizadas (TC), pero también está probado para funcionar con imágenes por resonancia magnética.

Las instrucciones a continuación contienen nuestra técnica de filtrado de ruido (filtro Wiener de paso bajo), así como el umbral de la imagen (usando el histograma de intensidad de la imagen en escala de grises) y usando un gradiente morfológico (la diferencia entre la dilatación y la erosión de una imagen) para identificar una región de interés. Luego, la instrucción explicará cómo integramos todos los elementos en la interfaz gráfica de usuario (GUI).

Nota:

1). Este proyecto está inspirado en un trabajo de investigación: "Segmentación y análisis de imágenes de pulmones anormales en CT: enfoques actuales, desafíos y tendencias futuras". Que se puede encontrar aquí

2). Estamos utilizando imágenes de rayos X de NIH: Clinical Center. El enlace se puede encontrar aquí

3). La ayuda del diseñador de aplicaciones se puede encontrar aquí

4). Antes de ejecutar el código: debe cambiar la ruta Dir (en la línea 34) a su directorio de archivos y el tipo de imagen (línea 35) (estamos analizando *.png).

Paso 1: Paso 1: carga de la imagen

Paso 1: carga de la imagen
Paso 1: carga de la imagen

Este paso le mostrará la imagen original en escala de grises. Cambie 'name_of_picture.png' por el nombre de su imagen

claro; clc; cierra todo;

%% Cargando imágenes

raw_x_ray = 'nombre_de_imagen.png';

I = imread (raw_x_ray);

figura (101);

imshow (yo);

mapa de colores (gris);

título ('Rayos X en escala de grises');

Paso 2: Paso 2: Filtrado de ruido e histograma

Paso 2: filtrado de ruido e histograma
Paso 2: filtrado de ruido e histograma

Para encontrar el umbral de la imagen en escala de grises, miramos el histograma para ver si hay modos distintos. Leer más aquí

I = wiener2 (I, [5 5]);

figura (102);

subtrama (2, 1, 1);

imshow (yo);

subtrama (2, 1, 2);

imhist (I, 256);

Paso 3: Paso 3: Establecer umbrales

Paso 3: Establecer umbrales
Paso 3: Establecer umbrales
Paso 3: Establecer umbrales
Paso 3: Establecer umbrales

Este paso le permite establecer el umbral de acuerdo con el histograma. morphologicalGradient resaltará la región de interés en rojo, y la función visboundary se superpone a la imagen delineada y filtrada del pulmón en rojo.

Mediante el uso de regionprops, podemos obtener las matrices de solidez y ordenarlas de forma descendente. A continuación, binarizo la imagen de sclae gris y aplico el método de gradiente morfológico y mLoren Shurasking para resaltar la región de interés (ROI). El siguiente paso es invertir la imagen para que el ROI del pulmón sea blanco sobre fondo negro. Utilizo la función showMaskAsOverlay para mostrar 2 máscaras. Nota: el código está inspirado en Loren Shure, enlace.

Por último, creo un contorno rojo usando los límites bwbw y enmascarando la imagen del filtro y los límites.

a_thresh = I> = 172; % establece este umbral

[labelImage, numberOfBlobs] = bwlabel (a_thresh);

props = regionprops (a_thresh, 'todos');

sortedSolidity = sort ([props. Solidity], 'descender');

SB = sortedSolidity (1);

si SB == 1% SB solo acepta solidez == 1 filtra los huesos

binaryImage = imbinarize (I); figura (103);

imshow (binaryImage); mapa de colores (gris);

SE = strel ('cuadrado', 3);

morphologicalGradient = imsubtract (imdilate (binaryImage, SE), imerode (binaryImage, SE));

mask = imbinarize (morphologicalGradient, 0.03);

SE = strel ('cuadrado', 2);

máscara = imclose (máscara, SE);

mask = imfill (máscara, 'agujeros');

mask = bwareafilt (máscara, 2); % de control del número de área mostrada

notMask = ~ máscara;

máscara = máscara | bwpropfilt (notMask, 'Área', [-Inf, 5000 - eps (5000)]);

showMaskAsOverlay (0.5, máscara, 'r'); % tienes que descargar la aplicación / función showMaskAsOverlay

BW2 = imfill (binaryImage, 'agujeros');

nueva_imagen = BW2;

nueva_imagen (~ máscara) = 0; % fondo invertido y agujeros

B = bwboundary (nueva_imagen); % solo puede aceptar 2 dimensiones

figura (104);

imshow (nueva_imagen);

esperar

límites fronterizos (B);

fin

Paso 4: creación de GUI

Ahora, integramos el código anterior en una aplicación MATLAB. Abra el Diseñador de aplicaciones en MATLAB (Nuevo> Aplicación). Primero, diseñamos la interfaz haciendo clic, manteniendo presionado y arrastrando tres ejes al espacio de trabajo central. A continuación, hacemos clic, mantén presionado y arrastramos dos botones, un campo de edición (texto), un campo de edición (numérico), un control deslizante y un menú desplegable. Dos ejes mostrarán cada uno la vista previa y analizarán la imagen, y el tercer eje mostrará un histograma de píxeles para la imagen "seleccionada" de vista previa. El cuadro del campo de edición (texto) mostrará la ruta del archivo de la imagen seleccionada y el campo de edición (numérico) mostrará el área de píxeles detectada de los pulmones.

Ahora cambie de la vista de diseño a la vista de código en App Designer. Introduzca en el código el código de las propiedades haciendo clic en el botón rojo "Propiedades" con un signo más. Inicialice las propiedades I, el umbral y las regiones para extraer como en el código que se proporciona a continuación. A continuación, haga clic con el botón derecho en un botón en la parte superior derecha del espacio de trabajo (el Explorador de componentes) y vaya a Devolución de llamada> Ir a … devolución de llamada. Agregue el código para la "función SelectImageButtonPushed (aplicación, evento)". Este código le permite seleccionar una imagen para analizar desde su computadora usando uigetfile. Después de seleccionar una imagen, aparecerá una imagen de vista previa debajo de los ejes acompañada de un histograma. Luego, haga clic con el botón derecho en el otro botón y repita el mismo procedimiento para crear una función de devolución de llamada.

Agregue el código debajo de la "función AnalyzeImageButtonPushed (aplicación, evento)". Este código realizará el recuento de píxeles y la detección de manchas en la imagen de vista previa en el botón analizar imagen (cualquiera en el que haya hecho clic con el botón derecho para este código). Después de programar los botones, ahora programaremos el control deslizante y el menú desplegable. Haga clic con el botón derecho en el control deslizante, cree una función de devolución de llamada y agregue el código debajo de "función FilterThresholdSliderValueChanged (aplicación, evento)" hasta el final. Esto permite que el control deslizante ajuste el umbral de intensidad de gris.

Cree una función de devolución de llamada para el menú desplegable y agregue el código debajo de "función AreastoExtractDropDownValueChanged (aplicación, evento)" para permitir que el menú desplegable modifique el número de manchas que se muestran en los ejes de la imagen analizada. Ahora, haga clic en cada entidad en el Explorador de componentes y cambie sus propiedades a su gusto, como cambiar los nombres de las entidades, eliminar ejes y cambiar la escala. Arrastre y suelte las entidades del Explorador de componentes en la vista Diseño a un diseño funcional y fácil de entender. ¡Ahora tiene una aplicación en MATLAB que puede analizar imágenes de pulmones para el área de píxeles!

propiedades (Acceso = privado) I = ; % archivo de imagen

umbral = 257; % de umbral para binarizar la intensidad del gris

RegionsToExtract = 2;

fin

función SelectImageButtonPushed (aplicación, evento)

clc; Dir = 'C: / Usuarios / danie / Descargas / images_004 / images'; % define archivo invariable "prefijo"

[imageExt, ruta] = uigetfile ('*. png'); % agarra la parte variable del nombre de la imagen

imageName = [Dir filesep imageExt]; % concatenar extracciones invariables y variables

app. I = imread (nombre de la imagen); % lee la imagen

imshow (aplicación I, 'padre', aplicación. UIAxes); % muestra la imagen

app. FilePathEditField. Value = ruta; % muestra la ruta del archivo de donde proviene la imagen original

fin

función AnalyzeImageButtonPushed (aplicación, evento)

originalImage = app. I;

Imagen original = wiener2 (aplicación. I, [5 5]); % filtro de eliminación de puntos

histograma (aplicación AxesHistogram, aplicación I, 256); % muestra el histograma de la imagen

a_thresh = originalImage> = app.threshold; % establece este umbral

labelImage = bwlabel (a_thresh);

props = regionprops (a_thresh, 'todos');

sortedSolidity = sort ([props. Solidity], 'descender');

SB = sortedSolidity (1);

si SB == 1% SB solo acepta solidez == 1 filtra los huesos

SE = strel ('cuadrado', 3);

morphologicalGradient = imsubtract (imdilate (labelImage, SE), imerode (labelImage, SE));

mask = imbinarize (morphologicalGradient, 0.03);

SE = strel ('cuadrado', 2);

máscara = imclose (máscara, SE);

mask = imfill (máscara, 'agujeros');

mask = bwareafilt (máscara, app.regionsToExtract);

% de control del número de área mostrada

notMask = ~ máscara;

máscara = máscara | bwpropfilt (notMask, 'Área', [-Inf, 5000 - eps (5000)]);

BW2 = imfill (labelImage, 'agujeros');

nueva_imagen = BW2;

nueva_imagen (~ máscara) = 0;

B = bwbo limits (nueva_imagen); % solo puede aceptar 2 dimensiones imshow (new_image, 'parent', app. UIAxes2);

mantener (app. UIAxes2, 'on');

límites fronterizos (B);

set (gca, 'YDir', 'reverse');

pulmonArea = bwarea (nueva_imagen);

app. PixelAreaEditField. Value = lungArea;

fin

fin

función FilterThresholdSliderValueChanged (aplicación, evento)

app.threshold = app. FilterThresholdSlider. Value;

fin

function AreastoExtractDropDownValueChanged (aplicación, evento) stringNumber = app. AreastoExtractDropDown. Value;

app.regionsToExtract = str2double (stringNumber);

fin

fin