一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 淺談tensorflow 中的圖片讀取和裁剪方式

淺談tensorflow 中的圖片讀取和裁剪方式

2020-07-01 10:25Kuhner Python

這篇文章主要介紹了淺談tensorflow 中的圖片讀取和裁剪方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

一 方式1: skimage

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
from skimage import data, io, transform, color
import matplotlib.pyplot as plt
 
# io.imread 讀出的圖片格式是uint8,value是numpy array 類型。
image = data.coffee()
image = io.imread(dir)
 
plt.imshow(image)
plt.show()
 
io.save('1.jpg',image) #保存圖像
 
image_gray = color.rgb2gray(image) #轉換為灰度圖像
io.save('2.jpg',image_gray)
 
# 通過transform.resize()裁剪后的圖片是以 float64的格式存儲的,數值的取值范圍是(0~1)
image_ = transform.resize(image,(200,200))
img = image_ * 255 #將圖片的取值范圍改成(0~255)
img = img.astype(np.uint8)
img = image_ * 255 #將圖片的取值范圍改成(0~255)
img = img.astype(np.uint8)

二、方式2:cv2

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import cv2
import matplotlib.pyplot as plt
 
# cv2.imread讀出的圖片格式是uint8,value也是numpy array 類型。
# 圖像數據格式是以BGR的格式進行存儲的。需要將存儲類型改成RGB 的形式才能正常顯示原圖的顏色。
image=cv2.imread(dir)
b,g,r = cv2.split(image)  #將圖像通道分離開
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新組合
#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用這個函數直接轉換成RGB 形式
plt.imshow(rgb_image)
 
# 通過cv2.resize()裁剪后的圖片還是以 numpy array 的方式保存的, 數值的取值范圍是(0~255)
image_cv2 = cv2.resize(rgb_image)
 
image=cv2.imread(dir)
b,g,r = cv2.split(image)  #將圖像通道分離開
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新組合
#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用這個函數直接轉換成RGB 形式
plt.imshow(rgb_image)
 
# 通過cv2.resize()裁剪后的圖片還是以 numpy array 的方式保存的, 數值的取值范圍是(0~255)
image_cv2 = cv2.resize(rgb_image)

補充知識:tensorflow中兩種讀圖及裁剪圖片的區別(io.imread和cv2.imread)以及(transform.resize和cv2.resize)

Tensorflow中,在訓練圖片數據之前,需要先對圖片進行預處理,讀圖和裁剪是最基本的兩步。常見的的讀圖何裁剪分別有兩種方式,這里小編將和大家分享下這幾種方式的實現以及他們之間的區別。

一、常見的兩種讀圖方式 io.imread() 和 cv2.imread()

1.io.imread 讀出的圖片格式是uint8,value是numpy array 類型。對于RGB 圖片,圖像數據是以RGB 的格式進行存儲的。

淺談tensorflow 中的圖片讀取和裁剪方式

2.cv2.imread讀出的圖片格式是uint8 ,value也是numpy array 類型。唯一的區別是,圖像數據格式是以BGR的格式進行存儲的。需要將存儲類型改成RGB 的形式才能正常顯示原圖的顏色。特別是制作tfrecord 時,需要將圖片通道改成RGB,具體代碼如下。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import cv2
import matplotlib.pyplot as plt
from skimage import transform
import numpy as np
import skimage.io as io
 
train_dir = 'E:/TensorFlow/Project_TF/flower_tfrecord/data/test/roses/timg.jpg'
 
'''以cv2方式讀取圖片'''
image=cv2.imread(train_dir)
b,g,r = cv2.split(image)  #將圖像通道分離開
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新組合
 
#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用這個函數直接轉換成RGB 形式
plt.imshow(rgb_image)
 
'''以io.imread方式讀取圖片'''
#image = io.imread(train_dir) #讀圖并顯示
#plt.imshow(image)

二、常見的兩種圖片裁剪方式 cv2.resize() 和 transform.resize()

1.通過cv2.resize()裁剪后的圖片還是以 numpy array 的方式保存的, 數值的取值范圍是(0~255)

淺談tensorflow 中的圖片讀取和裁剪方式

2.通過transform.resize()裁剪后的圖片是以 float64的格式存儲的,數值的取值范圍是(0~1)。通常在制作tfrecord 數據集的過程中,我們需要將其轉換成numpy array的形式,具體代碼如下

?
1
2
3
4
5
6
7
8
'''以io.imread方式讀取圖片并使用transform形式裁剪圖片'''
image = io.imread(train_dir) #讀圖并顯示
plt.imshow(image)
image =transform.resize(image, (208, 208))
img = image * 255 #將圖片的取值范圍改成(0~255)
img = img.astype(np.uint8)
 
plt.imshow(img)

讀圖和裁剪圖片在制作tfrecord數據集時,是很基礎的步驟,在接下來,我還將進一步更新如何制作自己的tfrecord數據集,以及tfrecord的讀取。如有謬誤,還請大家斧正。

以上這篇淺談tensorflow 中的圖片讀取和裁剪方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/dkuhn/article/details/80719452

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 18无删减羞羞网站动漫 | 亚洲 综合 欧美在线视频 | 国产精品日韩欧美一区二区 | 国内交换一区二区三区 | 俺去俺去啦最新官网在线 | 不卡视频一区二区 | 久久综合久综合久久鬼色 | 成在线人免费视频一区二区三区 | 亚洲欧美国产精品久久久 | 504神宫寺奈绪大战黑人 | 日本嫩模| 亚洲丁香网 | av毛片在线看| 国产精品成人在线播放 | 精选国产AV精选一区二区三区 | 亚洲精品久久中文字幕 | 免费一看一级毛片人 | 日韩在线视频免费不卡一区 | 日韩毛片免费 | 黄a 大片a v 永久免费 | 娇妻与公陈峰姚瑶小说在线阅读 | 国产原创一区二区 | 欧美日韩亚洲综合在线一区二区 | 欧美日韩不卡视频 | 精品国产一区二区在线观看 | 国产乱妇无码大片在线观看 | 亚洲天堂免费 | 香蕉eeww99国产在线观看 | 九九精品成人免费国产片 | 天天做天天爱天天综合网 | 欧美日韩中文字幕在线视频 | 午夜深情在线观看免费 | 久久99国产精品二区不卡 | 青草视频在线观看免费网站 | 国内自拍网红在线自拍综合 | 果冻传媒天美传媒在线小视频播放 | 狠狠色成人综合 | 手机看片一区二区 | 高清视频免费 | 色婷婷久久综合中文久久一本 | 91桃色污|