女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Keras和TensorFlow究竟哪個會更好?

電子工程師 ? 來源:未知 ? 作者:李倩 ? 2018-10-11 10:05 ? 次閱讀

深度學習發展勢頭迅猛,但近兩年涌現的諸多深度學習框架讓初學者無所適從。如 Google 的 TensorFlow亞馬遜的 MXNet、Facebook 支持的 PyTorch、Theano、Caffe、CNTK、Chainer、百度的 PaddlePaddle、DSSTNE、DyNet、BigDL、Neon 等等。

在這其中,TensorFlow 作為最為著名的用于深度學習生產環境的框架,它有一個非常強大的生態體系支持,然而,相比其他框架,TensorFlow 也有其劣勢,如速度較慢、使用上手難。而基于 TensorFlow 基礎上構建的 Keras 提供了簡單易用的 API 接口,非常適合初學者使用。

2017 年 1 月,隨著 Keras 的作者、谷歌 AI 研究員 Francois Chollet 的一條消息的宣布,Keras 成為第一個被添加到 TensorFlow 核心的高級別框架,Keras 從此成為 Tensorflow 的默認 API。

“那么,我應該在項目中使用 Keras 還是 TensorFlow?Keras 和 TensorFlow 究竟哪個會更好?我應該把時間花在研究 TensorFlow 還是 Keras 上?”

在與深度學習的研究人員、從業者包括工程師在內的交談中,“Deep Learning for Computer Vision with Python ”一書作者 Adrian Rosebrock 聽到了他們的困惑。

就 Keras 和 TensorFlow 而言,Rosebrock 認為開發者更應該關注的是當 Keras 實際上已被完全采用并整合到 TensorFlow 后,自己可以:

使用 Keras 易于使用的界面定義模型。

如果需要 TensorFlow 的特定功能,或需要實現 Keras 不支持但 TensorFlow 支持的自定義功能,則調入 TensorFlow。

他給出的建議是先使用 Keras ,然后下載 TensorFlow 以獲取可能需要的任何特定功能。文本中,Rosebrock展示了如何訓練使用 Keras 的神經網絡和使用直接構建在 TensorFlow 庫中的 Keras+TensorFlow 集成(具有自定義功能)的模型。

下面開始正文:

▌對比 Keras 和 TensorFlow 沒什么意義

前些年,深度學習領域的研究人員、開發人員和工程師必須經常做出一些選擇:

我應該選擇易于使用但自定義困難的 Keras 庫?

還是應該使用難度更大的 TensorFlow API,編寫大量代碼?(更不用說一個不那么容易使用的 API 了。)

如果你陷于“我應該使用 Keras 還是 TensorFlow”這樣的問題,你可以退一步再看,其實這是一個錯誤的問題,因為你可以選擇同時使用兩個。

我會使用基于 TensorFlow 的標準 keras 模塊和 tf.keras 模塊,來實現一個卷積神經網絡(CNN)。然后,基于一個示例數據集,來訓練這些 CNN,然后檢查所得結果,你會發現,Keras 和 TensorFlow 是可以和諧共處的。

雖然自一年多之前,TensorFlow 就宣稱 Keras 將被并入 TensorFlow 的官方發布版本中,但令我詫異的是,仍有很多深度學習開發者沒有意識到,他們可以通過 tf.keras 子模塊來調用 Keras。更重要的是,Keras 與 TensorFlow 是無縫銜接的,使得我們將 TensorFlow 的源代碼直接寫入 Keras 模型中。

在 TensorFlow 中結合 Keras 使用,會有雙贏效果:

你可以使用 Keras 提供的簡單、原生 API 來創建自己的模型。

Keras 的 API 類似于 scikit-learn 的,都可稱為機器學習的優質 API。

Keras 的 API 是模塊化的、基于 Python ,并且極其易于使用。

當你需要實現一個自定義的層或更復雜的損失函數時,你可以深入使用 TensorFlow,將代碼自動地與 Keras 模型相結合。

▌Keras 通過 tf.keras 模塊構建到 TensorFlow 中

可以看到,我們通過引入 TensorFlow (tf) 并調用 tf.keras,在 Python shell 中展示了 Keras 實際上是 TensorFlow 的一部分。

tf.keras 中的 Keras 允許我們使用標準的 Keras 包獲取下面這樣簡單的前饋神經網絡:

接下來基于 TensorFlow 的一部分 —— tf.keras 子模塊,來實現同樣的網絡:

然而這是否意味著你必須使用 tf.keras?從而現在放棄使用標準 Keras 包了嗎?當然不是!

