MatLab Lung -segmentering: 5 steg
MatLab Lung -segmentering: 5 steg
Anonim
MatLab Lung Segmentation
MatLab Lung Segmentation

Av: Phuc Lam, Paul Yeung, Eric Reyes

Medveten om att fel i lungsegmentering kommer att ge falsk information om identifiering av ett sjukdomsområde och kan direkt påverka diagnosprocessen. Moderna datorstödstekniker lyckades inte ge exakta resultat när lungsjukdomar har utmanande former. Dessa onormala former kan orsakas av pleural effusioner, konsolideringar etc. Genom att använda lungsegmenteringstekniken, där lungans gränser isoleras från omgivande bröstvävnad, kan vår app identifiera gränserna med användarens inmatningströsklar för att ge helt anpassningsbara vyer av lungornas former, Syftet med detta MatLab-projekt är att skapa en användarvänlig interaktiv lungsegmenteringsapp för att upptäcka patologiska tillstånd i lungornas röntgenbilder. Vårt mål är att skapa ett mer effektivt sätt att illustrera och identifiera onormala lungor för att ge läkare och radiologer ett mer tillförlitligt sätt att diagnostisera lungsjukdomar. Med hjälp av appdesignverktyget i MatLab är programmet utformat för att fungera specifikt med bröströntgen och datortomografi (CT), men det testas också för att fungera med MR-skanningar.

Instruktionerna nedan innehåller vår brusfiltreringsteknik (lågpass Wiener-filter) samt bildtröskeln (med hjälp av intensitetshistogrammet för gråskala bilden) och med hjälp av en morfologisk gradient (skillnaden mellan vidgning och erosion av en bild) till identifiera en region av intresse. Instruktionen kommer sedan att förklara hur vi integrerar alla element i det grafiska användargränssnittet (GUI).

Notera:

1). Detta projekt är inspirerat av en forskningsartikel: "Segmentering och bildanalys av onormala lungor vid CT: aktuella tillvägagångssätt, utmaningar och framtida trender". Som finns här

2). Vi använder röntgenbilder från NIH: Clinical Center. Länk hittar du här

3). Hjälp för appdesigner hittar du här

4). Innan du kör koden: du måste ändra Dir -sökvägen (på rad 34) till din filkatalog och bildtyp (rad 35) (vi analyserar *.png).

Steg 1: Steg 1: Ladda bild

Steg 1: Ladda bild
Steg 1: Ladda bild

Detta steg visar den ursprungliga bilden i gråskala. Ändra 'name_of_picture.png' till ditt bildnamn

klar; clc; Stäng alla;

%% Läser in bilder

raw_x_ray = 'name_of_picture.png';

I = imread (raw_x_ray);

figur (101);

imshow (I);

färgbild (grå);

titel ('gråtonröntgen');

Steg 2: Steg 2: Brusfiltrering och histogram

Steg 2: Brusfiltrering och histogram
Steg 2: Brusfiltrering och histogram

För att hitta tröskeln för gråskalebilden tittar vi på histogrammet för att se om ett distinkt läge. Läs mer här

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

figur (102);

delplan (2, 1, 1);

imshow (I);

delplan (2, 1, 2);

imhist (I, 256);

Steg 3: Steg 3: Ställa in trösklar

Steg 3: Ställa in trösklar
Steg 3: Ställa in trösklar
Steg 3: Ställa in trösklar
Steg 3: Ställa in trösklar

Detta steg låter dig ställa in tröskeln enligt histogrammet. morphologicalGradient kommer att markera området av intresse för rött, och funktionen gränsar överlagrar den skisserade och filtrerade bilden av lungan i rött.

Genom att använda regionprops kan vi exakta stabilitetsgrupperna och sortera dem i fallande. Därefter binariserar jag den grå sclae -bilden och tillämpar den morflogiska gradientmetoden och mLoren Shurasking för att markera regionen av intresse (ROI). Nästa steg är att vända bilden så att lungan ROI är vit i den svarta bakgrunden. Jag använder funktionen showMaskAsOverlay för att visa 2 mask. Obs: koden är inspirerad av Loren Shure, länk.

Lasly, jag skapar röd kontur genom att använda bwbwboundaries och maskera filterbilden och gränserna.

a_thresh = I> = 172; % anger denna tröskel

[labelImage, numberOfBlobs] = bwlabel (a_thresh);

rekvisita = regionprops (a_thresh, 'all');

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

SB = sortedSolidity (1);

om SB == 1 % SB endast accepterar soliditet == 1 filtrera bort ben

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

imshow (binaryImage); färgbild (grå);

SE = strel ('square', 3);

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

mask = imbinarize (morphologicalGradient, 0,03);

SE = strel ('square', 2);

mask = nära (mask, SE);

mask = imfill (mask, 'hål');

mask = bwareafilt (mask, 2); % kontrollantal områdeshow

notMask = ~ mask;

mask = mask | bwpropfilt (notMask, 'Area', [-Inf, 5000 - eps (5000)]);

showMaskAsOverlay (0,5, mask, 'r'); % du måste ladda ner app/funktion showMaskAsOverlay

BW2 = imfill (binaryImage, 'hål');

ny_bild = BW2;

new_image (~ mask) = 0; % invertera bakgrund och hål

B = bwboundaries (new_image); % kan bara acceptera 2 dimensioner

