二、訓練完以後的記錄去哪裏找

系列文章:
一、搭建屬於你的第一個神經網絡
三、【keras實戰】波士頓房價預測


之前沒有系統學習keras,每次等到程序跑完了,我都會在消息記錄窗口選定後往上狂拖選定,複製,然後建立txt粘貼,再寫一個re來正則匹配所需數據的程序,還覺得自己很機智,看了keras的具體功能以後,簡直無地自容。
我們在model.fit()訓練完以後,其實返回了一個obj,叫做history,保存了訓練過程中的所有數據,接下來通過代碼來講解。

>>> history_dict = history.history
>>> history_dict.keys()
[u'acc', u'loss', u'valacc', u'valloss']

首先將對象裏面的history字典存入history_dict,然後查看字典裏面的鍵。
接下來試着使用matplotlib來作出之前訓練完的數據的一些圖像。

import matplotlib.pyplot as plt
acc = history.history['acc']
val_acc = history.history['val_acc']
loss = history.history['loss']
val_loss = history.history['val_loss']
epochs = range(1, len(acc) + 1)
# "bo" is for "blue dot"
plt.plot(epochs, loss, 'bo', label='Training loss')
# b is for "solid blue line"
plt.plot(epochs, val_loss, 'b', label='Validation loss')
plt.title('Training and validation loss')
plt.xlabel('Epochs')
plt.ylabel('Loss')
plt.legend()
plt.show()

前面幾句很容易理解,從history分別將acc,val_acc,loss,val_loss提取出來,加了val前綴的是每個epoche所得到的模型丟測試集得到的結果。


plt.clf() # clear figure
acc_values = history_dict['acc']
val_acc_values = history_dict['val_acc']
plt.plot(epochs, acc, 'bo', label='Training acc')
plt.plot(epochs, val_acc, 'b', label='Validation acc')
plt.title('Training and validation accuracy')
plt.xlabel('Epochs')
plt.ylabel('Loss')
plt.legend()
plt.show()

也不難理解,此時作出的是損失隨訓練epoches的變化


用已經訓練好的模型來預測新的數據

>>> model.predict(x_test)
[ 0.98006207]
  [ 0.99758697]
  [ 0.99975556]
  ...,
  [ 0.82167041]
  [ 0.02885115]
  [ 0.65371346]]

返回的值是模型認爲這次預測的把握有多大。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章