Keras 依然作為一個庫,與 TensorFlow 分開,進行獨立操作,所以仍存在未來兩者會分開的可能性;然而,我們知道 Google 官方同時支持 Keras 和 TensorFlow,分開似乎又是極不可能發生的。

但重點在于:

如果你更喜歡只基于 Keras 來編程,那就這么做吧,以后可以一直如此。但如果你是 TensorFlow 用戶,你應該開始考慮 Keras API 了,因為:

它是基于 TensorFlow 創建的

它更易于使用

當你需要用純 TensorFlow 實現特定性能或功能時,它可以直接用于你的 Keras。

▌示例數據集

CIFAR-10 數據集有10個類,我們用該數據集來展示本文的觀點

為了簡單起見,我們就在 CIFAR-10 數據集上訓練兩個單獨的卷積神經網絡 (CNN),方案如下:

方法 1 :以 TensorFlow 作為后端的 Keras 模型

方法 2 :使用tf.keras中 Keras 子模塊

在介紹的過程中我還會展示如何把自定義的 TensorFlow 代碼寫入你的 Keras 模型中。

CIFAR-10 數據集包括10個單獨的類,50,000 張訓練圖片和 10,000 張測試圖片。

▌項目結構

我們可以在終端使用 tree 指令來查看該項目的結構:

pyimagesearch模塊被包括在與網絡條目相關的下載中。它不能通過 pip 來安裝,但包含在 "Downloads"后的結果中。我們先回顧一下該模塊中兩個重要的 Python 文件:

minivggnetkeras.py:此文件是基于 Keras 實現的 MiniVGGNet 網絡,一個基于 VGGNet 的深度學習模型。

minivggnettf.py:此文件是基于 TensorFlow + Keras (如 tf.keras)實現的 MiniVGGNet 網絡。

該項目的根目錄包含兩個 Python 文件:

train_network_keras.py:用 Keras 實現的訓練腳本;

train_network_tf.py: TensorFlow + Keras 實現需要的訓練腳本,與前者基本相同;但我們仍會進行說明,并標出不同之處。

每個腳本都會生成各自訓練的 accuracy 和 loss 曲線:

plot_keras.png

plot_tf.png

接下來就會向大家介紹基于 Keras 和 TensorFlow + Keras (tf.keras) 實現的 MiniVGGNet 網絡和他們的訓練過程。

▌用 Keras 訓練一個神經網絡

用 Keras 實現的一個 miniVGGNet 卷積神經網絡結構

訓練我們網絡的第一步是在 Keras 中構建網絡的架構。

如果你已經熟悉 Keras 訓練神經網絡的基礎知識,那么我們就開始吧 (如果你對此并不了解的話,請參考相關的介紹性文章)。

相關鏈接:https://www.pyimagesearch.com/2018/09/10/keras-tutorial-how-to-get-started-with-keras-deep-learning-and-python/

首先,打開 minivggnetkeras.py 文件并插入以下代碼:

從導入一系列所需的 Keras 庫開始構建模型。

然后,定義一個的MiniVGGNetKeras類:

我們在第 12 行定義了build方法,并定義inputShape和input參數。 我們假定以 channel last 的規則排序,所以inputShape參數中最后一個值應該對應的是depth值。

下面開始定義卷積神經網絡的主體結構:

從上面這段代碼你可以觀察到我們在每次應用池化 (pooling) 之前都堆疊了一系列卷積 (conv2D),ReLU 激活函數和批規范化層 (batch normalization),以降低卷積操作后的空間維度。此外,我們還使用 Dropout 技術來防止模型的過擬合現象。

對于圖層類型和有關術語的知識,可以參考以前的 Keras 教程

https://www.pyimagesearch.com/2018/09/10/keras-tutorial-how-to-get-started-with-keras-deep-learning-and-python/

如果想深入研究的話,推薦書“Deep Learning for Computer Vision with Python ”

https://www.pyimagesearch.com/deep-learning-computer-vision-python-book/

然后,將全連接層 (FC) 添加到網絡結構中,代碼如下:

我們將 FC 層和 Softmax 分類器添加到網絡中。隨后我們定義神經網絡模型并將其返回給回調函數 (calling function)。

現在我們已經在 Keras 中實現了 CNN 模型的定義。下面,我們創建用于訓練該模型的程序腳本。

打開train_network_keras.py文件并插入以下代碼:

我們首先在代碼的第 2-13 行導入我們模型訓練所需的包。

需要注意的是:

在第 3 行,將 Matplotlib 的后端設置為 Agg,以便我們可以能將訓練圖保存為圖像文件。

在第 6 行,我們導入MiniVGGNetKeras類。

