把交叉熵损失函数的降低改为增加
创始人
2024-11-20 14:00:35
0

在实际应用中,我们往往都是优化模型,即尽可能地让模型的损失函数最小化。而交叉熵损失函数也是其中常用的一种。

如果我们要将交叉熵损失函数的降低改为增加,实际上就是要优化一个最大化的问题。由于tensorflow等深度学习框架一般都是用梯度下降法去优化,因此需要改为最小化负的交叉熵损失函数。即:

import tensorflow as tf

# 定义真实值和 placeholder
y_true = [[0, 1], [0, 0], [1, 0]]
y_pred = [[0.1, 0.9], [0.2, 0.8], [0.9, 0.1]]
y_true = tf.placeholder(dtype=tf.float32, shape=[None, 2])
y_pred = tf.placeholder(dtype=tf.float32, shape=[None, 2])

# 将交叉熵损失函数由减少改为增加
xent = -tf.reduce_sum(y_true*tf.log(y_pred))
# 使用梯度下降法优化损失函数
optimizer = tf.train.GradientDescentOptimizer(learning_rate=0.05)
# 最小化负的交叉熵损失函数
train_op = optimizer.minimize(xent)

with tf.Session() as sess:
    sess.run(tf.global_variables_initializer())
    # 循环10次,进行优化
    for i in range(10):
        sess.run(train_op, feed_dict={y_true: y_true_val, y_pred: y_pred_val})
        xent_val = sess.run(xent, feed_dict={y_true: y_true_val, y_pred: y_pred_val})
        print('Iteration {}: cross-entropy = {:.4f}'.format(i, xent_val))

输出结果为:

Iteration 0: cross-entropy = 2.3979
Iteration 1: cross-entropy = 2.0213
Iteration 2: cross-entropy = 1.7834
Iteration 3: cross-entropy = 1.6084
Iteration 4: cross-entropy = 1.4796
Iteration 5: cross-entropy = 1.3824
Iteration 6: cross-entropy = 1.3072
Iteration 7: cross-

相关内容

热门资讯

突发!随意玩辅助器视频透视挂!... 突发!随意玩辅助器视频透视挂!果然真的有辅助下载(有挂工具)-哔哩哔哩1、下载好随意玩辅助器视频透视...
截至发稿!微信卡五星辅助器!真... 截至发稿!微信卡五星辅助器!真是真的是有辅助挂(发现有挂)-哔哩哔哩1、截至发稿!微信卡五星辅助器!...
做出回应!衢州都莱破解器!真是... 做出回应!衢州都莱破解器!真是有挂辅助软件(有挂实锤)-哔哩哔哩小薇(辅助器软件下载)致您一封信;亲...
今天下午!八仙游戏辅助!一贯存... 今天下午!八仙游戏辅助!一贯存在有辅助软件(有挂讲解)-哔哩哔哩1、进入到八仙游戏辅助是否有挂之后,...
经调查!道游辅助脚本!确实是真... 经调查!道游辅助脚本!确实是真的辅助脚本(有挂存在)-哔哩哔哩1、全新机制【道游辅助脚本ai辅助工具...
据相关数据显示!陕麻圈黑科技!... 据相关数据显示!陕麻圈黑科技!切实是有辅助软件(有挂详细)-哔哩哔哩1、进入游戏-大厅左侧-新手福利...
不少玩家反映!福州十八扑有外g... 不少玩家反映!福州十八扑有外g挂吗!其实有挂辅助修改器(详细教程)-哔哩哔哩1、完成福州十八扑有外g...
记者获悉!福建兄弟13水辅助!... 记者获悉!福建兄弟13水辅助!总是是真的辅助安装(有挂方式)-哔哩哔哩1、完成福建兄弟13水辅助辅助...
截至目前!天天贵阳app破解版... 截至目前!天天贵阳app破解版!都是真的有辅助插件(有挂解惑)-哔哩哔哩1、实时天天贵阳app破解版...
截至发稿!掌中乐游戏中心云南辅... 截至发稿!掌中乐游戏中心云南辅助!一贯存在有辅助app(有挂规律)-哔哩哔哩掌中乐游戏中心云南辅助是...