访问自定义损失函数中的特定元素?

在为分类问题定义自定义损失函数时,有没有办法访问y_true和y_pred的特定元素?

使用案例:多标签分类问题中,如果我预测了类别5的误报,即y_true[5] == 0y_pred[5] == 1,我想对模型进行额外惩罚。

我定义的损失函数如下:

def loss(y_true, y_pred):      wt = 10 if (y_true[5]==0 and y_pred[5]==1) else 1      return wt * binary_crossentropy(y_true, y_pred)

我也尝试过检查 K.gather(y_true, 5) == 0,但似乎不起作用。

我的批量大小大于1(256),我使用的是 fit_generator – 如果这有任何影响的话。谢谢!


回答:

有没有办法访问y_true和y_pred的特定元素?

Keras张量的索引方式与numpy数组的索引方式类似。唯一的区别是结果是一个Keras张量。因此,您应该随后使用Keras操作。


您的损失函数的可能实现

例如,您的损失函数可能这样实现:

def loss(y_true, y_pred):    a = K.equal(y_true[:, 5], 0)    b = K.greater(y_pred[:, 5], 0.5)    condition = K.cast(a, 'float') * K.cast(b, 'float')    wt = 10 * condition + (1 - condition)    return K.mean(wt[:, None] * K.binary_crossentropy(y_true, y_pred), axis=-1)

注意: 未经测试。

Related Posts

关于k折交叉验证的直观问题

我在使用交叉验证检查预测能力时遇到了一些直观问题,我认…

调整numpy数组大小以使用sklearn的train_test_split函数?

我正在尝试使用sklearn中的test_train_…

如何转换二维张量和索引张量以便用于torch.nn.utils.rnn.pack_sequence

我有一组序列,格式如下: sequences = to…

模型预测值的含义是什么?

我在网上找到一个数字识别器的CNN模型并进行了训练,当…

锯齿张量作为LSTM的输入

了解锯齿张量以及如何在TensorFlow中使用它们。…

如何告诉SciKit的LinearRegression模型预测值不能小于零?

我有以下代码,尝试根据非价格基础特征来估值股票。 pr…

发表回复

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