欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

keras回調(diào)函數(shù)的使用

 更新時間:2023年03月13日 10:13:38   作者:辛勤的小碼農(nóng)^_^  
本文主要介紹了keras回調(diào)函數(shù)的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

回調(diào)函數(shù)

  • 回調(diào)函數(shù)是一個對象(實現(xiàn)了特定方法的類實例),它在調(diào)用fit()時被傳入模型,并在訓練過程中的不同時間點被模型調(diào)用
  • 可以訪問關于模型狀態(tài)與模型性能的所有可用數(shù)據(jù)
  • 模型檢查點(model checkpointing):在訓練過程中的不同時間點保存模型的當前狀態(tài)。
  • 提前終止(early stopping):如果驗證損失不再改善,則中斷訓練(當然,同時保存在訓練過程中的最佳模型)。
  • 在訓練過程中動態(tài)調(diào)節(jié)某些參數(shù)值:比如調(diào)節(jié)優(yōu)化器的學習率。
  • 在訓練過程中記錄訓練指標和驗證指標,或者將模型學到的表示可視化(這些表示在不斷更新):fit()進度條實際上就是一個回調(diào)函數(shù)。

fit()方法中使用callbacks參數(shù)

# 這里有兩個callback函數(shù):早停和模型檢查點
callbacks_list=[
    keras.callbacks.EarlyStopping(
        monitor="val_accuracy",#監(jiān)控指標
        patience=2 #兩輪內(nèi)不再改善中斷訓練
    ),
    keras.callbacks.ModelCheckpoint(
        filepath="checkpoint_path",
        monitor="val_loss",
        save_best_only=True
    )
]
#模型獲取
model=get_minist_model()
model.compile(optimizer="rmsprop",
             loss="sparse_categorical_crossentropy",
             metrics=["accuracy"])

model.fit(train_images,train_labels,
         epochs=10,callbacks=callbacks_list, #該參數(shù)使用回調(diào)函數(shù)
         validation_data=(val_images,val_labels))

test_metrics=model.evaluate(test_images,test_labels)#計算模型在新數(shù)據(jù)上的損失和指標
predictions=model.predict(test_images)#計算模型在新數(shù)據(jù)上的分類概率

訓練結果

模型的保存和加載

#也可以在訓練完成后手動保存模型,只需調(diào)用model.save('my_checkpoint_path')。
#重新加載模型
model_new=keras.models.load_model("checkpoint_path.keras")

通過對Callback類子類化來創(chuàng)建自定義回調(diào)函數(shù)

