图像增强算法: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的图像处理教程》。

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

如有问题,欢迎指正。

相关推荐
深邃-2 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
咸鱼2.02 小时前
【java入门到放弃】Dubbo
java·开发语言·dubbo
We་ct5 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9178 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
周杰伦fans9 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
叼烟扛炮9 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说9 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove10 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung10 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展