tensorflow中的交叉熵损失

tf.nn.softmax_cross_entropy_with_logits传入的 labels是one-hot编码,logits需未使用softmax
tf.nn.softmax_cross_entropy_with_logits对传入的logits先计算softmax激活后的输出,再计算与 labels间的交叉熵

import tensorflow as tf

logits=tf.constant([[1.0,2.0,5.0],[1.0,2.0,3.0],[1.0,2.0,3.0]])
y_=tf.constant([[0.0,0.0,1.0],[0.0,0.0,1.0],[0.0,0.0,1.0]])
#dont forgettf.reduce_sum()!!
tf_softmax = tf.nn.softmax_cross_entropy_with_logits(labels=y_, logits=logits)
cross_entropy2=tf.reduce_sum(tf_softmax)
with tf.Session() as sess:
    print('tf_softmax:\n',sess.run(tf_softmax))
    c_e2 = sess.run(cross_entropy2)
    print("cross_entropy2:\n",c_e2)

输出

tf_softmax:
 [0.06588391 0.40760595 0.40760595]
cross_entropy2:
 0.88109577

tf.reduce_xxx系列在指定维度上对矩阵操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值