您好,登錄后才能下訂單哦!
使用opencv怎么調(diào)整圖像亮度和對(duì)比度?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
圖像處理
圖像變換就是找到一個(gè)函數(shù),把原始圖像矩陣經(jīng)過(guò)函數(shù)處理后,轉(zhuǎn)換為目標(biāo)圖像矩陣.
可以分為兩種方式,即像素級(jí)別的變換和區(qū)域級(jí)別的變換
Point operators (pixel transforms)
Neighborhood (area-based) operators
像素級(jí)別的變換就相當(dāng)于\(p_{after}(i,j) = f(p_{before}(i,j))\),
即變換后的每個(gè)像素值都與變換前的同位置的像素值有個(gè)函數(shù)映射關(guān)系.
對(duì)比度和亮度改變
線性變換
最常用的是線性變換.即\(g(i,j) = \alpha \cdot f(i,j) + \beta\)
f(i,j)是原像素值,g(i,j)是變換后的像素值.
\(\alpha\)調(diào)整對(duì)比度,\(\beta\)調(diào)整亮度.有時(shí)也稱之為gain和bias參數(shù).
對(duì)比度是什么?不就是"亮和暗的區(qū)別"嗎?也就是像素值的大小的區(qū)別.那我乘以一個(gè)alpha系數(shù),當(dāng)alpha很大的時(shí)候就是放大了這種亮度值的差異,也就是提高了對(duì)比度,當(dāng)alpha很小時(shí),也就是縮小了亮度的差異,也就是縮小了對(duì)比度.
beta就更好理解了,直接在像素的亮度值上加上一個(gè)數(shù),正數(shù)就是提高亮度,負(fù)數(shù)降低亮度.
看一下下面代碼的示例:
from __future__ import print_function from builtins import input import cv2 as cv import numpy as np import argparse # Read image given by user parser = argparse.ArgumentParser(description='Code for Changing the contrast and brightness of an image! tutorial.') parser.add_argument('--input', help='Path to input image.', default='lena.jpg') args = parser.parse_args() image = cv.imread(cv.samples.findFile(args.input)) if image is None: print('Could not open or find the image: ', args.input) exit(0) new_image = np.zeros(image.shape, image.dtype) alpha = 1.0 # Simple contrast control beta = 0 # Simple brightness control # Initialize values print(' Basic Linear Transforms ') print('-------------------------') try: alpha = float(input('* Enter the alpha value [1.0-3.0]: ')) beta = int(input('* Enter the beta value [0-100]: ')) except ValueError: print('Error, not a number') # Do the operation new_image(i,j) = alpha*image(i,j) + beta # Instead of these 'for' loops we could have used simply: # new_image = cv.convertScaleAbs(image, alpha=alpha, beta=beta) # but we wanted to show you how to access the pixels :) for y in range(image.shape[0]): for x in range(image.shape[1]): for c in range(image.shape[2]): new_image[y,x,c] = np.clip(alpha*image[y,x,c] + beta, 0, 255) cv.imshow('Original Image', image) cv.imshow('New Image', new_image) # Wait until user press some key cv.waitKey()
提示module 'cv2' has no attribute 'samples'的話要先安裝pip install opencv-python==4.0.0.21.
執(zhí)行:python change_brightness_contrast.py --input ./lights.jpeg
線性變換有個(gè)問(wèn)題,如上圖,α=1.3 and β=40,提高原圖亮度的同時(shí),導(dǎo)致云幾乎看不見(jiàn)了.如果要看見(jiàn)云的話,建筑的亮度又不夠.
這個(gè)時(shí)候就引入了非線性變換. 稱之為Gamma correction
\(O = \left( \frac{I}{255} \right)^{\gamma} \times 255\)
與線性變換不同,對(duì)不同的原始亮度值,其改變強(qiáng)度是不同的,是非線性的.
在 γ<1的時(shí)候,會(huì)提高圖片亮度.>1時(shí),降低亮度.
γ=0.4的變換效果圖如上.可以看到云層及建筑變亮的同時(shí)還保持了對(duì)比度讓圖像依然清晰.
如果查看不同變換下的灰度直方圖的話可以看到.中間是原圖的灰度直方圖,可以看到低亮度值的像素點(diǎn)很多.
左邊是做了線性變換的,整體直方圖產(chǎn)生了右移,并且在255處出現(xiàn)峰值.因?yàn)槊總€(gè)像素點(diǎn)都增加了亮度嘛.導(dǎo)致了白云和藍(lán)天過(guò)于明亮無(wú)法區(qū)分.
而右邊做了gamma校正的圖像亮度分布比較均勻,即使得低亮度值的部分得以加強(qiáng),又不至于過(guò)度曝光使得白云無(wú)法區(qū)分.
實(shí)現(xiàn)Gamma correction的代碼如下.
lookUpTable = np.empty((1,256), np.uint8) for i in range(256): lookUpTable[0,i] = np.clip(pow(i / 255.0, gamma) * 255.0, 0, 255) res = cv.LUT(img_original, lookUpTable)
關(guān)于使用opencv怎么調(diào)整圖像亮度和對(duì)比度問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。