figur (104);

imshow (ny_bild);

vänta

gränsöverskridande (B);

slutet

Steg 4: Skapa GUI

Nu integrerar vi den tidigare koden i en MATLAB -app. Öppna App Designer i MATLAB (Ny> App). Först designar vi gränssnittet genom att klicka-håll-och-dra i tre axlar in i mitten av arbetsytan. Därefter klickar och håller du ned två knappar, ett redigeringsfält (text), ett redigeringsfält (numeriskt), ett reglage och en rullgardinsmeny. Två axlar kommer var och en att visa förhandsgranskningen och analysera bilden, och den tredje axeln kommer att visa ett histogram med pixlar för förhandsgranskningen "vald" bild. Redigeringsfältet (text) -rutan visar filvägen för den valda bilden och redigeringsfältet (numeriskt) visar det identifierade pixelområdet för lungorna.

Byt nu från designvy till kodvy i App Designer. Ange koden för egenskaper genom att klicka på den röda knappen "Egenskaper" med ett plustecken. Initiera egenskaperna I, tröskel och regionToExtract som i koden nedan. Högerklicka sedan på en knapp i den övre högra sidan av arbetsytan (komponentbläddraren) och gå från Återuppringning> Gå till … återuppringning. Lägg till koden för “function SelectImageButtonPushed (app, händelse).” Denna kod låter dig välja en bild att analysera från din dator med uigetfile. Efter att ha valt en bild visas en förhandsgranskningsbild under axlarna tillsammans med ett histogram. Högerklicka sedan på den andra knappen och upprepa samma procedur för att skapa en återuppringningsfunktion.

Lägg till koden under "function AnalyzeImageButtonPushed (app, händelse)." Den här koden utför pixelräkningen och blobdetekteringen på förhandsgranskningsbilden på knappen analysera bild (beroende på vilken du högerklickade för den här koden). Efter programmering av knapparna programmerar vi nu reglaget och rullgardinsmenyn. Högerklicka på reglaget, skapa en återuppringningsfunktion och lägg till koden under "funktion FilterThresholdSliderValueChanged (app, händelse)" till slutet. Detta gör att reglaget kan justera tröskeln för grå intensitet.

Skapa en återuppringningsfunktion för rullgardinsmenyn och lägg till koden under "function AreastoExtractDropDownValueChanged (app, event)" för att låta rullgardinsmenyn ändra antalet blobbar som visas på de analyserade bildaxlarna. Klicka nu på varje enhet i komponentbläddraren och ändra deras egenskaper efter eget tycke, till exempel att ändra namn på enheter, ta bort axlar och ändra skalning. Dra och släpp enheterna i komponentbläddraren i designvyn till en funktionell och lättförståelig layout. Du har nu en app i MATLAB som kan analysera bilder av lungor för pixelområde!

fastigheter (Access = privat) I = ; % bildfil

tröskel = 257; %tröskel för binärisering av grå intensitet

regionToExtract = 2;

slutet

funktion SelectImageButtonPushed (app, händelse)

clc; Dir = 'C: / Users / danie / Downloads / images_004 / images'; %definiera invariat fil "prefix"

[imageExt, sökväg] = uigetfile ('*. png'); %ta tag i den variabla delen av bildnamnet

imageName = [Dir filesep imageExt]; %sammanfogade varierande och variabla strängar

app. I = imread (imageName); %läste bilden

imshow (app. I, 'parent', app. UIAxes); %visar bilden

app. FilePathEditField. Value = sökväg; %visningsfilväg för var originalbilden kom ifrån

slutet

function AnalyzeImageButtonPushed (app, händelse)

originalbild = app. I;

originalImage = wiener2 (app. I, [5 5]); %borttagningsfilter

histogram (app. AxesHistogram, app. I, 256); %visar histogram för bild

a_thresh = originalImage> = app.threshold; % anger denna tröskel

labelImage = bwlabel (a_thresh);

rekvisita = regionprops (a_thresh, 'all');

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

SB = sortedSolidity (1);

om SB == 1 % SB endast accepterar soliditet == 1 filtrera bort ben

SE = strel ('square', 3);

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

mask = imbinarize (morphologicalGradient, 0,03);

SE = strel ('square', 2);

mask = nära (mask, SE);

mask = imfill (mask, 'hål');

mask = bwareafilt (mask, app.regionsToExtract);

% kontrollantal områdeshow

notMask = ~ mask;

mask = mask | bwpropfilt (notMask, 'Area', [-Inf, 5000 - eps (5000)]);

BW2 = imfill (labelImage, 'hål');

ny_bild = BW2;

new_image (~ mask) = 0;

B = bwboundaries (new_image); % kan bara acceptera 2 dimensioner imshow (new_image, 'parent', app. UIAxes2);

håll (app. UIAxes2, 'on');

gränsöverskridande (B);

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

lungArea = bwarea (new_image);

app. PixelAreaEditField. Value = lungArea;

slutet

slutet

funktion FilterThresholdSliderValueChanged (app, händelse)

app.threshold = app. FilterThresholdSlider. Value;

slutet

function AreastoExtractDropDownValueChanged (app, event) stringNumber = app. AreastoExtractDropDown. Value;

app.regionsToExtract = str2double (stringNumber);

slutet

slutet