天天看點

tensorflow交叉熵損失函數

在分類的時候,一般采用交叉熵損失函數,然而今天用tensorflow做分類的時候,發現采用tensorflow的自用函數,和自己寫的,計算出來的結果不一樣。

而且采用自己實作時,我出現了loss為nan的情況

# tensorflow自帶
loss = tf.reduce_mean(
		tf.nn.softmax_cross_entropy_with_logits(labels=y, logits=y_conv)
)

## 自己實作交叉熵損失函數
# pred = tf.nn.softmax(y_conv)
# loss = tf.reduce_mean(-tf.reduce_sum(y * tf.log(pred)))
           

驗證程式

import tensorflow as tf
sess = tf.Session()
a = tf.constant([[ 0.1, 0.4], [ 1, 1.2]], dtype=tf.float32)
y = tf.constant([[ 0, 1], [ 1, 0]], dtype=tf.float32)

pred = tf.nn.softmax(a)
loss = tf.reduce_mean(-tf.reduce_sum(y * tf.log(pred)))
sess.run(loss)
>>> 1.3524942
loss1 = tf.reduce_mean(
		tf.nn.softmax_cross_entropy_with_logits(labels=y, logits=pred)
)
sess.run(loss1)
>>>0.6828476