如何将Tensorboard添加到Tensorflow估算器过程中

Tim*_*eed 13 python tensorflow tensorboard

我已经采用了提供的鲍鱼示例,并确保我已经理解了......好吧,我想我做到了.但是作为我正在研究的另一个估算项目是生产垃圾 - 我试图添加张量板,所以我可以理解发生了什么.

基本代码是https://www.tensorflow.org/extend/estimators

我添加了一个Session和一个writer

    # Set model params
    model_params = {"learning_rate": 0.01}
    with  tf.Session ()   as  sess: 
        # Instantiate Estimator
        nn = tf.contrib.learn.Estimator(model_fn=model_fn, params=model_params)
        writer  =  tf.summary.FileWriter ( '/tmp/ab_tf' ,  sess.graph)
        nn.fit(x=training_set.data, y=training_set.target, steps=5000)   
        # Score accuracy
        ev = nn.evaluate(x=test_set.data, y=test_set.target, steps=1)


And added 1 line in the model_fn function so it looks like this...


def model_fn(features, targets, mode, params):
  """Model function for Estimator."""

  # Connect the first hidden layer to input layer
  # (features) with relu activation
  first_hidden_layer = tf.contrib.layers.relu(features, 49)

  # Connect the second hidden layer to first hidden layer with relu
  second_hidden_layer = tf.contrib.layers.relu(first_hidden_layer, 49)

  # Connect the output layer to second hidden layer (no activation fn)
  output_layer = tf.contrib.layers.linear(second_hidden_layer, 1)

  # Reshape output layer to 1-dim Tensor to return predictions
  predictions = tf.reshape(output_layer, [-1])
  predictions_dict = {"ages": predictions}

  # Calculate loss using mean squared error
  loss = tf.losses.mean_squared_error(targets, predictions)

  # Calculate root mean squared error as additional eval metric
  eval_metric_ops = {
      "rmse": tf.metrics.root_mean_squared_error(
          tf.cast(targets, tf.float64), predictions)
  }

  train_op = tf.contrib.layers.optimize_loss(
      loss=loss,
      global_step=tf.contrib.framework.get_global_step(),
      learning_rate=params["learning_rate"],
      optimizer="SGD")


  tf.summary.scalar('Loss',loss)

  return model_fn_lib.ModelFnOps(
      mode=mode,
      predictions=predictions_dict,
      loss=loss,
      train_op=train_op,
      eval_metric_ops=eval_metric_ops)
Run Code Online (Sandbox Code Playgroud)

最后加了一个

writer.close()
Run Code Online (Sandbox Code Playgroud)

当我运行代码时......我在/ tmp/ab_tf中得到一个数据文件,这个文件是非空的.但它的大小也只有139个字节......这意味着什么都没有被写入....

当我用张量板打开它时 - 没有数据.

我究竟做错了什么 ?

感谢任何输入......

小智 16

实际上,您不需要为估算器设置摘要编写器.摘要日志将写入估算器的model_dir.

假设您的model_dir for estimator是'./tmp/model',您可以使用tensorboard查看摘要--logdir =./ tmp/model

  • 你写的是正确的,运行Tensorboard没有问题。我只是在输出中看不到任何变量! (2认同)
  • @ jccf091 Estimator将训练日志直接放在model_dir目录中,但对于评估日志,它将在model_dir目录中创建子目录“ eval”。您知道如何在培训阶段创建子目录吗? (2认同)

小智 11

我试图做与你完全相同的事情.我终于想通了你需要将model_dir作为参数传递给类构造函数,如下所示:

# Instantiate Estimator
nn = tf.contrib.learn.Estimator(model_fn=model_fn,
        params=model_params, 
        model_dir=FLAGS.log_dir)
Run Code Online (Sandbox Code Playgroud)

您可以在此处看到TensorFlow API中记录的内容:https://www.tensorflow.org/api_docs/python/tf/contrib/learn/Estimator