Inhoudsopgave:

Geautomatiseerde diagnose van diabetische retinopathie via MATLAB - Ajarnpa
Geautomatiseerde diagnose van diabetische retinopathie via MATLAB - Ajarnpa

Video: Geautomatiseerde diagnose van diabetische retinopathie via MATLAB - Ajarnpa

Video: Geautomatiseerde diagnose van diabetische retinopathie via MATLAB - Ajarnpa
Video: Болезненная диабетическая нейропатия 2025, Januari-
Anonim
Geautomatiseerde diagnose van diabetische retinopathie via MATLAB
Geautomatiseerde diagnose van diabetische retinopathie via MATLAB
Geautomatiseerde diagnose van diabetische retinopathie via MATLAB
Geautomatiseerde diagnose van diabetische retinopathie via MATLAB

(Zie codeoverzicht hierboven)

Diabetische retinopathie is een aan diabetes gerelateerde oogziekte die wordt veroorzaakt door een hoge bloedsuikerspiegel. De hoge bloedsuikerspiegels zorgen ervoor dat de bloedvaten in het netvlies opzwellen, wat leidt tot vergrote bloedvaten en zelfs bloedvatlekken, wat leidt tot donkere vlekken op retinale beelden. Met deze code willen we het verschijnen van bloedvatlekvlekken gebruiken als een indicator van diabetische retinopathie op de achtergrond, hoewel in de echte wereld verdere diagnosetechnieken vereist zouden zijn. Het doel van deze code is om beeldverwerking en diagnose van retinale beelden te automatiseren om tekenen van diabetische retinopathie te identificeren die worden weergegeven door donkere vlekken in de retinale beelden.

10 normale netvliesbeelden en 10 gediagnosticeerde netvliesbeelden werden verwerkt via een code die eerst de beelden leest en filtert en vervolgens de donkere vlekken kwantificeert om te bepalen of diabetische retinopathiesymptomen aanwezig zijn, op basis van een bepaalde drempel. De resultaten worden vervolgens afgedrukt op het opdrachtvenster voor interpretatie door de kijker.

Stap 1: Vereisten

Vereisten
Vereisten

1. Zorg ervoor dat u het MATLAB-programma op uw computer hebt gedownload.

2. Download het txt-bestand in de link. (Druk op 'ctrl+s' om op te slaan in dezelfde map als de MATLAB-code)

Stap 2: Vereisten (vervolg)

Vereisten (vervolg)
Vereisten (vervolg)
Vereisten (vervolg)
Vereisten (vervolg)

4. Open MATLAB en typ 'uiimport' in het opdrachtvenster.

5. Selecteer het bestand officialdiagnoses.txt en importeer het in MATLAB als een celmatrix.

6. Zorg ervoor dat je ‘officiële diagnoses’ als variabele ziet in de werkruimte.

Stap 3: Vereisten (vervolg)

Vereisten (vervolg)
Vereisten (vervolg)

7. Download de functie ModWald.m, die bovenstaande code kan verkrijgen of download deze van Canvas.

(Code verstrekt door Professor King en Professor Choi)

Stap 4: Vereisten (vervolg)

Vereisten (vervolg)
Vereisten (vervolg)

8. Download de 400 onbewerkte afbeeldingen uit de datasectie van The STARE Project.

Stap 5: Matlab opruimen om u voor te bereiden op het uitvoeren van code

Matlab opruimen om je voor te bereiden op het uitvoeren van code
Matlab opruimen om je voor te bereiden op het uitvoeren van code

Toevoegen aan code:

1. sluit alles (sluit alle eerder geopende afbeeldingen)

2. clearvars - behalve officiële diagnoses (wist alle variabelen behalve het officiële diagnose-txt-bestand dat eerder is geïmporteerd)

3. cclc (wist opdrachtvenster)

Stap 6: Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen

Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen
Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen
Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen
Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen

