Skip to content

sneha3799/Retinal-OCT-classification-and-segmentation

Repository files navigation

Retinal-OCT-classification-and-segmentation

In this project, we made a system to classify scans as normal, pachychoroid, drusen, or diabetic macular edema (DME). If a scan is labeled as DME, we identify the affected area to assist ophthalmologists who have to analyze many scans each day. For classification, we improved a model we found in our research. It's a 15-layer CNN model, a better version of the VGG16 transfer learning model. We made two main changes: using depthwise separable convolutional layers instead of regular ones and using ELU instead of ReLU activation function. Our custom model trains much faster and is more accurate. The accuracy acheived by the custom model is around 98.35% outperforming all the existing models. For segmentation, we prepared the scans first by finding valid indexes and enhancing contrast and reducing noise. We used Non-local Means Denoising for noise removal and Contrast Limited Adaptive Histogram Equalization (CLAHE) to enhance contrast. Then we resized the images and split them into training and testing sets. For segmentation, we simply thresholded the image masks and resized them. Then we trained a U-Net model to predict the masks.

After this, deployed the model on AWS EC2 (Elastic Cloud Compute) using Flask. Made a website using Flask then deployed it on AWS EC2 using the following commands.

  1. Open Powershell and go to the folder containing the project zip file.
  2. Execute the following cmd -> scp -i ssh_key.pem pythonProject.zip [email protected]:
  3. Next, send your files to the server by executing the following command -> ssh -i "ssh_key.pem" [email protected]
  4. Execute the following commands to get files on the server provided by the EC2 instance
  • dir
  • sudo apt install zip unzip
  • unzip pythonProject.zip
  • cd pythonProject
  1. Setup the environment by installing all dependencies using the commands below
  • sudo apt-get update
  • sudo apt-get install -y python3-pip
  • pip3 install -r requirements.txt
  1. Run the script by executing python3 app.py command
  2. Connect to the EC2 instance by running the public DNS ended with :8080/ (Ex - http://ec2-18-191-25-39.us-east-2.compute.amazonaws.com:5000/)

References

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published