Tensorflow 1.8.0:宽深模型结果不稳定,随机种子不起作用

我使用Tensorflow 1.8.0训练了一个宽深模型。我的测试和训练数据集是之前分开的文件。我在tf.contrib.learn.DNNLinearCombinedClassifier之前使用了tf.set_random_seed(1234),如下所示 –

tf.set_random_seed(1234)import tempfilemodel_dir = tempfile.mkdtemp()m = tf.contrib.learn.DNNLinearCombinedClassifier(model_dir=model_dir,                                                 linear_feature_columns=wide_columns,                                                 dnn_feature_columns=deep_columns,                                                 dnn_hidden_units=[100, 50])

它显示了以下日志 –

INFO:tensorflow:使用默认配置。INFO:tensorflow:使用配置: {'_task_type': None, '_task_id': 0, '_cluster_spec': <tensorflow.python.training.server_lib.ClusterSpec object at 0x7f394b585c18>, '_master': '', '_num_ps_replicas': 0, '_num_worker_replicas': 0, '_environment': 'local', '_is_chief': True, '_evaluation_master': '', '_train_distribute': None, '_tf_config': gpu_options {  per_process_gpu_memory_fraction: 1.0}, '_tf_random_seed': None, '_save_summary_steps': 100, '_save_checkpoints_secs': 600, '_log_step_count_steps': 100, '_session_config': None, '_save_checkpoints_steps': None, '_keep_checkpoint_max': 5, '_keep_checkpoint_every_n_hours': 10000, '_model_dir': '/tmp/tmpxka6vy6t'}

从日志中可以看出,随机种子没有被应用。

每次运行脚本时,我得到的准确率结果都不同。

如何使结果稳定?为什么随机种子不起作用?


回答:

经过一番努力,我终于找到了解决方案。需要在DNNLinearCombinedClassifier中作为config的参数设置tf_random_seed。加入config=tf.contrib.learn.RunConfig(tf_random_seed=123)这一行就可以解决问题。它设置了随机种子,使结果可重现。

代码应该如下所示 –

# 将宽模型和深模型结合为一个model_dir = tempfile.mkdtemp()m = tf.contrib.learn.DNNLinearCombinedClassifier(model_dir=model_dir,                                                 linear_feature_columns=wide_columns,                                                 dnn_feature_columns=deep_columns,                                                 dnn_hidden_units=[100, 50],                                                 config=tf.contrib.learn.RunConfig(tf_random_seed=123))

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注