python - 带有样本权重的 keras 自定义指标

标签 python tensorflow keras metrics

我正在尝试在 Keras 中定义一个考虑样本权重的自定义指标。在拟合模型时,我使用样本权重如下:

training_history = model.fit(
        train_data,
        train_labels,
        sample_weight = train_weights,
        epochs = num_epochs,
        batch_size = 128,
        validation_data = (validation_data, validatation_labels, validation_weights ),
    )

我使用的自定义指标的一个例子是 AUC(roc 曲线下的面积),我定义如下:

from keras import backend as K
import tensorflow as tf

def auc(true_labels, predictions, weights = None):
    auc = tf.metrics.auc(true_labels, predictions, weights = weights)[1]
    K.get_session().run(tf.local_variables_initializer())
    return auc

我在编译模型时使用了这个指标:

model.compile(
        optimizer = optimizer,
        loss = 'binary_crossentropy',
        metrics = ['accuracy', auc]
    )

但据我所知,该指标并未考虑样本权重。事实上,我通过比较使用上面定义的自定义指标训练模型时看到的指标值与我自己从模型输出和样本权重中计算得到的指标值来验证这一点,这确实产生了非常不同的结果。我将如何定义上面显示的 auc 指标以考虑样本权重?

最佳答案

您可以用另一个将 sample_weights 作为参数的函数包装您的指标:

def auc(weights):
    def metric(true_labels, predictions):
        auc = tf.metrics.auc(true_labels, predictions, weights=weights)[1]
        K.get_session().run(tf.local_variables_initializer())
        return auc
    return metric

然后定义一个额外的输入占位符来接收样本权重:

sample_weights = Input(shape=(1,))

然后您的模型可以按如下方式编译:

model.compile(
    optimizer = optimizer,
    loss = 'binary_crossentropy',
    metrics = ['accuracy', auc(sample_weights)]
)

注意:未经测试。

关于python - 带有样本权重的 keras 自定义指标,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54830573/

相关文章:

python - 使用 Python 将列表写入 Excel 中的单元格

Python pyCrypto RSA 加密方法使用私钥或公钥给出相同的结果

python - 如何在南迁移期间调用 django 模型类的静态方法

python - 尝试在 Tensorflow 中使用未初始化的值变量(使用了 sess.run(tf.global_variables_initializer()) !)

python - 关于占位符形状的 tensorflow 错误

python - 超拉斯 : 'List' object has no attribute 'shape'

python - 无法从 DenseVariational 获得合理的结果

python - 未知的字符问题�

python - 窗口多维 Tensorflow 数据集

python - 如何控制在 MNIST 中训练的 GAN 生成哪个数字?