1. Pak het diagnosetekstbestand en pak de afbeeldingsnamen uit. Deze namen staan in de eerste kolom van het tekstbestand, dus typ 'officialdiagnoses(:, 1)' om ze uit te pakken. De matrix van afbeeldingsnamen is toegewezen aan een variabele, " all_image_numbers"

2. Converteer de variabele all_image_numbers van een celarray naar een matrixarray met behulp van de cell2mat-functie

Stap 7: Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen (vervolg)

Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen (vervolg)
Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen (vervolg)
Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen (vervolg)
Selecteer 10 normale oogbeelden en 10 beelden met diabetische retinopathiesymptomen (vervolg)

3. Selecteer 10 normale oogbeelden om de code uit te voeren. De geselecteerde afbeeldingen in dit geval waren 278, 199, 241, 235, 35, 77, 82, 164, 239, 170.

Plaats deze getallen in een matrix en wijs ze toe aan een variabele die wordt aangeroepen bij het laden van de afbeeldingen.

4. Herhaal stap 3 voor beelden van het netvlies waarbij diabetische retinopathie is vastgesteld. De geselecteerde afbeeldingen in dit geval waren 139, 137, 136, 135, 133, 140, 141, 116, 157, 188.

Stap 8: Maak 2 variabelen (normaal en gediagnosticeerd) en stel ze elk gelijk aan 0

Maak 2 variabelen (normaal en gediagnosticeerd) en stel ze elk gelijk aan 0
Maak 2 variabelen (normaal en gediagnosticeerd) en stel ze elk gelijk aan 0

Maak deze variabelen vóór de for-lus om de lusnummers te initialiseren.

Stap 9: Maak een for-lus om automatisch normale afbeeldingen te uploaden

Maak een for-lus om automatisch normale afbeeldingen te uploaden
Maak een for-lus om automatisch normale afbeeldingen te uploaden

1. Maak een for-lus

2. Stel een telvariabele (i, in dit geval) in op een matrix van waarden 1-10. Deze telvariabele wordt gebruikt om elke afbeelding afzonderlijk aan te roepen

3. Neem het i-element in de matrix van afbeeldingen om de afbeeldingsnaam te extraheren en om te zetten van een string naar een getal met behulp van de num2str-functie.

Zoek het aantal cijfers in de afbeeldingsnaam met behulp van de cijferfunctie. Wijs deze waarde toe aan een variabele, digits_normal. Dit nummer moet 1 zijn voor nummers met één cijfer, 2 voor nummers met twee cijfers en 3 voor nummers met drie cijfers. Deze informatie wordt gebruikt om automatisch afbeeldingen op te roepen.

Stap 10: Maak een for-lus om automatisch normale afbeeldingen te uploaden (vervolg)

Maak een for-lus om automatisch normale afbeeldingen te uploaden (vervolg)
Maak een for-lus om automatisch normale afbeeldingen te uploaden (vervolg)

3. Maak een if-statement met alle drie de mogelijkheden uit de vorige stappen. Als de afbeeldingsnaam 1 cijfer heeft, wordt de afbeelding "im000" genoemd, als deze 2 cijfers heeft, wordt de afbeelding "im00" genoemd en als deze er 3 heeft, wordt de afbeelding "im0" genoemd.

4. Wijs onder elk if-statement een variabele toe om "im" te imreaden onder het corresponderende if-statement met het juiste aantal nullen (zoals hierboven beschreven), gevolgd door de i.

Stap 11: Snijd de randen van de afbeelding bij

Snijd de randen van de afbeelding bij
Snijd de randen van de afbeelding bij

Neem de originele afbeelding en pas een imcrop-filter toe om zwarte randen te elimineren en wijs deze toe aan een variabele I_crop. De bijsnijdrechthoek wordt gespecificeerd met behulp van een matrix [95, 95, 500, 410].

Stap 12: Maak een grijsschaalafbeelding

Een grijswaardenafbeelding maken
Een grijswaardenafbeelding maken

