matlab数字图像处理实验二:单像素空域图像增强,编写函数实现直方图均衡化和规定化


博客使用指南:把每一节的 代码按顺序和提示复制到matlab就行。

准备工作

原理

造一张低对比度的图像,可以直接用老师给的,不过由于老师给的图像就是一张灰度值范围在0-100这样子的图片,我估计就是老师自己拿线性变换造的。
根据线性变换公式如下所示:
在这里插入图片描述
可以得到[a,b]是原图灰度值区间,[a’,b’]是目标图像灰度值区间,也就是把[a,b]拉伸到[a’,b’]这样子,就可以造出一张低对比度图像。代码就不写了。
然后读这张低对比度图像,把它三个通道扯出来作为二维图像。再搞一张第二题需要用到的匹配图像,也把三个通道扯出来。

代码

I0=imread('02.jpg');%需要增强的图像
IR=I0(:,:,1);
IG=I0(:,:,2);
IB=I0(:,:,3);
I1=imread('01.jpg');%读取匹配图,用以系统直方图规定化和后续的函数直方图规定化
I1R=I1(:,:,1);
I1G=I1(:,:,2);
I1B=I1(:,:,3);

题目一:对一幅低对比度分辨率的图像采用除直方图处理方法之外的灰度级变换方法实现图像增强

原理

线性变换原理就是准备工作里提到的公式,对数变换原理如下:
在这里插入图片描述
r就是要变的二维图像图像,注意matlab中log函数的参数得是double过的,对数函数决定了灰度值拉伸的样子,c决定了灰度值拉伸程度。

代码

%线性、对数变换增强
a=0;
b=130;%原图灰度值范围0-130
a1=0;
b1=255;%线性变换后的范围0-255
LT=a1+(b1-a1)/(b-a)*(I0-a); %线性变换
c=50;
LG=c*log(1+double(I0));%对数变换
figure;
subplot(431),imshow(uint8(I0));title('原图');  
subplot(432),imshow(uint8(LT));title('线性变换增强图像');  
subplot(433),imshow(uint8(LG));title('对数变换增强图像');  
subplot(434)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值