基于matlab的图像增强

1 原理

在图像增强中,线性变换、非线性变换(包括伽马变换和对数变换)以及直方图均衡化是常用的技术。以下是这些技术的原理和标准公式:

1.1 线性变换

线性变换主要用于调整图像的对比度和亮度。它通过改变像素值的线性映射关系来实现,公式如下:

S = k × r + b

  • S:输出变量(变换后的像素值)
  • r:输入变量(原始像素值)
  • k:倍数因子(控制对比度)
  • b:偏移因子(控制亮度)
1.2 非线性变换

本文采用伽马变换与对数变换。

1.2.1 伽马变换(Gamma Transformation)

伽马变换是一种常用的非线性灰度变换方法,用于调整图像的对比度。它基于光照强度与人眼感知之间的非线性关系。

g(x, y) = c × [f(x, y)]^γ

  • g(x, y):变换后的像素值
  • f(x, y):原始像素值
  • c:常数,用于控制对比度的增益
  • γ:伽马值,用于调整亮度的曲线形状。当γ > 1时,增加了高灰度级之间的对比度;当γ < 1时,增加了低灰度级之间的对比度。
1.2.2 对数变换

对数变换通过拉伸低灰度级并压缩高灰度级来增强图像的暗部细节。

g(x, y) = c × log(1 + f(x, y))

  • g(x, y):变换后的像素值
  • f(x, y):原始像素值
  • c:常数,用于控制对比度的增益
1.3 直方图均衡化

直方图均衡化通过调整图像的灰度级分布,使得图像中的像素更加均匀地分布在整个灰度级范围内,从而增强图像的整体对比度。

  • s_k:输出灰度级
  • n:图像中像素的总和
  • n_j:当前灰度级的像素个数
  • k:灰度级索引(0到L-1,L是图像中可能的灰度级总数)

综上所述:

  1. 线性变换通过调整倍数因子和偏移因子来改变图像的对比度和亮度。
  2. 非线性变换(如伽马变换和对数变换)基于非线性函数来调整图像的灰度级,以实现特定的对比度增强效果。
  3. 直方图均衡化通过调整图像的灰度级分布来增强图像的整体对比度。

2 代码

Matlab 复制代码
 %% 线性变换进行图像增强
I2= imread('test.jpeg');
J2=rgb2gray(I2);
figure;
subplot(2,2,1), imshow(J2) ;
title('原始图像');  
subplot(2,2,2), imhist(J2) ;%显示原始图像的直方图
title('原始灰度直方图');  
K = imadjust(J2,[0.4 0.6],[]);%使用imadjust函数进行灰度的线性变换
subplot(2,2,3), imshow(K);
title('线性变换后的灰度图像');  
subplot(2,2,4),imhist(K)%显示变换后图像的直方图
title('线性变换后的灰度直方图');

%% 伽马变换进行图像增强
figure;
subplot(3,2,1), imshow(J2) ;
title('原始图像');  
subplot(3,2,2), imhist(J2) ;%显示原始图像的直方图
title('原始灰度直方图'); 
gamma = 0.5;
I_gamma = imadjust(J2, [], [], gamma);  
subplot(3,2,3),imshow(I_gamma); 
title('伽马变换后的灰度图像'); 
subplot(3,2,4),imhist(I_gamma);
title('伽马变换后的灰度直方图'); 
%% % 对数变换进行图像增强  
c = 0.5; % 控制参数,用于避免log(0)  
I_log = c * log(1 + double(J2)) / log(256);  
I_log = im2uint8(I_log);    
subplot(3,2,5);  
imshow(I_log);  
title('对数变换后的图像');
subplot(3,2,6);  
imhist(I_log);
title('对数变换后的灰度直方图');
%% 
figure('Position',[50 50 800 600])
subplot(4,2,1), imshow(J2);
title('原始图像');  
subplot(4,2,2), imhist(J2);
title('原始灰度直方图'); 
subplot(4,2,3), imshow(K);
title('线性变换后的灰度图像');  
subplot(4,2,4),imhist(K)%显示变换后图像的直方图
title('线性变换后的灰度直方图');
subplot(4,2,5),imshow(I_gamma); 
title('伽马变换后的灰度图像'); 
subplot(4,2,6),imhist(I_gamma);
title('伽马变换后的灰度直方图'); 
subplot(4,2,7),imshow(I_log);  
title('对数变换后的图像');
subplot(4,2,8),imhist(I_log);
title('对数变换后的灰度直方图');
%% 直方图均衡化进行图像增强
I3 = imread('test.jpeg'); % 读取图像  
I_gray = rgb2gray(I3); % 转换为灰度图像    
% 直方图均衡化  
I_eq = histeq(I_gray);    
% 显示原始图像和增强后的图像  
figure;
subplot(2, 2, 1),imshow(I_gray);
title('原始图像'); 
subplot(2, 2, 2);  
imhist(I_gray),title('原始灰度直方图'); 
subplot(2, 2, 3),imshow(I_eq);  
title('直方图均衡化后的图像');
subplot(2, 2, 4),imhist(I_eq);  
title('直方图均衡化后的灰度直方图');

3 运行结果

图1 线性变换与原始图像对比图

图2 非线性变换与原始图像对比图

图3 总体变换对比图

图4 直方图均衡化对比图

相关推荐
@李思成1 小时前
动手学深度学习(Pytorch版)代码实践 -计算机视觉-44目标检测算法综述:R-CNN、SSD和YOLO
pytorch·深度学习·计算机视觉
@李思成1 小时前
动手学深度学习(Pytorch版)代码实践 -计算机视觉-45多尺度目标检测
pytorch·深度学习·计算机视觉
Jurio.2 小时前
2024年虚拟现实、图像和信号处理国际学术会议(ICVISP 2024,8月2日-4)
图像处理·人工智能·ar·vr·信号处理·虚拟现实
多恩Stone3 小时前
【可控图像生成系列论文(四)】IP-Adapter 具体是如何训练的?1公式篇
人工智能·pytorch·python·深度学习·机器学习·计算机视觉·aigc
源于花海3 小时前
计算机视觉 | 基于图像处理和边缘检测算法的黄豆计数实验
图像处理·计算机视觉·边缘检测·canny算子
_一帘幽梦_5 小时前
图像分割方法一:阈值分割
人工智能·opencv·计算机视觉
王二空间5 小时前
图像增强及运算篇之图像掩膜直方图和HS直方图
人工智能·python·opencv·计算机视觉
阑梦清川5 小时前
数学建模--Matlab操作与运算
开发语言·数学建模·matlab
小蟒天天向上5 小时前
【图像处理】1、使用OpenCV库图像轮廓的检测和绘制
图像处理·python·opencv
.carpe.diem.14 小时前
双路视频同屏显示(拼接)-基于野火Zynq7020开发板
图像处理·嵌入式硬件·fpga开发