帶你少走彎路:強烈推薦的Keras快速入門資料和翻譯(可下載)
- 2019 年 10 月 28 日
- 筆記
上次寫了TensorFlow和PyTorch的快速入門資料,受到很多好評,讀者強烈建議我再出一個keras的快速入門路線,經過翻譯和搜索網上資源,我推薦4份入門資料,希望對大家有所幫助。
備註:另外兩個入門資料
很負責任地說:看完這些資料,Keras基本入門了,接下來碰到問題能自己查資料解決了!(本文作者:黃海廣)
推薦資料
1.《python深度學習》及中文注釋的程式碼
TensorFlow團隊的Josh Gordon推薦這本書,TF2.0基於Keras。如果你是一個深度學習新手,最好從這本書入手。當然這本書里的程式碼需要改一下,但非常簡單:
import keras -> from tensorflow import keras
作者在github公布了程式碼,程式碼幾乎囊括了本書所有知識點。在學習完本書後,讀者將具備搭建自己的深度學習環境、建立影像識別模型、生成影像和文字等能力。但是有一個小小的遺憾:程式碼的解釋和注釋是全英文的,即使英文水平較好的朋友看起來也很吃力。
本站認為,這本書和程式碼是初學者入門深度學習及Keras最好的工具。
黃海廣對全部程式碼做了中文解釋和注釋,並下載了程式碼所需要的一些數據集(尤其是「貓狗大戰」數據集),並對其中一些影像進行了本地化,程式碼全部測試通過。(請按照文件順序運行,程式碼前後有部分關聯)。
以下程式碼包含了全書80%左右的知識點,程式碼目錄:
- 2.1: A first look at a neural network( 初識神經網路)
- 3.5: Classifying movie reviews(電影評論分類:二分類問題)
- 3.6: Classifying newswires(新聞分類:多分類問題 )
- 3.7: Predicting house prices(預測房價:回歸問題)
- 4.4: Underfitting and overfitting( 過擬合與欠擬合)
- 5.1: Introduction to convnets(卷積神經網路簡介)
- 5.2: Using convnets with small datasets(在小型數據集上從頭開始訓練一個卷積
- 5.3: Using a pre-trained convnet(使用預訓練的卷積神經網路)
- 5.4: Visualizing what convnets learn(卷積神經網路的可視化)
- 6.1: One-hot encoding of words or characters(單詞和字元的 one-hot 編碼)
- 6.1: Using word embeddings(使用詞嵌入)
- 6.2: Understanding RNNs(理解循環神經網路)
- 6.3: Advanced usage of RNNs(循環神經網路的高級用法)
- 6.4: Sequence processing with convnets(用卷積神經網路處理序列)
- 8.1: Text generation with LSTM(使用 LSTM 生成文本)
- 8.2: Deep dream(DeepDream)
- 8.3: Neural style transfer( 神經風格遷移)
- 8.4: Generating images with VAEs(用變分自編碼器生成影像)
- 8.5: Introduction to GANs(生成式對抗網路簡介)
中文注釋與解釋如圖:
圖:程式碼的中文注釋與解釋
作者的github:
https://github.com/fchollet/deep-learning-with-python-notebooks
中文注釋程式碼:
https://github.com/fengdu78/machine_learning_beginner/tree/master/deep-learning-with-python-notebooks
2.keras的樣例程式碼
資源地址:
https://github.com/erhwenkuo/deep-learning-with-keras-notebooks
資源介紹:
這個github的repository主要是ErhWen Kuo在學習Keras的一些記錄及練習。希望在學習過程中發現到一些好的資訊與示例也可以對想要學習使用Keras來解決問題的同學帶來幫助。這些notebooks主要是使用Python 3.6與Keras 2.1.1版本跑在一台配置Nivida 1080Ti的Windows 10的機台所產生的結果,但有些部份會參雜一些Tensorflow與其它的函式庫的介紹。
配置環境:
python 3.6以上,Keras 2.1.1
資源目錄:
0.圖象數據集/工具介紹
- 0.0: COCO API解說與簡單示例
- 0.1:土炮自製撲克牌圖象數據集
- 0.2:使用Pillow來進行影像處理
1.Keras API示例
- 1.0:使用影像增強來進行深度學習
- 1.1:如何使用Keras函數式API進行深度學習
- 1.2:從零開始構建VGG網路來學習Keras
- 1.3:使用預訓練的模型來分類照片中的物體
- 1.4:使用影像增強來訓練小數據集
- 1.5:使用預先訓練的卷積網路模型
- 1.6:卷積網路模型學習到什麼的可視化
- 1.7:構建自動編碼器(Autoencoder)
- 1.8:序列到序列(Seq-to-Seq)學習介紹
- 1.9: One-hot編碼工具程式介紹
- 1.10:循環神經網路(RNN)介紹
- 1.11: LSTM的返回序列和返回狀態之間的區別
- 1.12:用LSTM來學習英文字母表順序
2.影像分類(Image Classification)
- 2.0: Julia(Chars74K)字母影像分類
- 2.1:交通標誌影像分類
- 2.2:辛普森卡通影像角色分類
- 2.3:時尚服飾影像分類
- 2.4:人臉關鍵點辨識
- 2.5: Captcha驗證碼分類
- 2.6: Mnist手寫影像分類(MLP)
- 2.7: Mnist手寫影像分類(CNN)
3.目標檢測(Object Recognition)
- 3.0: YOLO目標檢測演算法概念與介紹
- 3.1: YOLOv2目標檢測示例
- 3.2:浣熊(Racoon)檢測-YOLOv2模型訓練與調整
- 3.3:浣熊(Racoon)檢測-YOLOv2模型的使用
- 3.4:袋鼠(Kangaroo)檢測-YOLOv2模型訓練與調整
- 3.5:雙手(Hands)檢測-YOLOv2模型訓練與調整
- 3.6:辛普森卡通圖象角色(Simpson)檢測-YOLOv2模型訓練與調整
- 3.7: MS COCO圖象檢測-YOLOv2模型訓練與調整
4.物體分割(Object Segmentation)
5.關鍵點檢測(Keypoint Detection)
6.圖象標題(Image Caption)
7.人臉檢測識別(Face Detection/Recognition)
- 7.0:人臉檢測- OpenCV(Haar特徵分類器)
- 7.1:人臉檢測- MTCNN(Multi-task Cascaded Convolutional Networks)
- 7.2:人臉識別-臉部檢測、對齊&裁剪
- 7.3:人臉識別-人臉部特徵提取&人臉分類器
- 7.4:人臉識別-轉換、對齊、裁剪、特徵提取與比對
- 7.5:臉部關鍵點檢測(dlib)
- 7.6:頭部姿態(Head pose)估計(dlib)
8.自然語言處理(Natural Language Processing)
- 8.0:詞嵌入(word embeddings)介紹
- 8.1:使用結巴(jieba)進行中文分詞
- 8.2: Word2vec詞嵌入(word embeddings)的基本概念
- 8.3:使用結巴(jieba)進行歌詞分析
- 8.4:使用gensim訓練中文詞向量(word2vec)
3.keras的官方樣例
資源地址:
https://github.com/keras-team/keras/tree/master/examples
資源介紹:
這個github是Keras的官方例子,包含了CV、NLP、生成模型以及一些通用的函數程式碼,可以說是教科書式的,拿過來改下輸入輸出就能用,非常方便。
4.keras的預訓練模型
資源地址:
https://github.com/fchollet/deep-learning-models
這個倉庫是keras的作者建立的,包含的預訓練的 Keras 模型:
- VGG16
- VGG19
- ResNet50
- Inception v3
- CRNN for music tagging 樣例說明:
影像分類程式碼
from resnet50 import ResNet50 from keras.preprocessing import image from imagenet_utils import preprocess_input, decode_predictions model = ResNet50(weights='imagenet') img_path = 'elephant.jpg' img = image.load_img(img_path, target_size=(224, 224)) x = image.img_to_array(img) x = np.expand_dims(x, axis=0) x = preprocess_input(x) preds = model.predict(x) print('Predicted:', decode_predictions(preds)) # print: [[u'n02504458', u'African_elephant']]
總結
看完這些資料,Keras基本入門了,接下來碰到問題能自己查資料解決了!