python中PS 圖像調(diào)整算法原理之亮度調(diào)整
亮度調(diào)整
非線性亮度調(diào)整:
對于R,G,B三個通道,每個通道增加相同的增量。
線性亮度調(diào)整:
利用HSL顏色空間,通過只對其L(亮度)部分調(diào)整,可達(dá)到圖像亮度的線性調(diào)整。但是,RGB和HSL顏色空間的轉(zhuǎn)換很繁瑣,一般還需要浮點(diǎn)數(shù)的運(yùn)算,不僅增加了代碼的復(fù)雜度,更重要的是要逐點(diǎn)將RGB轉(zhuǎn)換為HSL,然后確定新的L值,再將HSL轉(zhuǎn)換為RGB,運(yùn)行速度可想而知是很慢的。要想提高圖像亮度線性調(diào)整的速度,應(yīng)該從三方面考慮,一是變浮點(diǎn)運(yùn)算為整數(shù)運(yùn)算,二是只提取HSL的L部分進(jìn)行調(diào)整,三是采用匯編代碼,在Delphi中,當(dāng)然是BASM。下面是按照這三方面考慮寫的圖像亮度線性調(diào)整代碼:
L := (Max(R, Max(G,B)) + Min(R, Min(G, B))) div 2;
L沒有采用通常的百分比表示,而是取值0 - 255,這樣就不必要采用浮點(diǎn)數(shù)運(yùn)算了。
下面代碼主要完成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值加需要調(diào)整的亮度值(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;
如此,一個像素點(diǎn)的線性亮度調(diào)整就基本完成了
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;
%%% 利用原始圖像的亮度分量結(jié)合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: 亮度的調(diào)整增量(-255,255)
Increment=-100;
I_out=I+Increment-128;
%%%% 再利用新的亮度值結(jié)合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);
總結(jié)
以上所述是小編給大家介紹的python中PS 圖像調(diào)整算法原理之亮度調(diào)整 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
Python實(shí)現(xiàn)棧的方法詳解【基于數(shù)組和單鏈表兩種方法】
這篇文章主要介紹了Python實(shí)現(xiàn)棧的方法,結(jié)合實(shí)例形式詳細(xì)分析了Python基于數(shù)組和單鏈表兩種方法定義棧的相關(guān)操作技巧,需要的朋友可以參考下2020-02-02
淺談Python_Openpyxl使用(最全總結(jié))
這篇文章主要介紹了淺談Python_Openpyxl使用(最全總結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Pytorch自定義Dataset和DataLoader去除不存在和空數(shù)據(jù)的操作
這篇文章主要介紹了Pytorch自定義Dataset和DataLoader去除不存在和空數(shù)據(jù)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03
python 函數(shù)嵌套及多函數(shù)共同運(yùn)行知識點(diǎn)講解
在本篇文章里小編給各位整理的是一篇關(guān)于python 函數(shù)嵌套及多函數(shù)共同運(yùn)行知識點(diǎn)講解,需要的朋友們可以學(xué)習(xí)下。2020-03-03
如何在Python中導(dǎo)入EXCEL數(shù)據(jù)
這篇文章主要介紹了使用Python處理EXCEL基礎(chǔ)操作篇1,如何在Python中導(dǎo)入EXCEL數(shù)據(jù),文中提供了解決思路和部分實(shí)現(xiàn)代碼,一起來看看吧2023-03-03
python TK庫簡單應(yīng)用(實(shí)時顯示子進(jìn)程輸出)
這篇文章主要介紹了python TK庫簡單應(yīng)用(實(shí)時顯示子進(jìn)程輸出),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
python實(shí)現(xiàn)優(yōu)雅的打印json格式文本
這篇文章主要介紹了python實(shí)現(xiàn)優(yōu)雅的打印json格式文本方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
在Python中實(shí)現(xiàn)函數(shù)重載的示例代碼
這篇文章主要介紹了在Python中實(shí)現(xiàn)函數(shù)重載的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12

