溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用Tensorflow訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存

發(fā)布時(shí)間:2021-08-13 17:52:10 來源:億速云 閱讀:307 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了如何使用Tensorflow訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

制作自己的訓(xùn)練集

下圖是我們數(shù)據(jù)的存放格式,在data目錄下有驗(yàn)證集與測試集分別對(duì)應(yīng)iris_test, iris_train

如何使用Tensorflow訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存

為了向偉大的MNIST致敬,我們采用的數(shù)據(jù)名稱格式和MNIST類似

如何使用Tensorflow訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存

classification_index.jpg

圖像的index都是5的整數(shù)倍是因?yàn)槲覀冞x擇測試集的原則是每5個(gè)樣本,選擇一個(gè)樣本作為測試集,其余的作為訓(xùn)練集和驗(yàn)證集

生成這樣數(shù)據(jù)的過程相對(duì)簡單,如果有需要python代碼的,可以給我發(fā)郵件,或者在我的github下載

至此,我們的訓(xùn)練集,測試集,驗(yàn)證集就生成成功了,之所以我們的文件夾只有訓(xùn)練集和測試集是因?yàn)槲覀冊(cè)诤罄m(xù)的訓(xùn)練過程中,會(huì)在訓(xùn)練集中分出一部分作為驗(yàn)證集,所以兩者暫時(shí)合稱為訓(xùn)練集

將數(shù)據(jù)集寫入到Tensorflow中

1. 直接寫入到隊(duì)列中

import tensorflow as tf
import numpy as np
import os

train_dir = '/home/ruyiwei/data/iris_train/'#your data directory
def get_files(file_dir):
  '''
  Args:
    file_dir: file directory
  Returns:
    list of images and labels
  '''
  iris = []
  label_iris = []
  contact = []
  label_contact = []
  for file in os.listdir(file_dir):
    name = file.split('_')
    if name[0]=="iris":
      iris.append(file_dir + file)
      label_iris.append(0)
    else:
      contact.append(file_dir + file)
      label_contact.append(1)
  print('There are %d iris\nThere are %d contact' %(len(iris), len(contact)))

  image_list = np.hstack((iris, contact))
  label_list = np.hstack((label_iris, label_contact))

  temp = np.array([image_list, label_list])
  temp = temp.transpose()
  np.random.shuffle(temp)

  image_list = list(temp[:, 0])
  label_list = list(temp[:, 1])
  label_list = [int(i) for i in label_list]

  return image_list, label_list

為了大家更方便的理解和修改代碼,我們對(duì)代碼進(jìn)行講解如下

1-3行 : 導(dǎo)入需要的模塊
5行: 定義訓(xùn)練集合的位置,這個(gè)需要根據(jù)自己的機(jī)器進(jìn)行修改
7行: 定義函數(shù) get_files
18行: os.listdir(file_dir) 獲取指定目錄file_dir下的所有文件名詞,也就是我們的訓(xùn)練圖片名稱
18行:for file in os.listdir(file_dir): 遍歷所有的圖片
19行: name為一個(gè)數(shù)組,由于我們根據(jù)MINIST來定制的圖片名詞,所以file.split(‘_')會(huì)將圖像名稱分為兩部分,第一部分為classification,通過name[0]來獲得分類信息。
21行、24行:iris.append(file_dir + file)/contact.append(file_dir + file)將圖像的絕對(duì)路徑放入到iris/contact
22行、25行:label_iris.append(0)/label_contact.append(1)給對(duì)應(yīng)的圖片貼標(biāo)簽
28-29行:將二分類的圖像與標(biāo)簽壓入到list中
31-33行:合并二分類圖像,然后打亂
38行:返回打亂后對(duì)應(yīng)的圖像與標(biāo)簽

在spyder下執(zhí)行如上代碼后會(huì)返回如下信息

如何使用Tensorflow訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存

這樣圖像和標(biāo)簽信息就被load到了內(nèi)存中,我們接下來就可以利用現(xiàn)有的模型對(duì)圖像進(jìn)行分類訓(xùn)練,模型的選擇和訓(xùn)練的過程,我們會(huì)在后面進(jìn)行講解。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何使用Tensorflow訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI