多标签分类中的ROC曲线具有斜率

我有一个用Keras编写的多标签分类器,我希望计算每个测试集元素的AUC并绘制ROC曲线。

enter image description here

一切看起来都很好,除了某些元素的ROC曲线具有如下斜率:

enter image description here

我不知道在这种情况下如何解释斜率。

我的工作流程大致如下:我有一个预训练的model,是Keras的一个实例,我有特征X和二值化标签yy中的每个元素是一个长度为1000的数组,因为这是一个多标签分类问题,y中的每个元素可能包含多个1,表示该元素属于多个类别,因此我使用了内置的binary_crossentropy损失函数,我的模型预测输出是分数概率。然后我按照以下方式绘制ROC曲线。

from sklearn.metrics import roc_curve, auc#...for xi, yi in (X_test, y_test):    y_pred = model.predict([xi])[0]    fpr, tpr, _ = roc_curve(yi, y_pred)    plt.plot(fpr, tpr, color='darkorange', lw=0.5)

预测方法返回概率,因为我使用了Keras的函数式API。

有谁知道为什么ROC曲线看起来像这样吗?


回答:

在scikit-learn的邮件列表中询问,他们回答说:

斜率通常意味着你的预测中有平局。

这正是这个问题的情况。

Related Posts

Keras Dense层输入未被展平

这是我的测试代码: from keras import…

无法将分类变量输入随机森林

我有10个分类变量和3个数值变量。我在分割后直接将它们…

如何在Keras中对每个输出应用Sigmoid函数?

这是我代码的一部分。 model = Sequenti…

如何选择类概率的最佳阈值?

我的神经网络输出是一个用于多标签分类的预测类概率表: …

在Keras中使用深度学习得到不同的结果

我按照一个教程使用Keras中的深度神经网络进行文本分…

‘MatMul’操作的输入’b’类型为float32,与参数’a’的类型float64不匹配

我写了一个简单的TensorFlow代码,但不断遇到T…

发表回复

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