on_epoch_begin(epoch, logs) ←----在每輪開始時被調(diào)用
on_epoch_end(epoch, logs) ←----在每輪結束時被調(diào)用
on_batch_begin(batch, logs) ←----在處理每個批量之前被調(diào)用
on_batch_end(batch, logs) ←----在處理每個批量之后被調(diào)用
on_train_begin(logs) ←----在訓練開始時被調(diào)用
on_train_end(logs ←----在訓練結束時被調(diào)用

from matplotlib import pyplot as plt
# 實現(xiàn)記錄每一輪中每個batch訓練后的損失,并為每個epoch繪制一個圖
class LossHistory(keras.callbacks.Callback):
    def on_train_begin(self, logs):
        self.per_batch_losses = []

    def on_batch_end(self, batch, logs):
        self.per_batch_losses.append(logs.get("loss"))

    def on_epoch_end(self, epoch, logs):
        plt.clf()
        plt.plot(range(len(self.per_batch_losses)), self.per_batch_losses,
                 label="Training loss for each batch")
        plt.xlabel(f"Batch (epoch {epoch})")
        plt.ylabel("Loss")
        plt.legend()
        plt.savefig(f"plot_at_epoch_{epoch}")
        self.per_batch_losses = [] #清空,方便下一輪的技術
model = get_mnist_model()
model.compile(optimizer="rmsprop",
              loss="sparse_categorical_crossentropy",
              metrics=["accuracy"])
model.fit(train_images, train_labels,
          epochs=10,
          callbacks=[LossHistory()],
          validation_data=(val_images, val_labels))

在這里插入圖片描述

【其他】模型的定義 和 數(shù)據(jù)加載

def get_minist_model():
    inputs=keras.Input(shape=(28*28,))
    features=layers.Dense(512,activation="relu")(inputs)
    features=layers.Dropout(0.5)(features)
    outputs=layers.Dense(10,activation="softmax")(features)
    model=keras.Model(inputs,outputs)
    return model
    
#datset
from tensorflow.keras.datasets import mnist
(train_images,train_labels),(test_images,test_labels)=mnist.load_data()
train_images=train_images.reshape((60000,28*28)).astype("float32")/255
test_images=test_images.reshape((10000,28*28)).astype("float32")/255
train_images,val_images=train_images[10000:],train_images[:10000]
train_labels,val_labels=train_labels[10000:],train_labels[:10000]

到此這篇關于keras回調(diào)函數(shù)的使用的文章就介紹到這了,更多相關keras回調(diào)函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Python Numpy中數(shù)據(jù)的常用保存與讀取方法

    Python Numpy中數(shù)據(jù)的常用保存與讀取方法

    這篇文章主要介紹了Python Numpy中數(shù)據(jù)的常用保存與讀取方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • python文件轉(zhuǎn)為exe文件的方法及用法詳解

    python文件轉(zhuǎn)為exe文件的方法及用法詳解

    py2exe是一個將python腳本轉(zhuǎn)換成windows上的可獨立執(zhí)行的可執(zhí)行程序(*.exe)的工具,這樣,你就可以不用裝python而在windows系統(tǒng)上運行這個可執(zhí)行程序。本文重點給大家介紹python文件轉(zhuǎn)為exe文件的方法,感興趣的朋友跟隨小編一起看看吧
    2019-07-07
  • 通過字符串導入 Python 模塊的方法詳解

    通過字符串導入 Python 模塊的方法詳解

    這篇文章主要介紹了通過字符串導入 Python 模塊的方法詳解,本文通過實例結合,給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • Python中staticmethod和classmethod的作用與區(qū)別

    Python中staticmethod和classmethod的作用與區(qū)別

    今天小編就為大家分享一篇關于Python中staticmethod和classmethod的作用與區(qū)別,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • Pytorch:Conv2d卷積前后尺寸詳解

    Pytorch:Conv2d卷積前后尺寸詳解

    這篇文章主要介紹了Pytorch:Conv2d卷積前后尺寸,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Python3模擬curl發(fā)送post請求操作示例

    Python3模擬curl發(fā)送post請求操作示例

    這篇文章主要介紹了Python3模擬curl發(fā)送post請求操作,結合實例形式分析了Python3使用Request請求模擬curl發(fā)送post相關操作技巧,需要的朋友可以參考下
    2019-05-05
  • 對Python 網(wǎng)絡設備巡檢腳本的實例講解

    對Python 網(wǎng)絡設備巡檢腳本的實例講解

    下面小編就為大家分享一篇對Python 網(wǎng)絡設備巡檢腳本的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • 使用django-guardian實現(xiàn)django-admin的行級權限控制的方法

    使用django-guardian實現(xiàn)django-admin的行級權限控制的方法

    這篇文章主要介紹了使用django-guardian實現(xiàn)django-admin的行級權限控制的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • Python發(fā)送網(wǎng)絡請求(requests)

    Python發(fā)送網(wǎng)絡請求(requests)

    這篇文章主要介紹了Python發(fā)送網(wǎng)絡請求(requests),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Python實現(xiàn)按逗號分隔列表的方法

    Python實現(xiàn)按逗號分隔列表的方法

    今天小編就為大家分享一篇Python實現(xiàn)按逗號分隔列表的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10

最新評論