我們使用 scikit-learn 庫中的LabelBinarizer方法進行獨熱編碼 (one-hot encoding),并使用其classification_report方法打印出分類精度統計結果 (分別對應第 7 行和第 8 行)。

我們在第 10 行導入訓練所需的數據庫。

如何使用自定義的數據集,可參考

https://www.pyimagesearch.com/2018/09/10/keras-tutorial-how-to-get-started-with-keras-deep-learning-and-python/

https://www.pyimagesearch.com/2018/04/16/keras-and-convolutional-neural-networks-cnns/

此外,我們還在第 16-19 行解析了一個命令行參數 (輸出 --plot path)。

下面我們就加載 CIFAR-10 數據集,并對標簽進行編碼操作,代碼如下:

在第 24 行和第 25 行中,我們分別加載并提取訓練和測試所需的數據,同時在第 26 和 27 行將數據進行 floating point + scale 轉化。

第 30-36 行我們對標簽進行編碼并初始化真實的labelNames。

模型定義和數據集導入的工作都已經完成。現在可以開始訓練我們的模型,代碼如下:

在第 40-46 行,我們設置訓練過程所需的一些參數和模型優化方法。

然后在第 47-50 行,我們使用MiniVGGNetKeras.build方法初始化我們的模型并進行編譯。

最后,在第 54 和 55 行啟動模型的訓練程序。

下面,我們將對網絡模型進行評估并生成一個結果圖:

在這里,我們利用測試數據來評估我們的模型,并生成 classification_report。最后,我們將評估結果集成并導出結果圖。

需要注意的是,通常在這里我們會將模型序列化并導出我們的模型,以便可以在圖像或視頻處理腳本中使用它,但在這篇教程中我們不介紹這部分的內容。

如果你想要運行以上的腳本,請確認下載本文的源代碼。

然后,打開一個終端并執行以下命令就可以用 Keras 實現一個神經網絡:

在我的電腦 cpu 上運行每個訓練 epoch 只需要 5 多分鐘。訓練結果圖如下:

用 Keras 實現的神經網絡模型,以 Matplotlib 畫出訓練過程的 accuracy/loss 曲線

正如我們從上面終端的輸出看到那樣,我們的模型取得75%的準確度。雖然這不是最先進的模型,但它能比隨機猜測 (1/10) 要好得多。

相比起小型的神經網絡,我們模型的結果實際上是非常好的!

此外,正如我們在輸出圖6中所示,我們模型并不會發生過擬合現象。

▌用 Tensorflow 和 tf.keras 訓練一個神經網絡模型

使用 tf.keras (內置于 TensorFlow 中的模塊) 構建的 MiniVGGNet CNN 架構與我們直接使用 Keras 構建的模型是相同的。在此,出于演示的目的,我改變了其中的激活函數,其他的結構都是相同的。

上面我們已經能夠使用 Keras 庫實現并訓練了一個簡單的 CNN 模型。接下來,我們要做的是:

1.學習如何使用 TensorFlow 中的 tf.keras 模塊實現相同的網絡架構

2.在我們的 Keras 模型中包含一個 TensorFlow 激活函數,而該函數未在Keras中實現。

下面,讓我們開始吧。

首先,打開minivggnettf.py文件,我們將實現 TensorFlow 版的 MiniVGGNet 模型,代碼如下:

在這個 .py 文件中,請注意第 2 行我們需要導入所需的 tensorflow 依賴庫,而 tensorflow 中自帶 tf.keras 子模塊,該子模塊包含我們可以直接調用的所有 Keras 功能。

在模型定義中,我使用 Lambda 層,如代碼中的黃色突出顯示,它可以用于插入自定義激活函數 CRELU (Concatenated ReLUs),

激活函數 CRELU是由 Shang 等人在論文“Understanding and Improving Convolutional Neural Network”中所提出。

CRELU 激活函數在 Keras 中沒有相應的實現,但是在 TensorFlow 中可以。你可以在 TensorFlow 中的 tf.keras 模塊,使用一行代碼來將 CRELU 函數添加到我們的 Keras 模型中。

還需要注意的是:CRELU 函數有兩個輸出,一個 positive ReLU 和一個 negative ReLU,二者連接在一起。對于正值 x,CRELU 函數的返回值是 [x,0];而對于負值 x,CRELU 函數的返回值是 [0,x]。有關該函數的詳細介紹可以參考 Shang 等人的論文。

接下來,我們將用 TensorFlow + Keras 來定義用于訓練MiniVGGNetTF模型的程序。打開 train_network_tf.py 并插入如下代碼:

