这个算法是参考自 阿发伯 的博客,在此对 阿发伯 表示感谢,

http://blog.csdn.net/maozefa

亮度调整

非线性亮度调整:

对于R,G,B三个通道,每个通道增加相同的增量。

线性亮度调整:

利用HSL颜色空间,通过只对其L(亮度)部分调整,可达到图像亮度的线性调整。但是,RGB和HSL颜色空间的转换很繁琐,一般还需要浮点数的运算,不仅增加了代码的复杂度,更重要的是要逐点将RGB转换为HSL,然后确定新的L值,再将HSL转换为RGB,运行速度可想而知是很慢的。要想提高图像亮度线性调整的速度,应该从三方面考虑,一是变浮点运算为整数运算,二是只提取HSL的L部分进行调整,三是采用汇编代码,在Delphi中,当然是BASM。下面是按照这三方面考虑写的图像亮度线性调整代码:

L := (Max(R, Max(G,B)) + Min(R, Min(G, B))) div 2;

L没有采用通常的百分比表示,而是取值0 - 255,这样就不必要采用浮点数运算了。

下面代码主要完成2个功能,一是用以前的L值与RGB分别求出其HSL的HS部分,其公式用Pascal表示为:

if L > 128 then

begin

  rHS := (R * 128 - (L - 128) * 256) div (256 - L);

  gHS := (G * 128 - (L - 128) * 256) div (256 - L);

  bHS := (B * 128 - (L - 128) * 256) div (256 - L);

end else

begin

  rHS := R * 128 div L;

  gHS := G * 128 div L;

  bHS := B * 128 div L;

end;

二是用新的L值(老的L值加需要调整的亮度值(0 - 255))和上面求出的HS值计算出新的

RGB值,计算方法为:

newL := L + Value - 128;

if newL > 0 then

begin

  newR := rHS + (256 - rHS) * newL div 128;

  newG := gHS + (256 - gHS) * newL div 128;

  newB := bHS + (256 - bHS) * newL div 128;

else begin

  newR := rHS + rHS * newL div 128;

  newG := gHS + gHS * newL div 128;

  newB := bHS + bHS * newL div 128;

end;

如此,一个像素点的线性亮度调整就基本完成了

Program:

clc;

clear all;

close all;

Image=imread('4.jpg');

Image=double(Image);

R=Image(:,:,1);

G=Image(:,:,2);

B=Image(:,:,3);

%%%% 求出原始图像亮度分量

I=(R+G+B)/3;

%%% 利用原始图像的亮度分量结合R,G,B求出HSL空间的H,S;

rHS=R;

gHS=G;

bHS=B;

[row, col]=size(I);

for i=1:row

    for j=1:col

        if(I(i,j)>128)

            rHS(i,j)=(R(i,j)*128-(I(i,j)-128)*256)/(256-I(i,j));

            gHS(i,j)=(G(i,j)*128-(I(i,j)-128)*256)/(256-I(i,j));

            bHS(i,j)=(B(i,j)*128-(I(i,j)-128)*256)/(256-I(i,j));

        else

            rHS(i,j)=R(i,j)*128/(I(i,j));

            gHS(i,j)=G(i,j)*128/(I(i,j));

            bHS(i,j)=B(i,j)*128/(I(i,j));

        end

    end

end

%%%% 然后求出新的亮度值

%%%% Increment: 亮度的调整增量(-255,255)

Increment=-100;

I_out=I+Increment-128;

%%%% 再利用新的亮度值结合H,S,求出新的R,G,B分量

R_new=R;

G_new=G;

B_new=B;

for i=1:row

    for j=1:col

        if(I_out(i,j)>0)

            R_new(i,j)=rHS(i,j)+(256-rHS(i,j))*I_out(i,j)/128;

            G_new(i,j)=gHS(i,j)+(256-gHS(i,j))*I_out(i,j)/128;

            B_new(i,j)=bHS(i,j)+(256-bHS(i,j))*I_out(i,j)/128;

        else

            R_new(i,j)=rHS(i,j)+rHS(i,j)*I_out(i,j)/128;

            G_new(i,j)=gHS(i,j)+gHS(i,j)*I_out(i,j)/128;

            B_new(i,j)=bHS(i,j)+bHS(i,j)*I_out(i,j)/128;

        end

    end

end

Image_new(:,:,1)=R_new;

Image_new(:,:,2)=G_new;

Image_new(:,:,3)=B_new;

imshow(Image/255);

figure, imshow(Image_new/255);

