How to automatically identify abnormal regions and highlight boundaries in a different color
1 次查看(过去 30 天)
显示 更早的评论
I have a set of images for classification.
For this I have already extracted features from which the images have been already segmented and divided into four quadrants.
Now I want to use this feature values to idenifty the quadrants with the specified value ranges given below.
Here is my code;
% Read in the images.
I= imread ('nhimg-*.jpg';
% Segmentation of the ROI.
[S] = LungMask (I);
% Dividing Segmented ROI into quadrants.
[RUQ, LUQ, RLQ, LLQ] = crop(S);
% Extracting Features from each quadrant of the segmented images.
[Stats1, MaxProb1, Entropy1] = Prop(RUQ)
[Stats2, MaxProb2, Entropy2] = Prop(LUQ)
[Stats3, MaxProb3, Entropy3] = Prop(RLQ)
[Stats4, MaxProb4, Entropy4] = Prop(LLQ)
.
.
.
.
Now for this program I need to add the below feature ranges for each qaudrant to check whether the qaudrant features are in the defined range and if so mark the border of the respective quadrant in red color and create a label as "Abnormal".
These are the feature ranges;
Feature RUQ LUQ RLQ LLQ
Contrast 18-150 50-70 7-157 21-179
Correlation 0.97-0.99 0.97-0.99 0.98-1.00 0.97-0.99
Energy 0.30-0.54 0.32-0.48 - -
Etropy 2.79-3.76 2.85-3.94 - -
Max.Prob 0.58- 0.84 - - -
When the images are processed with this I need a final output like this image attached.
Can you help me to automize this existing code to get the output I need? Thanks in advance.
5 个评论
采纳的回答
Image Analyst
2020-3-27
You have to help us first. You forgot to attach 'nhimg-*.jpg' plus you forgot to attach the code for your LungMask(), crop(), and Prop() functions. What can we do without all those? Anyway, did you try subplot()M title(), and xlabel()?
subplot(2, 2, 1);
imshow(RUQ);
title('RUQ', 'FontSize', 15);
if IsAbnormal(RUQ) % You need to write this function
xlabel('Abnormal', 'FontSize', 15)
end
subplot(2, 2, 2);
imshow(LUQ);
title('LUQ', 'FontSize', 15);
if IsAbnormal(LUQ) % You need to write this function
xlabel('Abnormal', 'FontSize', 15)
end
subplot(2, 2, 3);
imshow(RLQ);
title('RLQ', 'FontSize', 15);
if IsAbnormal(RLQ) % You need to write this function
xlabel('Abnormal', 'FontSize', 15)
end
subplot(2, 2, 4);
imshow(LLQ);
title('LLQ', 'FontSize', 15);
if IsAbnormal(LLQ) % You need to write this function
xlabel('Abnormal', 'FontSize', 15)
end
13 个评论
Image Analyst
2020-3-30
No. Why would you want it to do that? First of all, the <= or >= evaluate to 0 or 1, so that means you'd be constructing a vector going from the first value to the second value in steps of 1. See what happens when you do that:
>> 0:0
ans =
0
>> 0:1
ans =
0 1
>> 1:0
ans =
1×0 empty double row vector
>> 1:1
ans =
1
It just does not make sense to do it.
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Introduction to Installation and Licensing 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!