在 2-12 行,我們導入訓練過程所需的依賴庫。與我們之前的 Keras 版的訓練腳本相比,唯一的變化在于我們導入了 MiniVGGNetTF 類及 tensorflow as tf 而不是使用 Keras。而在第 15-18 行是我們的命令行參數解析部分。

和之前一樣,我們在第 23 行加載模型訓練所需的數據。腳本剩余的部分和之前 Keras 版的訓練過程是一樣的,即提取并分離訓練和測試集數據并編碼我們的標簽。

下面,讓我們開始訓練我們的模型,代碼如下:

在第 39-54 行,是與 Keras 版訓練過程不同的地方,我們用黃色突出顯示,其余部分都是相同的。

在第 58-73 行,我們用測試數據評估我們的模型并繪制最終的結果。

正如你所看到的,我們只是更換了所使用的方法 (使用 tf.keras),實現了幾乎一樣的訓練流程。

然后,打開一個終端并執行以下命令就可以使用 tensorflow + tf.keras 訓練一個神經網絡模型:

訓練完成后,你可以得到如上類似的訓練結果圖:

用 Tensorflow + tf.keras 實現的神經網絡模型,以 Matplotlib 畫出訓練過程的 accuracy/loss 曲線

可以看到,我們用 CRELU 代替原有的 RELU 激活函數,獲得 76% 的準確率; 然而,1% 的準確性提升增加可能是由于網絡中權重的隨機初始化導致的,這還需進行交叉驗證實驗來進一步證明 CRELU 激活函數是否確實能夠提升模型的準確性。當然,原始精度并不是本節所重點關注的內容。

相反,更需要我們注意的是,如何在 Keras 模型內部,用 TensorFlow 的激活函數替換標準 Keras 激活函數!

此外,你也可以使用自定義的激活函數、損失/成本函數或圖層來執行以上相同的操作。

▌總結

在今天的文章中,關于 Keras 和 TensorFlow 我們主要討論了以下幾個問題:

我是否應該在我的項目中使用 Keras 或 TensorFlow?

TensorFlow 比 Keras 要好嗎?

我是否要花時間學習 TensorFlow 或者 Keras?

最終,我們發現,試圖在 Keras 和 TensorFlow 之間作出抉擇變成一個越來越無關緊要的問題。Keras 庫已經通過 tf.keras 模塊直接集成到 TensorFlow 中了。

本質上來說,你可以通過易于使用的 Keras API 來編碼模型和訓練過程,然后用純 TensorFlow 進行自定義實現。

所以,如果你正準備開始學習深度學習,或在糾結下一個項目是“用 Keras 還是 TensorFlow ?”或就是在思考他們兩者間“誰更好?”這些問題,現在正是尋找答案和動力的時候了,而我給你的建議非常簡單:

不多說,先開始!

在你的 Python 項目中輸入 import keras 或者 import tensorflow as tf (這樣你就可以訪問 tf.keras 了)然后開始后續的工作。

TensorFlow 可以直接集成到你的模型和訓練過程中,所以不用去比較特性,功能或易用性,你都可以直接在項目中使用 TensorFlow 或 Keras。

▌讀者的疑問

對此,有讀者提出了尖銳的疑問:

根據上述以及我的了解,不少開發者仍糾纏在 Keras 和 TensorFlow 究竟是什么的問題,可能對此我也不甚了解,但我還是希望提出一些澄清性的問題:

一是在這二者中,將一個視為計算引擎,另一個作為一種工具包是否正確?如果這樣的話,我猜測 TensorFlow 是工具包而 Keras 是計算后端?

二是你也提到 TensorFlow 與 Caffe 的整合,但為了支持 Keras 已經放棄了 Caffe。您能分享您為什么會這樣的原因嗎?是 Caffe不再可用,還是因為 Keras 有了更多功能?

對此,Adrian Rosebrock 回應道:

是的,Keras 本身依賴于 TensorFlow、Theano、CNTK 等后端來執行實際的計算。

Caffe 仍存在,只是其他功能已經分解為 Caffe2 。TensorFlow 從未成為 Caffe 的一部分。我們仍使用 Caffe,尤其是研究人員。但從業者尤其是 Python 的從業者更喜歡編程友好的庫如 TensorFlow、Keras、PyTorch 或 mxnet。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 數據集
    +關注

    關注

    4

    文章

    1223

    瀏覽量

    25276
  • 深度學習
    +關注

    關注

    73

    文章

    5554

    瀏覽量

    122482
  • keras
    +關注

    關注

    2

    文章

    20

    瀏覽量

    6169

原文標題:Keras還是TensorFlow?深度學習框架選型實操分享