PS 图像调整算法——亮度调整的更多相关文章

  1. PS 图像调整算法——阈值

    PS里面这个算法,先将图像转成灰度图像,然后根据给定的阈值,大于该阈值的像素赋值为1,小于该阈值的赋值为0. if x>T, x=1; if x<T, x=0; 原图: 效果图:阈值为 1 ...

  2. PS 图像调整算法——自动色阶 (Auto Levels)

    PS 给出的定义: Enhance Per Channel Contrast:Maximizes the tonal range in each channel to produce a more d ...

  3. PS 图像调整算法——黑白

    这个算法是参考自 阿发伯 的博客: http://blog.csdn.net/maozefa 黑白调整 Photoshop CS的图像黑白调整功能,是通过对红.黄.绿.青.蓝和洋红等6种颜色的比例调节 ...

  4. PS 图像调整算法——饱和度调整

    算法参考自 阿发伯 的博客. http://blog.csdn.net/maozefa 饱和度调整 图像的饱和度调整有很多方法,最简单的就是判断每个象素的R.G.B值是否大于或小于128,大于加上调整 ...

  5. PS 图像调整算法——自动对比度 (Auto Contrast)

    PS 给出的定义: Enhance Monochromatic Contrast: Clips all channels identically. This preserves the overall ...

  6. PS 图像调整算法— —渐变映射

    这个调整简单来说就是先建立一张lookup table, 然后以图像的灰度值作为索引,映射得到相应的颜色值.图像的灰度值是由图像本身决定的,但是lookup table 却可以各种各样,所以不同的lo ...

  7. PS 图像调整算法——色调分离

    色调分离的原理就是将R, G, B每个通道 0-255 的色调区间进行强制划分到给定的区间里去,所以色调会合并,最终的图像看起来颜色就是一块一块的. clc; clear all; close all ...

  8. PS 图像调整算法——反相

    这个顾名思义,对图像做减法. Image_new=1-Image_old; 原图: 反相:

  9. Python: PS 图像调整--亮度调整

    本文用 Python 实现 PS 图像调整中的亮度调整,具体的算法原理和效果可以参考之前的博客: http://blog.csdn.net/matrix_space/article/details/2 ...

随机推荐

  1. 开源框架Slidingmenu的基本使用

    转载本博客请标明出处:点击打开链接      http://blog.csdn.net/qq_32059827/article/details/52464262 侧滑菜单在开发中经常用到,而Slidi ...

  2. JVM学习之-栈

    JVM栈解决程序的运行问题,即程序如何执行,或者说如何处理数据;JVM堆解决的是数据存储的问题,即数据怎么放.放在哪儿,另外JVM堆中存的是对象.JVM栈中存的是基本数据类型和JVM堆中对象的引用. ...

  3. Android必知必会-Stetho调试工具

    一.背景 Stetho是 Facebook 出品的一个强大的 Android 调试工具,使用该工具你可以在 Chrome Developer Tools查看APP的布局, 网络请求(仅限使用Volle ...

  4. 最详细的制作正式版10.11 OS X El Capitan 安装U盘的方法

    原帖地址:http://bbs.feng.com/read-htm-tid-10036487.html 一.准备工作: 1.准备一个 8GB 或以上容量的 U 盘,确保里面的数据已经妥善备份好(该过程 ...

  5. 如何在mac OS X中查看Emoji表情的含义

    使用ctrl+空格,在搜索框中搜索 TextEdit程序,其实中文是 文本编辑 程序, 运行,在菜单中选择 编辑->特殊字符 然后可以看到每个图标的说明啦

  6. (一一八)利用block实现链式编程

    有些时候需要不断地调用方法,如果使用传统方案,需要拿到对象多次调用,例如有一个Ball对象,实现了up.down.left.right四个方法,分别控制球的运动方向,如果要实现球向右再向下,需要这么写 ...

  7. Postgre: How to import UUID function into Postgre 9.3

    1. Open a command console and go to the directory where you installed Postgre server. e.g. D:\Progra ...

  8. springMVC 使用ajax 出现No serializer found for class异常

    转自  http://mxdba.iteye.com/blog/668155 google了一下,发现坛子里已经有人解答了 http://godfox.iteye.com/blog/646887 不过 ...

  9. 手把手教你轻松实现listview下拉刷新

    很多人觉得自定义一个listview下拉刷新上拉加载更多是一件很牛x的事情,不是大神写不出来,我想大多数童鞋都是做项目用到时就百度,什么pulltorefresh,xlistview...也不看原理, ...

  10. 【嵌入式开发】嵌入式 开发环境 (远程登录 | 文件共享 | NFS TFTP 服务器 | 串口连接 | Win8.1 + RedHat Enterprise 6.3 + Vmware11)

    作者 : 万境绝尘 博客地址 : http://blog.csdn.net/shulianghan/article/details/42254237 一. 相关工具下载 嵌入式开发工具包 : -- 下 ...