用matlab_實現基於直方圖均衡化的彩色圖像增強 - 成人教育 - 道客巴巴 http://www.doc88.com/p-9042097312218.html
數字圖像處理之直方圖均衡化 - yoyo_sincerely - 博客園
HE.m文件:
RGB = imread('1233212.png'); % 讀取彩色圖 subplot(121); imshow(RGB); title('原圖'); [R, C, K] = size(RGB); % 新增的K表示顏色通道數 % 統計每個像素值出現次數 cnt = zeros(K, 256); for i = 1 : R for j = 1 : C for k = 1 : K cnt(k, RGB(i, j, k) + 1) = cnt(k, RGB(i, j, k) + 1) + 1; end end end f = zeros(3, 256); f = double(f); cnt = double(cnt); % 統計每個像素值出現的概率, 得到概率直方圖 for k = 1 : K for i = 1 : 256 f(k, i) = cnt(k, i) / (R * C); end end % 求累計概率,得到累計直方圖 for k = 1 : K for i = 2 : 256 f(k, i) = f(k, i - 1) + f(k, i); end end % 用f數組實現像素值[0, 255]的映射。 for k = 1 : K for i = 1 : 256 f(k, i) = f(k, i) * 255; end end % 完成每個像素點的映射 RGB = double(RGB); for i = 1 : R for j = 1 : C for k = 1 : K RGB(i, j, k) = f(k, RGB(i, j, k) + 1); end end end % 輸出 RGB = uint8(RGB); subplot(122); imshow(RGB); title('處理后');
Matlab 直方圖均衡化 - CSDN博客 https://blog.csdn.net/acmore_xiong/article/details/53183131