使用MATLAB进行中位数,四分位数,四分位数跨度和分辨率

问题描述 投票:0回答:1

我在MATLAB中有一张图片并将其分解为R,G和B通道。现在我需要弄清楚分辨率,中位数,上下四分之一,四分之一跨度和模式。

这是我用它的代码:关闭所有; CLC;清除所有

I = imread('image_S006_I0000.jpg'); 
 imshow(I)                           


[R S T] = size(I);                  

Red(:,:,1)=I(:,:,1);
Red(:,:,2)=zeros(R,S);
Red(:,:,3)=zeros(R,S);

Green(:,:,1)=zeros(R,S);
Green(:,:,2)=I(:,:,1);
Green(:,:,3)=zeros(R,S);

Blue(:,:,1)=zeros(R,S);
Blue(:,:,2)=zeros(R,S);
Blue(:,:,3)=I(:,:,1);


OR

Red=double(I(:,:,1));
Red=zeros(R,S);
Red=zeros(R,S);

Green=zeros(R,S);
Green=double(I(:,:,1));
Green=zeros(R,S);

Blue=zeros(R,S);
Blue=zeros(R,S);
Blue=double(I(:,:,1));

OR
Red(:,:,1)=double(I(:,:,1));
Green(:,:,1)=double(I(:,:,1));
Blue(:,:,1)=double(I(:,:,1));


cat(3, uint8(Red), zeros(R, S), zeros(R, S));
others = zeros(R, S);
red_plt = cat(3, uint8(Red), others, others);
green_plt = cat(3, others, uint8(Green), others);
blue_plt = cat(3, others, others, uint8(Blue));

figure()
subplot(131);imshow(red_plt)
subplot(132);imshow(green_plt)
subplot(133);imshow(blue_plt)

NOW PLOTTITG (It doesn't print it in Red, Green and Blue color. First two 
are just all black, the third one is black and white):
figure()
subplot(131);imshow(uint8(Red))
subplot(132);imshow(uint8(Green))
subplot(133);imshow(uint8(Blue))


[x1 y1 z1] = size(I);   

% MEDIAN. 
imgmedianR = median (Red(:))
imgmedianG = median (Green(:))
imgmedianB = median (Blue(:))


%QUARTIL
r025 = quantile(Red,0.25) 
r075 = quantile(Red,0.75) 

g025 = quantile(Green,0.25) 
g075 = quantile(Green,0.75) 

b025 = quantile(Blue,0.25) 
b075 = quantile(Blue,0.75) 


%INTERQUARTIL SPAN
r_iqr = iqr(Red) 
g_iqr = iqr(Green) 
b_iqr = iqr(Blue) 


modus_Red = mode(Red(:))
modus_Green = mode(Green(:))
modus_Blue = mode(Blue(:))

MEDIAN:当我尝试计算MEDIAN时,它给了我一堆数字(实际上matlab分别打印出每列的数字)。那我做错了什么?

QUARTIL:与我在MEDIAN的代码中遇到的问题相同。那我做错了什么?

INTERQUARTIL SPAN:Matlab打印出后续错误:不支持混合整数类输入。我做错了什么?

解决方案:我需要使用Matlab找出图像的分辨率。我已经尝试了funciton imfinfo,但信息不包括在内。如何使用任何类型的Matlab函数找到这样的信息?

非常感谢你提前!

matlab math
1个回答
0
投票

您将每个单独的颜色保存在3d矩阵中。这不是必需的。要将它们保存在2d矩阵中,如下所示:

Red=double(I(:,:,1));

Green=double(I(:,:,2));

Blue=double(I(:,:,3));

请注意,有一个转换为double。那是iqr所需要的。也可以在每个函数中使用Red(:)而不是Red(当然其他颜色也一样)。如果你改变了这一切,它应该工作得很好。

关于分辨率,这只是高度和宽度的像素数,在你的情况下RS

ps你两次打电话给size(I)


如果分别绘制红色,绿色和蓝色,则需要制作与原始矩阵相同的矩阵,但只有1种颜色不为零。该图像是RxSx3矩阵。因此,如果您想绘制红色部分,您需要制作一个RxSx3矩阵,其中只有红色非零:

cat(3, uint8(Red), zeros(R, S), zeros(R, S));

所以总的来说应该是这样的

others = zeros(R, S);
red_plt = cat(3, uint8(Red), others, others);
green_plt = cat(3, others, uint8(Green), others);
blue_plt = cat(3, others, others, uint8(Blue));

figure()
subplot(131);imshow(red_plt)
subplot(132);imshow(green_plt)
subplot(133);imshow(blue_plt)

编辑:

整个代码:

I = imread('image_S006_I0000.jpg'); 
 imshow(I)                           

[R S T] = size(I);                  

Red=double(I(:,:,1));

Green=double(I(:,:,2));

Blue=double(I(:,:,3));

others = zeros(R, S);
red_plt = cat(3, uint8(Red), others, others);
green_plt = cat(3, others, uint8(Green), others);
blue_plt = cat(3, others, others, uint8(Blue));

figure()
subplot(131);imshow(red_plt)
subplot(132);imshow(green_plt)
subplot(133);imshow(blue_plt)


% MEDIAN. 
imgmedianR = median (Red(:))
imgmedianG = median (Green(:))
imgmedianB = median (Blue(:))


%QUARTIL
r025 = quantile(Red(:),0.25) 
r075 = quantile(Red(:),0.75) 

g025 = quantile(Green(:),0.25) 
g075 = quantile(Green(:),0.75) 

b025 = quantile(Blue(:),0.25) 
b075 = quantile(Blue(:),0.75) 


%INTERQUARTIL SPAN
r_iqr = iqr(Red(:)) 
g_iqr = iqr(Green(:)) 
b_iqr = iqr(Blue(:)) 


modus_Red = mode(Red(:))
modus_Green = mode(Green(:))
modus_Blue = mode(Blue(:))
© www.soinside.com 2019 - 2024. All rights reserved.