日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

tensorflow可視化Keras框架中Tensorboard使用示例_python

作者:Bubbliiiing ? 更新時間: 2022-07-01 編程語言

Tensorboard詳解

該類在存放在keras.callbacks模塊中。擁有許多參數,主要的參數如下:

1、log_dir: 用來保存Tensorboard的日志文件等內容的位置

2、histogram_freq: 對于模型中各個層計算激活值和模型權重直方圖的頻率。

3、write_graph: 是否在 TensorBoard 中可視化圖像。

4、write_grads: 是否在 TensorBoard 中可視化梯度值直方圖。

5、batch_size: 用以直方圖計算的傳入神經元網絡輸入批的大小。

6、write_images: 是否在 TensorBoard中將模型權重以圖片可視化。

7、update_freq: 常用的三個值為’batch’ 、 ‘epoch’ 或 整數。當使用 ‘batch’ 時,在每個 batch 之后將損失和評估值寫入到 TensorBoard 中。 ‘epoch’ 類似。如果使用整數,會在每一定個樣本之后將損失和評估值寫入到 TensorBoard 中。

默認值如下:

log_dir='./logs',  # 默認保存在當前文件夾下的logs文件夾之下
histogram_freq=0,
batch_size=32,
write_graph=True,  #默認是True,默認是顯示graph的。
write_grads=False,
write_images=False,
update_freq='epoch'

使用例子

以手寫體為例子,我們打開histogram_freq和write_grads,也就是在Tensorboard中保存權值直方圖和梯度直方圖。

打開CMD,利用tensorboard --logdir=logs生成tensorboard觀測網頁。

1、loss和acc

2、權值直方圖

3、梯度直方圖

實現代碼

import numpy as np
from keras.layers import Input, Dense, Dropout, Activation,Conv2D,MaxPool2D,Flatten
from keras.datasets import mnist
from keras.models import Model
from keras.utils import to_categorical
from keras.callbacks import TensorBoard
if __name__=="__main__":
    (x_train,y_train),(x_test,y_test) = mnist.load_data()
    x_train=np.expand_dims(x_train,axis=-1)
    x_test=np.expand_dims(x_test,axis=-1)
    y_train=to_categorical(y_train,num_classes=10)
    y_test=to_categorical(y_test,num_classes=10)
    batch_size=128
    epochs=10
    inputs = Input([28,28,1])
    x = Conv2D(32, (5,5), activation='relu')(inputs)
    x = Conv2D(64, (5,5), activation='relu')(x)   
    x = MaxPool2D(pool_size=(2,2))(x)
    x = Flatten()(x)    
    x = Dense(128, activation='relu')(x)
    x = Dropout(0.5)(x)
    x = Dense(10, activation='softmax')(x)
    model = Model(inputs,x)
    model.compile(loss='categorical_crossentropy', optimizer="adam",metrics=['acc']) 
    Tensorboard= TensorBoard(log_dir="./model", histogram_freq=1,write_grads=True)
    history=model.fit(x_train, y_train, batch_size=batch_size, epochs=epochs, shuffle=True, validation_split=0.2,callbacks=[Tensorboard])

原文鏈接:https://blog.csdn.net/weixin_44791964/article/details/105002793

欄目分類
最近更新