Clear Filters
Clear Filters

I want to extract skull from Brain MRI usinG MORPHOLOGICAL OPERATIONS . But i didnt get a useful output by using the following code..Please help me to solve this.s

20 views (last 30 days)
clear all;
clc
[filename pathname] = uigetfile({'*.jpg';'*.bmp'},'Select MRI');
inputimage=strcat(pathname, filename);
I = imread(inputimage);
figure,imshow(I), title('input');
se = strel('disk',7);
closeBW = imclose(I,se);
figure, imshow(closeBW);title('close operation');
afterOpening = imopen(closeBW,se);
figure, imshow(afterOpening,[]);title('open operation');
J=I-afterOpening;
figure, imshow(J,[]);title('Skull of MRI');
K=I-J;
figure, imshow(K,[]);title('Skull removed MRI');

Accepted Answer

Image Analyst
Image Analyst on 17 Feb 2017
See attached m-file.
  6 Comments
Magdalena Gierczynska
Magdalena Gierczynska on 25 Jul 2020
Hi, I'm writing my bachelor thesis and I tried use this code to skull removal but it doesn't work. I work on dicom files, but on .jpg it doesn't work too. Can u help me? What I do wrong?
Image Analyst
Image Analyst on 25 Jul 2020
Well it's nothing like my code. Anyway, you should threshold the image to find everything that's skull, then use that to erase the skull pixels.
skull = grayImage > someValue;
grayImage(skull) = 0;
There are a few other things you could do to make it better but that's basically it.

Sign in to comment.

More Answers (1)

Manikandan R
Manikandan R on 6 Dec 2018
where the m file is attached

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!