利用Matlab實現(xiàn)圖像亮度分布統(tǒng)計圖
更新時間:2022年05月17日 16:16:50 作者:slandarer
這篇文章主要介紹了如何利用Matlab實現(xiàn)圖像亮度分布統(tǒng)計圖的繪制,文中的示例代碼講解詳細,對我們學習Matlab有一定的幫助,感興趣的可以了解一下
寫了一個輸入圖片,便會生成美觀的圖像各通道亮度分布圖的函數(shù),大概效果如下:


老樣子,工具函數(shù)放在最前面,之后會介紹咋用這個函數(shù):
工具函數(shù)
function HistogramPic(pic)
FreqNum=zeros(size(pic,3),256);
for i=1:size(pic,3)
for j=0:255
FreqNum(i,j+1)=sum(sum(pic(:,:,i)==j));
end
end
ax=gca;hold(ax,'on');box on;grid on
if size(FreqNum,1)==3
bar(0:255,FreqNum(1,:),'FaceColor',[0.6350 0.0780 0.1840],'FaceAlpha',0.5);
bar(0:255,FreqNum(2,:),'FaceColor',[0.2400 0.5300 0.0900],'FaceAlpha',0.5);
bar(0:255,FreqNum(3,:),'FaceColor',[0 0.4470 0.7410],'FaceAlpha',0.5);
ax.XLabel.String='RGB brightness';
rrange=[num2str(min(pic(:,:,1),[],[1,2])),' , ',num2str(max(pic(:,:,1),[],[1,2]))];
grange=[num2str(min(pic(:,:,2),[],[1,2])),' , ',num2str(max(pic(:,:,2),[],[1,2]))];
brange=[num2str(min(pic(:,:,3),[],[1,2])),' , ',num2str(max(pic(:,:,3),[],[1,2]))];
legend({['R: range[',rrange,']'],['G: range[',grange,']'],['B: range[',brange,']']},...
'Location','northwest','Color',[0.9412 0.9412 0.9412],...
'FontName','Cambria','LineWidth',0.8,'FontSize',11);
else
bar(0:255,FreqNum(1,:),'FaceColor',[0.50 0.50 0.50],'FaceAlpha',0.5);
ax.XLabel.String='Gray scale';
krange=[num2str(min(pic(:,:,1),[],[1,2])),' , ',num2str(max(pic(:,:,1),[],[1,2]))];
legend(['Gray: range[',krange,']'],...
'Location','northwest','Color',[0.9412 0.9412 0.9412],...
'FontName','Cambria','LineWidth',0.8,'FontSize',11);
end
ax.LineWidth=1;
ax.GridLineStyle='--';
ax.XLim=[-5 255];
ax.XTick=[0:45:255,255];
ax.YLabel.String='Frequency number';
ax.FontName='Cambria';
ax.FontSize=13;
end函數(shù)調用
非常簡單的使用方法,就是讀取圖片后調用函數(shù)即可:
pic=imread('test.png');
HistogramPic(pic)若圖像是彩圖則效果如下:


若圖像為灰度圖則效果如下:


以上就是利用Matlab實現(xiàn)圖像亮度分布統(tǒng)計圖的詳細內容,更多關于Matlab亮度分布統(tǒng)計圖的資料請關注腳本之家其它相關文章!
相關文章
Qt出現(xiàn)假死凍結現(xiàn)象的原因及解決方法
應用程序出現(xiàn)假死或凍結現(xiàn)象通常是由于一些常見問題所導致的,本文主要介紹了Qt出現(xiàn)假死凍結現(xiàn)象的原因及解決方法,具有一定的參考價值,感興趣的可以了解一下2023-10-10