文章出處:【微信號:rgznai100,微信公眾號:rgznai100】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    Tensorflow保存和恢復模型的方法

    Tensorflow+Keras入門——保存和恢復模型的方法學習
    發表于 06-03 16:30

    TensorFlow是什么

    的領先地位:圖 1 TensorFlow的領先地位示意圖先來了解一下 TensorFlow 究竟是什么,以及它為什么在 DNN 研究人員和工程師中如此受歡迎。開源深度學習庫 TensorFl
    發表于 07-22 10:14

    RK3399Pro入門教程(4)從Tensorflow.Keras到RKNN

    tensorflow還一直保留著他們自己的pb模型格式文件(配置+權重)。我們直接從Tensorflow官網首頁的教程Mnist入手,大概簡單說明下如何從Tensorflow.Keras搭建訓練模型,然后
    發表于 03-31 16:23

    keras順序模型與函數式模型

    mnist的代碼如下: 方式1:采用model.add 一層層添加 import tensorflow as tf import tensorflow.keras as keras ? print
    發表于 08-18 06:01

    keras可視化介紹

    , Tensorflow, Pytorch, Keras, Caffe等),網頁地址: https://netron.app/ 將上一講生成的keras_mnist.h5導入,得到模型結構,如下圖: 2
    發表于 08-18 07:53

    Keras搭建神經網絡的一般步驟

    1 keras是什么? Keras 是一個用 Python 編寫的高級神經網絡 API,它能夠以 TensorFlow, CNTK, 或者 Theano 作為后端運行。 Keras
    發表于 08-18 07:35

    TensorFlowKeras哪個更好用?

    作為一個庫,Keras 仍然可以單獨使用,因此未來兩者可能會分道揚鑣。不過,因為谷歌官方支持 KerasTensorFlow,所以似乎不太可能出現這種情況。
    的頭像 發表于 10-31 09:40 ?1.1w次閱讀

    TensorFlow 2.0中關于Keras的一些新功能和重大變化

    Keras有以下幾大關鍵優點:用戶友好、模塊化、可組合、容易擴展,既適合新手,也適合專家。這些優點加起來。可以讓學習、研究、開發、部署的工作流更加容易,效率更高。通過將 Keras 構建為
    的頭像 發表于 12-12 09:55 ?8762次閱讀
    <b class='flag-5'>TensorFlow</b> 2.0中關于<b class='flag-5'>Keras</b>的一些新功能和重大變化

    深入了解TensorFlow隨附的此版Keras將能為您實現哪些功能

    也是 TensorFlow 集成 Keras 的主要設計目標,即讓用戶能夠選擇對自己更有用處的 Keras 組件,而無需采用整個框架。
    的頭像 發表于 12-18 13:38 ?2999次閱讀

    最新tf.keras指南,TensorFlow官方出品

    TensorFlow 1.x以靜態圖為主,網上主流的TF代碼編寫主要是面向過程的(函數為主),在引入tf.keras之后,TensorFlow官方就開始推薦tf.keras里各種面向對
    的頭像 發表于 03-29 11:28 ?4523次閱讀

    基于TensorFlowKeras的圖像識別

    TensorFlowKeras最常見的用途之一是圖像識別/分類。通過本文,您將了解如何使用Keras達到這一目的。定義如果您不了解圖像識別的基本概念,將很難完全理解本文的內容。因此在正文開始之前
    的頭像 發表于 01-13 08:27 ?1121次閱讀
    基于<b class='flag-5'>TensorFlow</b>和<b class='flag-5'>Keras</b>的圖像識別

    keras的模塊結構介紹

    Keras是一個高級深度學習庫,它提供了一個易于使用的接口來構建和訓練深度學習模型。Keras是基于TensorFlow、Theano或CNTK等底層計算庫構建的。以下是Keras的模
    的頭像 發表于 07-05 09:35 ?629次閱讀

    keras模型轉tensorflow session

    在這篇文章中,我們將討論如何將Keras模型轉換為TensorFlow session。 KerasTensorFlow簡介 Keras
    的頭像 發表于 07-05 09:36 ?803次閱讀

    tensorflow和pytorch哪個

    tensorflow和pytorch都是非常不錯的強大的框架,TensorFlow還是PyTorch哪個更好取決于您的具體需求,以下是關于這兩個框架的一些關鍵點:
    的頭像 發表于 07-05 09:42 ?1111次閱讀

    tensorflow和pytorch哪個更簡單?

    PyTorch更簡單。選擇TensorFlow還是PyTorch取決于您的具體需求和偏好。如果您需要一個易于使用、靈活且具有強大社區支持的框架,PyTorch可能是一個更好的選擇。如果您需要一個在
    的頭像 發表于 07-05 09:45 ?1356次閱讀