Neem de bijgesneden afbeelding en pas het rbg2gray-filter toe om de afbeelding in grijswaarden te veranderen. Wijs deze afbeelding toe aan variabele I2.

Stap 13: Maak een contrasterende afbeelding

Maak een contrasterende afbeelding
Maak een contrasterende afbeelding

Neem de afbeelding I2 en gebruik imadjust om de intensiteitswaarden opnieuw te schalen.

Neem waarden die binnen het bereik [0,2, 0,7] vallen en schaal deze opnieuw naar een [0, 1]. Het gamma is ingesteld op 0,8 om het beeld helderder te maken. Wijs de nieuwe afbeelding toe aan I_adjusted.

Stap 14: Verbeter het contrastbeeld

Verbeter het contrastbeeld
Verbeter het contrastbeeld

Neem de I_adjusted-afbeelding en gebruik de adapthisteq-functie om het contrast te verbeteren.

De Adapthisteq-syntaxis vereist de afbeeldingsnaam, I_adjusted, 'numTiles', de grootte van numTiles, 'nBins' en het aantal bins. De grootte van numTiles is ingesteld op [8 8], waarbij de afbeelding wordt verdeeld in tegels van 8x8 en het aantal bakken is ingesteld op 28. Wijs de afbeelding toe aan I_constrast.

Stap 15: Maak een gemiddeld filter

Een gemiddeld filter maken
Een gemiddeld filter maken

Maak een variabele met de naam 'meanfilt' met behulp van de functie fspecial. Voer 'gemiddelde functie' in om het middelingsfilter te maken en voer [90 90] in voor de schuifvenstergrootte.

Stap 16: Combineer het middelingsfilter met de contrasterende afbeelding

Combineer het middelingsfilter met de contrasterende afbeelding
Combineer het middelingsfilter met de contrasterende afbeelding

Maak een nieuwe variabele met de naam mask_mean en gebruik de functie imfilter om de afbeelding I_contrast te nemen en het eerder gemaakte gemiddelde filter toe te passen.

Stap 17: Maak een nieuw gemiddeld masker door pixels af te trekken

Maak een nieuw gemiddeld masker door pixels af te trekken
Maak een nieuw gemiddeld masker door pixels af te trekken

Maak een variabele met de naam mask_mean2 en gebruik de functie imsubtract om de waarde van elke pixel in I_contrast af te trekken van de overeenkomstige pixel in mask_mean.

Stap 18: Maak een binair gefilterde afbeelding

Een binair gefilterde afbeelding maken
Een binair gefilterde afbeelding maken

Zet grijswaardenafbeeldingen om in zwart-wit met behulp van imbinarize. Invoer mask_mean2, 'adaptive', 'ForegroundPolarity', 'dark', 'Sensitivity', 0.6. Wijs deze nieuwe afbeelding toe aan mask_binarize.

Stap 19: Verwijder kleinere blobs gevonden in de gefilterde afbeeldingen

Verwijder kleinere blobs gevonden in de gefilterde afbeeldingen
Verwijder kleinere blobs gevonden in de gefilterde afbeeldingen

Verwijder objecten met een connectiviteit van minder dan 100 pixels met behulp van de bwareaopen-functie op de mask_binarize en stel de drempelwaarde in op 100. Wijs de variabele toe als bw.

Stap 20: Maak een schijfstructureringselement

Een schijfstructureringselement maken
Een schijfstructureringselement maken

Maak een schijfstructurerend element (met een straal van 2) met behulp van de strel-functie. Wijs het toe aan se.

Stap 21: Voer morfologische afsluitingsbewerkingen uit

Morfologische afsluitingsoperaties uitvoeren
Morfologische afsluitingsoperaties uitvoeren

Neem bw en pas de imclose-functie toe op het structurele element om een morfologische close-operatie op het object uit te voeren.

Stap 22: Zoek de objecten met connectiviteit van ten minste 8

Vind de objecten met een connectiviteit van minimaal 8
Vind de objecten met een connectiviteit van minimaal 8

