在TensorFlow训练过程中改变Dropout率 – 这是可能的吗?

我认为在训练神经网络(特别是生成对抗网络)时,改变dropout率有时可能是一个好主意,从高dropout率开始,并线性地将dropout率降低到零。你认为这有意义吗?如果有意义的话,在TensorFlow中实现这个方法有没有可能?


回答:

你可以将一个占位符传递给tf.nn.dropoutkeep_prob参数,以便在运行时能够输入任意dropout率:

# 一个全为1的数组data=np.ones((3,4), dtype=np.float32)keep_prob = tf.placeholder(tf.float32)drop = tf.nn.dropout(data, keep_prob=keep_prob)sess = tf. InteractiveSession()print(sess.run(drop, feed_dict={keep_prob: 0.5}))# >>> [[0. 2. 0. 2.]#      [0. 2. 0. 0.]#      [2. 2. 2. 2.]]print(sess.run(drop, feed_dict={keep_prob: 1.0}))# >>> [[1. 1. 1. 1.]#      [1. 1. 1. 1.]#      [1. 1. 1. 1.]]

至于这是否有意义,最好的验证方法是运行一组使用静态和变化dropout率的实验,然后比较结果。

Related Posts

Keras Dense层输入未被展平

这是我的测试代码: from keras import…

无法将分类变量输入随机森林

我有10个分类变量和3个数值变量。我在分割后直接将它们…

如何在Keras中对每个输出应用Sigmoid函数?

这是我代码的一部分。 model = Sequenti…

如何选择类概率的最佳阈值?

我的神经网络输出是一个用于多标签分类的预测类概率表: …

在Keras中使用深度学习得到不同的结果

我按照一个教程使用Keras中的深度神经网络进行文本分…

‘MatMul’操作的输入’b’类型为float32,与参数’a’的类型float64不匹配

我写了一个简单的TensorFlow代码,但不断遇到T…

发表回复

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