ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

MATLAB实现灰度图像的直方图均衡化算法

2021-04-05 19:32:41  阅读:241  来源: 互联网

标签:均衡化 uint8 直方图 Pa 灰度 图像 像素点



作用

直方图均衡化的作用是图像增强。

原理

参考这篇文章


实验步骤

在这里插入图片描述

实现代码

function [J] = imhisteq(I) 
[M,N,C]=size(I);  %获得输入图像尺寸M、N、C(size函数)

I0 = double(I);%矩阵F中的数据由uint8类型转换为double类型以便后续处理。

if(C>1)
    I=rgb2gray(I); %如果颜色通道数C>1,则将彩色图像转化为灰度图rgb2gray
end

%计算图像F的灰度直方图h(imhist函数)
%或者通过两重循环遍历每个像素点从而得到每个灰度值的累计像素点个数)。
h = imhist(I,256)';

%计算原图的灰度分布概率Pf =h/(M*N)    (i=0,1,…,255)。
Pf = h/(M*N);

%计算原图灰度的累计分布Pa(使用cumsum函数)
Pa = cumsum(Pf);

%令Pa(1)=0
Pa(1)=0;

%Pa_1= Pa *255。将Pa_1四舍五入.
Pa_1 = round(Pa*255);

%置两重循环遍历图像F中所有像素点,求出每一个像素点的灰度值F(i,j)
for i=1:M
    for j=1:N
        J(i,j) = Pa_1(I0(i,j)+1);
    end
end

%计算得到的新图像矩阵中所有点的灰度值由double转换为uint8
J = uint8(J);  %转换uint8编码

测试

F  = imread('');/*灰度图路径自己指定*/
[G]=imhisteq(F);
figure,imshow(G);

效果

在这里插入图片描述

标签:均衡化,uint8,直方图,Pa,灰度,图像,像素点
来源: https://blog.csdn.net/weixin_43745075/article/details/115446383

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有