Neem bw en gebruik bwconncomp om de objecten te vinden met een connectiviteit van minimaal 8 in de afbeelding. Wijs de nummeruitvoer toe aan cc_1.

Stap 23: Zoek het maximale aantal verbonden pixels

Vind het maximale aantal verbonden pixels
Vind het maximale aantal verbonden pixels
Vind het maximale aantal verbonden pixels
Vind het maximale aantal verbonden pixels

Gebruik de cellfun-functie om de functie "numel" op elke cel in CC uit te voeren. Hiermee wordt het aantal elementen in de PixelIdxList-cel gevonden. Waarde toewijzen aan "numPixels".

Zoek de maximale waarden in numPIxels. Wijs het grootste maximum toe aan "grootste" en de index van de maximale waarde aan "idx".

Stap 24: Stel de maximale pixelwaarden in op 0 en zoek pixels met >=26 pixelconnectiviteit

Bloedvaten in afbeelding verwijderen
Bloedvaten in afbeelding verwijderen
Figuurweergave
Figuurweergave
Vaten verwijderen en bloedklonters tellen
Vaten verwijderen en bloedklonters tellen
Diagnose van het netvliesbeeld op basis van het aantal geïdentificeerde bloedstolsels
Diagnose van het netvliesbeeld op basis van het aantal geïdentificeerde bloedstolsels

Zet de pixels met de grootste waarden in de afbeelding “bw” op 0, waardoor de pixels zwart worden.

Zoek de objecten met een connectiviteit van ten minste 26 pixels in de afbeelding met behulp van bwconncomp. Toewijzen aan variabele cc_1.

Stap 25: Bloedvaten in afbeelding verwijderen

Verwijder de bloedvaten die nog in het beeld aanwezig zijn met behulp van de bwpropfilt-functie met een bereik van [0, 0.9].

[0.9, 1] is uitgesloten omdat waarden dichtbij 1 een lijn aangeven. Wijs toe aan "VerwijderVessels".

Stap 26: Figuurweergave

Geef elke gefilterde afbeelding weer in een subplot. laat zien. met 'border' en 'strakke' ingangen, geeft elke afbeelding weer in een subplotstructuur. Voeg een titel toe aan elke afbeelding om te onderscheiden welk filter is gebruikt.

Stap 27: Verwijder vaten en tel bloedvlekken

1. Neem "RemoveVessels" en pas de functie 'Centroid' toe in regionprops om de zwaartepunten van de objecten in de afbeelding te identificeren. Deze objecten moeten overeenkomen met bloedstolsels die in het beeld aanwezig zijn.

2. Tel het aantal geïdentificeerde bloedstolsels door de lengte van de zwaartepuntmatrix te nemen.

Stap 28: Diagnose van het netvliesbeeld op basis van het aantal geïdentificeerde bloedstolsels

Gebruik if-statements om het beeld te diagnosticeren op basis van het aantal geïdentificeerde bloedstolsels.

Als het aantal geïdentificeerde zwaartepunten minder dan of gelijk aan 5 was, werd het beeld als normaal geïdentificeerd.

Als het aantal zwaartepunten groter was dan 5, werd het beeld gediagnosticeerd met diabetische retinopathie.

Het resultaat wordt met fprintf in het opdrachtvenster afgedrukt.

Stap 29: Als er meer dan 5 blobs zijn…

Als er meer dan 5 blobs zijn…
Als er meer dan 5 blobs zijn…

Herhaal de bovenstaande instructies voor gediagnosticeerde beelden als een else-statement. Dit deel wordt uitgevoerd als het aantal blobs groter is dan 5.

Beëindig het if-statement.

Stap 30: Herhaal het filterproces voor normale afbeeldingen met beeldcijferwaarden als 2 en 3

