Python基于Tensor FLow的圖像處理操作詳解
本文實(shí)例講述了Python基于Tensor FLow的圖像處理操作。分享給大家供大家參考,具體如下:
在對(duì)圖像進(jìn)行深度學(xué)習(xí)時(shí),有時(shí)可能圖片的數(shù)量不足,或者希望網(wǎng)絡(luò)進(jìn)行更多的學(xué)習(xí),這時(shí)可以對(duì)現(xiàn)有的圖片數(shù)據(jù)進(jìn)行處理使其變成一張新的圖片,在此基礎(chǔ)上進(jìn)行學(xué)習(xí),從而提高網(wǎng)絡(luò)識(shí)別的準(zhǔn)確率。
1、圖像解碼顯示
利用matplot庫(kù)可以方便簡(jiǎn)潔地在jupyter內(nèi)對(duì)圖片進(jìn)行繪制與輸出,首先通過tf.gfile打開圖片文件,并利用函數(shù)tf.image.decode_jpeg將jpeg圖片解碼為三位矩陣,之后便可以通過matplot繪制與顯示圖片信息了
import matplotlib.pyplot as plt import tensorflow as tf import numpy as np #讀取圖像文件 image_raw=tf.gfile.GFile('D:\Temp\MachineLearning\data\cat.jpeg','rb').read() with tf.Session() as sess: #對(duì)jpeg圖像解碼得到圖像的三位矩陣數(shù)據(jù) image_data=tf.image.decode_jpeg(image_raw) print(image_data.eval()) plt.imshow(image_data.eval()) plt.show()
可以看到打印的圖片三維矩陣信息和顯示的圖片:
2、圖像縮放
tensorflow還自帶了許多圖像處理函數(shù),比如resize_image對(duì)圖片進(jìn)行大小的縮放。其中第一個(gè)參數(shù)代表圖片數(shù)據(jù)源,第二個(gè)數(shù)組代表縮放后的大小,第三個(gè)method代表采用的縮放方法,默認(rèn)0是雙線性插值法,1代表最近鄰插值法,2代表雙立方插值法,3代表像素區(qū)域插值法。
#對(duì)圖片大小進(jìn)行縮放 image_resize=tf.image.resize_images(image_data,[500,500],method=0) #tensorflow處理后的圖片是float32格式的,需要轉(zhuǎn)化為uint8才能正確輸出 image_resize=np.asarray(image_resize.eval(),dtype='uint8') plt.imshow(image_resize) plt.show()
3、圖像裁切
函數(shù)tf.image.resize_image_with_crop_or_pad可以在保證圖片原始比例的條件下對(duì)圖片進(jìn)行裁切或填充。
函數(shù)tf.image.random_crop是隨機(jī)對(duì)圖片進(jìn)行選取裁剪,而不是以中心。
#圖片裁剪 image_crop=tf.image.resize_image_with_crop_or_pad(image_data,500,500) plt.imshow(image_crop.eval()) plt.show() #隨機(jī)裁剪 img_random=tf.image.random_crop(image_data,[300,300,3]) plt.imshow(img_random.eval()) plt.show()
resize_image_with_crop_or_pad第一個(gè)參數(shù)是圖片資源,后兩個(gè)參數(shù)是裁切后的圖片大小,當(dāng)原始圖片大于目標(biāo)值時(shí)將裁去兩邊多余部分,當(dāng)圖片小于目標(biāo)值時(shí)將用黑色填充,例如上圖左右被裁剪,上下用黑色填充。
random_crop第一個(gè)參數(shù)是圖片資源,第二個(gè)參數(shù)是一個(gè)三位張量,代表目標(biāo)圖像大小。
4、圖像翻轉(zhuǎn)
通過函數(shù)實(shí)現(xiàn)圖片的上下、左右翻轉(zhuǎn),在模型訓(xùn)練時(shí),可以將原本的樣本圖片進(jìn)行反轉(zhuǎn),作為新的特征值進(jìn)行輸入供模型訓(xùn)練。
#上下翻轉(zhuǎn) img_down=tf.image.flip_up_down(image_data) plt.imshow(img_down.eval()) plt.show() #左右翻轉(zhuǎn) img_left=tf.image.flip_left_right(image_data) plt.imshow(img_left.eval()) plt.show()
5、調(diào)整對(duì)比度、明度、飽和度
通過tf.image.adjust_contrast可以對(duì)圖像對(duì)比度進(jìn)行調(diào)整,當(dāng)參數(shù)大于1代表加深,小于1代表減淡
tf.image.random_contrast可以在指定范圍內(nèi)隨即調(diào)整對(duì)比度
類似的還有adjust_brightness、adjust_saturation、adjust_hue對(duì)明度、飽和度、色相進(jìn)行調(diào)整
#加深對(duì)比度 img_deep=tf.image.adjust_contrast(image_data,2) plt.imshow(img_deep.eval()) plt.show() #降低對(duì)比度 img_fade=tf.image.adjust_contrast(image_data,0.5) plt.imshow(img_fade.eval()) plt.show() #隨機(jī)對(duì)比度 img_contrast=tf.image.random_contrast(image_data,0.5,2) plt.imshow(img_contrast.eval()) plt.show()
6、對(duì)VGG網(wǎng)絡(luò)的輸入圖片進(jìn)行處理
Vgg網(wǎng)絡(luò)訓(xùn)練中傳入的圖片參數(shù)x_img是以batch_size為單位的四維數(shù)據(jù),例如傳入20張32×32的3通道圖片,其數(shù)據(jù)為[20,32,32,3]。但是tensorflow的圖片處理函數(shù)只可以處理三維的單張圖片。因此需要首先通過split()函數(shù)將20張圖片拆分成單張[1,32,32,3],再通過reshape()函數(shù)轉(zhuǎn)化為三維數(shù)據(jù)[32,32,3],之后再調(diào)用圖片處理函數(shù)對(duì)圖片進(jìn)行處理,將處理后的圖片恢復(fù)成四維,然后放在數(shù)組res_arr中,拼接成原來的一組20×32×32×3的數(shù)據(jù)。
# 將一批batch_size張圖片在第一維上切分為單張圖片 img_arr=tf.split(x_img,batch_size,axis=0) res_arr=[] # 遍歷每個(gè)圖片對(duì)其進(jìn)行處理 for img in img_arr: # 將單張四維的圖片[1,32,32,3]處理成三維[32,32,3] img=tf.reshape(img,[32,32,3]) # 對(duì)單張圖片進(jìn)行圖像增強(qiáng) img_flip=tf.image.random_flip_left_right(img) # 翻轉(zhuǎn)圖片 img_bright=tf.image.random_brightness(img_flip,max_delta=63) # 隨機(jī)調(diào)整亮度 img_contrast=tf.image.random_contrast(img_bright,lower=0.2, upper=1.8) # 調(diào)整對(duì)比度 # 將增強(qiáng)后的圖片再變回原來的四維格式 img=tf.reshape(img_contrast,[1,32,32,3]) # 將每個(gè)處理后的圖片放在一個(gè)數(shù)組 res_arr.append(img) # 將處理后的單個(gè)圖片重新拼接在一起 img_aug=tf.concat(res_arr,axis=0)
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Django開發(fā)web后端對(duì)比SpringBoot示例分析
這篇文章主要介紹了Django開發(fā)web后端對(duì)比SpringBoot示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12python 字符串和整數(shù)的轉(zhuǎn)換方法
今天小編就為大家分享一篇python 字符串和整數(shù)的轉(zhuǎn)換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-06-06Python裝飾器的應(yīng)用場(chǎng)景代碼總結(jié)
這篇文章主要介紹了Python裝飾器的應(yīng)用場(chǎng)景,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04使用Python實(shí)現(xiàn)BT種子和磁力鏈接的相互轉(zhuǎn)換
這篇文章主要介紹了使用Python實(shí)現(xiàn)BT種子和磁力鏈接的相互轉(zhuǎn)換的方法,有時(shí)比如迅雷無(wú)法加載磁力鏈接或者無(wú)法上傳附件分享時(shí)可以用到,需要的朋友可以參考下2015-11-11pytorch之關(guān)于PyTorch結(jié)構(gòu)介紹
這篇文章主要介紹了pytorch之關(guān)于PyTorch結(jié)構(gòu)的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Python實(shí)現(xiàn)的單向循環(huán)鏈表功能示例
這篇文章主要介紹了Python實(shí)現(xiàn)的單向循環(huán)鏈表功能,簡(jiǎn)單描述了單向循環(huán)鏈表的概念、原理并結(jié)合實(shí)例形式分析了Python定義與使用單向循環(huán)鏈表的相關(guān)操作技巧,需要的朋友可以參考下2017-11-11使用python執(zhí)行shell腳本 并動(dòng)態(tài)傳參 及subprocess的使用詳解
這篇文章主要介紹了使用python執(zhí)行shell腳本 并動(dòng)態(tài)傳參 及subprocess的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03python中protobuf和json互相轉(zhuǎn)換應(yīng)用處理方法
protobuf目前有proto2和proto3兩個(gè)版本,本文所介紹的是基于proto3,在Python 3.6.9環(huán)境下運(yùn)行,本文記錄一下python中protobuf和json的相互轉(zhuǎn)換的處理方法,感興趣的朋友跟隨小編一起看看吧2022-12-12Python 實(shí)現(xiàn)「食行生鮮」簽到領(lǐng)積分功能
今天我們就用 Python 來實(shí)現(xiàn)自動(dòng)簽到,省得我每天打開 APP 來操作了。感興趣的朋友跟隨小編一起看看吧2018-09-09