Kaggle上使用Tensorboard

yizhihongxing

Kaggle上使用Tensorboard

1. 前言

  • 想在Kaggle上使用Tensorboard,找了一圈。
  • 参考了Kaggle上的一个Code:Tensorboard on Kaggle
  • 但发现有些变化,Code中用到的内网穿透工具Ngrok需要加一个Token,所以需要注册一个Ngrok账号,免费获取一个通道的Token。

2. Kaggle上使用Tensorboard

2.1. 方法一

  • 其实直接把在Kaggle上跑出来的Tensorboard日志文件下载到本地,在本地启动Tensorboard即可查看。
  • 当然,这里主要讲在线的方法。

2.2. 方法二

  • 在线使用Tensorboard

2.2.1. 获取一个Ngrok的免费通道

  • 访问Ngrok,注册一个账号并登录
  • 登录后界面如下,复制并保存你的Token
    image

2.2.2. 调试运行代码

  • 主要参考Kaggle上的一个Code:Tensorboard on Kaggle
  • 建议分段运行,以避免中间出错,全部重新运行一次
  • 以下代码在Kaggle的Notebook中运行

(1) 环境准备

import tensorflow as tf # This is how we import tf
# Clear any logs from previous runs
# 清除以前运行的所有日志
!rm -rf ./logs/ 
!mkdir ./logs/

(2) 启动Tensorboard

# Download Ngrok to tunnel the tensorboard port to an external port
# 下载 Ngrok 以将 tensorboard 端口隧道传输到外部端口
!wget https://bin.equinox.io/c/4VmDzA7iaHb/ngrok-stable-linux-amd64.zip
!unzip ngrok-stable-linux-amd64.zip
# 添加自己在 Ngrok 上获取的专属Token
!./ngrok authtoken 粘贴你的专属Token
  • 注意这一步需要添加自己在 Ngrok 上获取的专属Token

image

# Run tensorboard as well as Ngrok (for tunneling as non-blocking processes)
# 运行 tensorboard 和 Ngrok(用于作为非阻塞进程的隧道)
import os
import multiprocessing

pool = multiprocessing.Pool(processes = 10)
# --logdir ./logs/ 是 TensorBoard 的日志文件(log)路径
# 你可以修改为你训练时的log保存路径(可以用绝对/相对路径),但相关的代码路径也要记得修改
results_of_processes = [pool.apply_async(os.system, args=(cmd, ), callback = None )
                        for cmd in [
                        f"tensorboard --logdir ./logs/ --host 0.0.0.0 --port 6006 &",
                        "./ngrok http 6006 &"
                        ]]
  • 获取访问 Tensorload 的URL,访问生成的URL即可看到 Tensorload 界面
  • 但还没有产生日志文件,所以现在还看不到有图形
! curl -s http://localhost:4040/api/tunnels | python3 -c \
    "import sys, json; print(json.load(sys.stdin)['tunnels'][0]['public_url'])"

image
image
image

(3) 创建和训练模型

(x_train, y_train),(x_test, y_test) = mnist.load_data()
x_train, x_test = x_train / 255.0, x_test / 255.0

def create_model():
  return tf.keras.models.Sequential([
    tf.keras.layers.Flatten(input_shape=(28, 28)),
    tf.keras.layers.Dense(512, activation='relu'),
    tf.keras.layers.Dropout(0.2),
    tf.keras.layers.Dense(10, activation='softmax')
  ])
import datetime
model = create_model()
model.compile(optimizer='adam',
              loss='sparse_categorical_crossentropy',
              metrics=['accuracy'])

log_dir = "logs/fit/" + datetime.datetime.now().strftime("%Y%m%d-%H%M%S")
tensorboard_callback = tf.keras.callbacks.TensorBoard(log_dir=log_dir, histogram_freq=1)

model.fit(x=x_train, 
          y=y_train, 
          epochs=10, 
          validation_data=(x_test, y_test), 
          callbacks=[tensorboard_callback])
  • 产生日志文件后,就可以在打开的 Tensorboard 界面点击刷新,看到实时训练趋势了
    image

到底了 ?