Herhaal het filterproces voor normale afbeeldingen met beeldcijferwaarden als 2 en 3
Herhaal het filterproces voor normale afbeeldingen met beeldcijferwaarden als 2 en 3
Herhaal het filterproces voor normale afbeeldingen met beeldcijferwaarden als 2 en 3
Herhaal het filterproces voor normale afbeeldingen met beeldcijferwaarden als 2 en 3

Herhaal het proces voor de rest van de originele if-statements wanneer numel (het aantal cijfers in het afbeeldingsnummer) gelijk is aan 2 en 3. Dit voltooit de for-lus voor de normale afbeeldingen.

Beëindig de for-lus.

Stap 31: Herhaal het hele proces voor de gediagnosticeerde afbeeldingen

Herhaal het hele proces voor de gediagnosticeerde beelden
Herhaal het hele proces voor de gediagnosticeerde beelden

Herhaal het hele proces met behulp van de gediagnosticeerde beelden die worden vermeld in de matrix "numbers_to_extract_diagnosed".

Zorg ervoor dat u elk cijfer (i) doorloopt en verander het in cijfer (i+10), zodat de gediagnosticeerde cijfers verschijnen als afbeeldingen 11 tot 20.

Stap 32: statistische analyse

Statistische analyse
Statistische analyse

1. 'Actual_Diagnosis_Matrix' wordt gebruikt om de resultaten te vergelijken met de officiële diagnose in het txt-bestand. De eerste 10 nullen geven aan dat de eerste 10 afbeeldingen normaal moeten zijn. De laatste 10 geven aan dat de laatste 10 beelden moeten worden geclassificeerd als diabetische retinopathie.

2. Het dubbele gelijkteken dat wordt gebruikt om 'number_correct' te creëren, creëert een logische array door de waarde van de corresponderende elementen van 'Actual_Diagnosis_Matrix' te vergelijken met 'Diagnosis_Matrix' gemaakt op basis van de for-lus.

Voor elk element dat overeenkomt met de diagnose wordt een 1 toegevoegd, wat betekent dat de code die afbeelding correct diagnosticeert. Als het onjuist is, wordt een 0 aan de matrix toegevoegd.

Als je de som daarvan neemt, worden alle getallen bij elkaar opgeteld. Met andere woorden, het vindt de som van correct gediagnosticeerde beelden.

3. 'Final_percentage_correct' is het berekende percentage van hoe nauwkeurig de code diabetische retinopathie diagnosticeerde. Het aantal correct gediagnosticeerde beelden wordt gedeeld door 20 (het totale aantal foto's) en vermenigvuldigd met 100 om het percentage succesvolle diagnoses te vinden.

Stap 33: Betrouwbaarheidsinterval vinden

Betrouwbaarheidsinterval vinden
Betrouwbaarheidsinterval vinden

1. Zorg ervoor dat je ModWald.m hebt gedownload om het als een functie aan te roepen. Zonder de functie zou u het betrouwbaarheidsinterval zelf moeten berekenen met de aangepaste Wald-methode.

2. De ModWald-functie heeft 2 ingangen waarbij de eerste het aantal correct geïdentificeerde afbeeldingen is en de tweede het totale aantal afbeeldingen.

3. De ModWald-functie geeft de onder- en bovengrenzen van het betrouwbaarheidsinterval van verhoudingen weer voor de nauwkeurigheid van de gesamplede gegevens. Met andere woorden, het geeft u een interval van percentages waar het echte percentage van de nauwkeurigheid van de code zal liggen.

4. Gebruik onderstaande fprintf om de statistieken en het betrouwbaarheidsinterval uit te voeren in het opdrachtvenster.

> fprintf('%.0f procent van de retinale beelden werd correct gediagnosticeerd volgens de officiële diagnose. \n\n', Final_percentage_correct)

> fprintf('Het werkelijke percentage waarmee onze code diabetische retinopathie correct zal diagnosticeren, zal\n binnen het bereik van [%.3f, %.3f] vallen, gebaseerd op 20 gesamplede afbeeldingen \n', lower_bound, upper_bound)