图像增强算法:Gamma映射算法及MATLAB实现

(本文只介绍算法及实现,关于Gamma的具体原理需要大家自行去了解)

目录

一.计算公式

二.MATLAB的实现


一.计算公式

将像素扩展到0-255,上述计算公式进一步变形如下:

当r<1时,增强暗部细节,压缩亮部,用于处理过暗的图像;

当r>1时,增强亮部细节,压缩暗部,用于处理过亮的图像。

二.MATLAB的实现

Matlab 复制代码
clc;
clear all;

img = imread('D:\matlab file\image_gamma\yu.bmp');
img = rgb2gray(img);
[h,w] = size(img);

figure('Position', [700,200, 1000, 800]);  %设置figure的大小
subplot(1,3,1);imshow(img);title('原图');

img = double(img);
image1 = zeros(h,w);
for i = 1 : h
    for j = 1 : w
        image1(i,j) = (255/(255.^2.2)) * img(i,j).^2.2; %gamma取2.2
    end
end

image1 = uint8(image1);

subplot(1,3,2);imshow(image1);title('gamma = 2.2的映射');

image2 = zeros(h,w);
for m = 1 : h
    for n = 1 : w
        image2(m,n) = (255/(255.^(1/2.2))) * img(m,n).^(1/2.2); %gamma取1/2.2
    end
end

image2 = uint8(image2);

subplot(1,3,3);imshow(image2);title('gamma = 1/2.2的映射');

显示效果如下所示

参考自《基于MATLAB与FPGA的图像处理教程》。

内容仅供学习使用,请勿转载。

如有问题,欢迎指正。

相关推荐
t198751282 小时前
基于自适应Chirplet变换的雷达回波微多普勒特征提取
算法
guygg882 小时前
采用PSO算法优化PID参数,通过调用Simulink和PSO使得ITAE标准最小化
算法
老鼠只爱大米2 小时前
LeetCode算法题详解 239:滑动窗口最大值
算法·leetcode·双端队列·滑动窗口·滑动窗口最大值·单调队列
简简单单做算法3 小时前
基于PSO粒子群优化的分位数回归QRBILSTM网络模型的多输入单输出预测算法matlab仿真
matlab·分位数回归·多输入单输出·qrbilstm·pso-qrbilstm
mit6.8243 小时前
序列化|质数筛|tips|回文dp
算法
亲爱的非洲野猪3 小时前
Java锁机制八股文
java·开发语言
rgeshfgreh3 小时前
C++字符串处理:STL string终极指南
java·jvm·算法
LawrenceLan3 小时前
Flutter 零基础入门(十二):枚举(enum)与状态管理的第一步
开发语言·前端·flutter·dart
Protein_zmm3 小时前
【算法基础】二分
算法