Python?OpenCV實(shí)現(xiàn)圖像增強(qiáng)操作詳解
創(chuàng)作背景
最近在忙著兩個(gè)YOLOv7項(xiàng)目,通過看大量的論文,發(fā)現(xiàn)很多的相關(guān)的論文都會在收集圖像后進(jìn)行圖像的增強(qiáng),本文將使用python中的opencv模塊實(shí)現(xiàn)常見的圖像增強(qiáng)方法。
由于光照角度和天氣等不確定因素,導(dǎo)致圖像采集的光環(huán)境極其復(fù)雜;為了提高目標(biāo)檢測模型的泛化能力,本文采用了幾種圖像增強(qiáng)方法。
圖像增強(qiáng)方法包括
- 圖像亮度增強(qiáng)和降低
- 水平鏡像
- 垂直鏡像
- 多角度旋轉(zhuǎn)(90°?,180°?,270°?)
- 高斯噪聲
此外,考慮到圖像采集設(shè)備在圖像采集過程中產(chǎn)生的噪聲,以及設(shè)備或樹枝晃動造成的拍攝圖像模糊,在圖像中加入方差為0.02的高斯噪聲,進(jìn)行運(yùn)動模糊處理。
圖像亮度增強(qiáng)和降低
圖像亮度。指數(shù)字圖像中包含色彩的明暗程度,是人眼對物體本身明暗程度的感覺。
圖像亮度調(diào)節(jié)可以采用最簡單的圖像處理算法,通過常見的線性運(yùn)算即完成亮度調(diào)節(jié),這里我們讓所有的像素點(diǎn)亮度值乘上一個(gè)增強(qiáng)系數(shù) percetage,使得圖像整體變亮或者變暗。
# 變暗
def Darker(image,percetage=0.9):
image_copy = image.copy()
w = image.shape[1]
h = image.shape[0]
#get darker
for xi in range(0,w):
for xj in range(0,h):
image_copy[xj,xi,0] = int(image[xj,xi,0]*percetage)
image_copy[xj,xi,1] = int(image[xj,xi,1]*percetage)
image_copy[xj,xi,2] = int(image[xj,xi,2]*percetage)
return image_copy
# 明亮
def Brighter(image, percetage=1.1):
image_copy = image.copy()
w = image.shape[1]
h = image.shape[0]
#get brighter
for xi in range(0,w):
for xj in range(0,h):
image_copy[xj,xi,0] = np.clip(int(image[xj,xi,0]*percetage),a_max=255,a_min=0)
image_copy[xj,xi,1] = np.clip(int(image[xj,xi,1]*percetage),a_max=255,a_min=0)
image_copy[xj,xi,2] = np.clip(int(image[xj,xi,2]*percetage),a_max=255,a_min=0)
return image_copy
旋轉(zhuǎn)
本文使用opencv中的使用getRotationMatrix2D() 函數(shù)和warpAffine() 函數(shù)實(shí)現(xiàn)旋轉(zhuǎn)原始圖像,通過改變函數(shù)參數(shù)“angle”分別實(shí)現(xiàn)90°?、180°?、270°旋轉(zhuǎn)。變換后的圖像可以通過正確識別不同方位的目標(biāo)來提高模型的檢測性能。改變函數(shù)參數(shù)scal一個(gè)各向同性比例因子,根據(jù)提供的值向上或向下縮放圖像。
# 旋轉(zhuǎn),R可控制圖片放大縮小
def Rotate(image, angle=15, scale=1):
w = image.shape[1]
h = image.shape[0]
#rotate matrix
M = cv2.getRotationMatrix2D((w/2,h/2), angle, scale)
#rotate
image = cv2.warpAffine(image,M,(w,h))
return image
水平鏡像和垂直鏡像
圖像鏡像(水平和垂直鏡像)是通過opencv中的使用flip函數(shù)實(shí)現(xiàn)的,通過以圖像的垂直線為中心變換圖像的左側(cè)和右側(cè)來實(shí)現(xiàn)水平鏡像。垂直鏡像是通過以圖像的水平中心線為中心變換圖像的上下側(cè)來實(shí)現(xiàn)的。
# 水平翻轉(zhuǎn)
def Horizontal(image):
return cv2.flip(image,1,dst=None)
# 垂直翻轉(zhuǎn)
def Vertical(image):
return cv2.flip(image,0,dst=None)
高斯噪聲
本文使用NumPy中的可以產(chǎn)生符合高斯分布(正態(tài)分布)的隨機(jī)數(shù)的 np.random.normal()函數(shù)。利用產(chǎn)生隨機(jī)數(shù)的函數(shù)來對圖像添加方差為0.02的高斯噪聲。
def gaussian_noise(image, mean=0, var=0.02):
# 添加高斯噪聲
# mean : 均值
# var : 方差
image = np.array(image / 255, dtype=float)
noise = np.random.normal(mean, var ** 0.5, image.shape)
out = image + noise
if out.min() < 0:
low_clip = -1.
else:
low_clip = 0.
out = np.clip(out, low_clip, 1.0)
out = np.uint8(out * 255)
return out
其它圖像增強(qiáng)的方法
# 放大縮小
def Scale(image, scale):
return cv2.resize(image,None,fx=scale,fy=scale,interpolation=cv2.INTER_LINEAR)
# 平移
def Move(img,x,y):
img_info=img.shape
height=img_info[0]
width=img_info[1]
mat_translation=np.float32([[2,0,x],[0,2,y]]) #變換矩陣:設(shè)置平移變換所需的計(jì)算矩陣:2行3列
#[[1,0,20],[0,1,50]] 表示平移變換:其中x表示水平方向上的平移距離,y表示豎直方向上的平移距離。
dst=cv2.warpAffine(img,mat_translation,(width,height)) #變換函數(shù)
# 椒鹽噪聲
def SaltAndPepper(src,percetage=0.05):
SP_NoiseImg=src.copy()
SP_NoiseNum=int(percetage*src.shape[0]*src.shape[1])
for i in range(SP_NoiseNum):
randR=np.random.randint(0,src.shape[0]-1)
randG=np.random.randint(0,src.shape[1]-1)
randB=np.random.randint(0,3)
if np.random.randint(0,1)==0:
SP_NoiseImg[randR,randG,randB]=0
else:
SP_NoiseImg[randR,randG,randB]=255
return SP_NoiseImg
#模糊
def Blur(img):
blur = cv2.GaussianBlur(img, (7, 7), 1.5)
# # cv2.GaussianBlur(圖像,卷積核,標(biāo)準(zhǔn)差)
return blur適用于項(xiàng)目的的整體代碼
為了滿足項(xiàng)目的使用,我對上述代碼進(jìn)行了了擴(kuò)充,實(shí)現(xiàn)了對單個(gè)圖片,單個(gè)文件夾和多個(gè)文件夾中多個(gè)圖片的圖像的增強(qiáng)