原文链接:https://www.cnblogs.com/jhy-ColdMoon/p/17341992.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Kaggle上使用Tensorboard - Python技术站

(0)
上一篇 2023年4月22日
下一篇 2023年4月22日

相关文章

  • 如何获得Python数组中一个元素的地址

    想要获取Python数组中单个元素的地址,可以通过以下步骤实现: 1.先导入Python中的array模块,并创建一个数组对象: import array arr = array.array(‘i’, [1, 2, 3]) 2.使用Python内置的id()函数获取数组中元素的地址。id()函数将返回一个唯一的表示变量内存地址的整数。 print(id(ar…

    python-answer 2023年3月25日
    00
  • Python入门教程(九)Python字符串介绍

    Python入门教程(九)Python字符串介绍 在Python中,字符串是一种不可变的数据类型,表示一系列Unicode字符序列。字符串在Python中非常重要,因为它们可以用于许多地方,比如文件处理。本文将介绍Python字符串的基本用法和操作。 字符串的定义 要定义一个字符串,请将文本包装在引号中。Python中支持单引号、双引号和三引号: # 使用单…

    python 2023年5月14日
    00
  • 如何在Python中查询MongoDB数据库中的数据?

    以下是在Python中查询MongoDB数据库中的数据的完整使用攻略。 使用MongoDB数据库的前提条件 在使用Python连接MongoDB数据库之前,确保已经了MongoDB数据库,并已经创建使用数据库和集合,同时需要安Python的驱动程序,例如pymongo。 步骤1:导模 在Python中使用pymongo模块连接MongoDB数据库。以下是导入…

    python 2023年5月12日
    00
  • pandas merge报错的解决方案

    以下是关于“pandas merge 报错的解决方案”的完整攻略: 问题描述 在使用 pandas 进行数据处理时,可能会遇到 merge 函数报错的问题。本文将介绍如何解决这个问题。 解决方法 1. 检查列名 在使用 merge 函数时,需要确保两个 DataFrame 中的列名相同。如果列名不同,可以使用 rename 函数重命列名。示例代码如下: df…

    python 2023年5月13日
    00
  • Python 如何解决稀疏矩阵运算

    Python 如何解决稀疏矩阵运算 稀疏矩阵是一种特殊类型的矩阵,其中大量的元素值都为0。在大多数实际问题中我们往往只需要处理少部分非零元素。这些矩阵需要专门的算法来处理,否则将浪费大量的计算时间和内存空间。Python提供了许多包来处理稀疏矩阵,其中最常用的包为scipy.sparse。 下面将介绍如何使用scipy.sparse来解决稀疏矩阵运算问题。 …

    python 2023年5月19日
    00
  • Python中使用logging模块代替print(logging简明指南)

    Python中使用logging模块代替print(logging简明指南) 使用print输出调试信息是一种常见的方式,但是print的缺陷也很明显:有时候输出的信息太多太杂,有时候输出的信息太少无法发现问题。为了更好的管理和处理调试信息,Python提供了logging模块。 基本用法 使用logging的流程可以大致分为以下三个步骤: 导入loggin…

    python 2023年6月3日
    00
  • Python语言描述KNN算法与Kd树

    下面是关于Python语言描述KNN算法与Kd树的攻略。 KNN算法是什么? KNN算法全称为K-近邻算法,基于特征之间的相似度计算样本之间的距离,进而来进行分类或回归。KNN是一个简单但十分有效的算法,它的主要思想是:新样本到训练样本中距离最近的K个样本的类别来决定它的类别。 KNN算法的应用场景 KNN算法适用于数据比较大、准确度要求不是那么高的场景,比…

    python 2023年6月3日
    00
  • python 美化输出信息的实例

    下面我将为你详细讲解“Python美化输出信息的实例”的攻略。 Python美化输出信息的实例 在Python中,我们可以通过一些工具或方法美化输出信息,比如使用高亮颜色、对齐文本等,以提高程序可读性。接下来我们将讲解两个美化输出信息的实例。 例子一:高亮显示输出信息 高亮显示输出信息可以让信息更加易于阅读,我们可以使用colorama模块来实现高亮。首先需…

    python 2023年6月5日
    00
合作推广
合作推广
分享本页
返回顶部