到此這篇關(guān)于Python OpenCV實(shí)現(xiàn)圖像增強(qiáng)操作詳解的文章就介紹到這了,更多相關(guān)Python OpenCV圖像增強(qiáng)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python使用openpyxl實(shí)現(xiàn)Excel超鏈接批量化設(shè)置
在Excel中,超鏈接是一種非常有用的功能,本文我們將介紹如何使用Python來處理Excel中的超鏈接,以及如何將超鏈接與對應(yīng)的工作表鏈接起來,需要的可以參考一下2023-07-07
Keras多線程機(jī)制與flask多線程沖突的解決方案
這篇文章主要介紹了Keras多線程機(jī)制與flask多線程沖突的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05
Matplotlib的反轉(zhuǎn)軸、繪制雙軸和定制刻度詳解
這篇文章主要介紹了Matplotlib的反轉(zhuǎn)軸、繪制雙軸和定制刻度詳解,作為Python生態(tài)中應(yīng)用最廣泛的繪圖庫,Matplotlib用起來非常簡單,也很容易上手,本文匯總了和軸、刻度相關(guān)的七個(gè)Matplotlib使用技巧,并給出了實(shí)例代碼,需要的朋友可以參考下2023-08-08
Python os.rename() 重命名目錄和文件的示例
今天小編就為大家分享一篇Python os.rename() 重命名目錄和文件的示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
利用4行Python代碼監(jiān)測每一行程序的運(yùn)行時(shí)間和空間消耗
這篇文章主要介紹了如何使用4行Python代碼監(jiān)測每一行程序的運(yùn)行時(shí)間和空間消耗,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
pandas?實(shí)現(xiàn)?in?和?not?in?的用法及使用心得
pandas按條件篩選數(shù)據(jù)時(shí),除了使用query()方法,還可以使用isin和對isin取反進(jìn)行條件篩選,今天通過本文給大家介紹pandas?實(shí)現(xiàn)?in?和?not?in?的用法及使用心得,感興趣的朋友跟隨小編一起看看吧2023-01-01

