IoU
类keras.metrics.IoU(
num_classes,
target_class_ids,
name=None,
dtype=None,
ignore_class=None,
sparse_y_true=True,
sparse_y_pred=True,
axis=-1,
)
计算特定目标类别的交并比 (Intersection-Over-Union) 指标。
公式
iou = true_positives / (true_positives + false_positives + false_negatives)
交并比是语义图像分割的常用评估指标。
为了计算交并比,预测结果会累积到一个混淆矩阵中,并按 sample_weight
加权,然后从中计算指标。
如果 sample_weight
为 None
,则权重默认为 1。使用 sample_weight
为 0 来掩盖值。
请注意,此类首先计算所有单个类别的交并比,然后返回由 target_class_ids
指定的类别的交并比的平均值。如果 target_class_ids
只有一个 id 值,则返回该特定类别的交并比。
参数
ignore_class=None
),将考虑所有类别。False
,则使用 argmax
函数确定每个样本最有可能关联的标签。False
,则使用 argmax
函数确定每个样本最有可能关联的标签。-1
。示例
>>> # cm = [[1, 1],
>>> # [1, 1]]
>>> # sum_row = [2, 2], sum_col = [2, 2], true_positives = [1, 1]
>>> # iou = true_positives / (sum_row + sum_col - true_positives))
>>> # iou = [0.33, 0.33]
>>> m = keras.metrics.IoU(num_classes=2, target_class_ids=[0])
>>> m.update_state([0, 0, 1, 1], [0, 1, 0, 1])
>>> m.result()
0.33333334
>>> m.reset_state()
>>> m.update_state([0, 0, 1, 1], [0, 1, 0, 1],
... sample_weight=[0.3, 0.3, 0.3, 0.1])
>>> # cm = [[0.3, 0.3],
>>> # [0.3, 0.1]]
>>> # sum_row = [0.6, 0.4], sum_col = [0.6, 0.4],
>>> # true_positives = [0.3, 0.1]
>>> # iou = [0.33, 0.14]
>>> m.result()
0.33333334
与 compile()
API 一起使用
model.compile(
optimizer='sgd',
loss='mse',
metrics=[keras.metrics.IoU(num_classes=2, target_class_ids=[0])])
BinaryIoU
类keras.metrics.BinaryIoU(
target_class_ids=(0, 1), threshold=0.5, name=None, dtype=None
)
计算类别 0 和/或 1 的交并比指标。
公式
iou = true_positives / (true_positives + false_positives + false_negatives)
交并比是语义图像分割的常用评估指标。
为了计算交并比,预测结果会累积到一个混淆矩阵中,并按 sample_weight
加权,然后从中计算指标。
如果 sample_weight
为 None
,则权重默认为 1。使用 sample_weight
为 0 来掩盖值。
此类可用于计算二元分类任务的交并比,其中预测以 logits 的形式提供。首先,将 threshold
应用于预测值,使得低于 threshold
的值转换为类别 0,高于 threshold
的值转换为类别 1。
然后计算类别 0 和 1 的交并比,返回由 target_class_ids
指定的类别的交并比的平均值。
注意:当 threshold=0
时,此指标的行为与 IoU
相同。
参数
[0]
、[1]
或 [0, 1]
。使用 [0]
(或 [1]
),返回类别 0(或类别 1)的交并比指标。使用 [0, 1]
,返回两个类别的交并比的平均值。threshold
)或预测的类别 1(如果 logit 高于 threshold
)。示例
示例
>>> m = keras.metrics.BinaryIoU(target_class_ids=[0, 1], threshold=0.3)
>>> m.update_state([0, 1, 0, 1], [0.1, 0.2, 0.4, 0.7])
>>> m.result()
0.33333334
>>> m.reset_state()
>>> m.update_state([0, 1, 0, 1], [0.1, 0.2, 0.4, 0.7],
... sample_weight=[0.2, 0.3, 0.4, 0.1])
>>> # cm = [[0.2, 0.4],
>>> # [0.3, 0.1]]
>>> # sum_row = [0.6, 0.4], sum_col = [0.5, 0.5],
>>> # true_positives = [0.2, 0.1]
>>> # iou = [0.222, 0.125]
>>> m.result()
0.17361112
与 compile()
API 一起使用
model.compile(
optimizer='sgd',
loss='mse',
metrics=[keras.metrics.BinaryIoU(
target_class_ids=[0],
threshold=0.5
)]
)
OneHotIoU
类keras.metrics.OneHotIoU(
num_classes,
target_class_ids,
name=None,
dtype=None,
ignore_class=None,
sparse_y_pred=False,
axis=-1,
)
计算 one-hot 编码标签的交并比指标。
公式
iou = true_positives / (true_positives + false_positives + false_negatives)
交并比是语义图像分割的常用评估指标。
为了计算交并比,预测结果会累积到一个混淆矩阵中,并按 sample_weight
加权,然后从中计算指标。
如果 sample_weight
为 None
,则权重默认为 1。使用 sample_weight
为 0 来掩盖值。
此类可用于计算多类分类任务的交并比,其中标签是 one-hot 编码的(最后一个轴应该每个类别有一个维度)。请注意,预测也应该具有相同的形状。为了计算交并比,首先通过对类别轴取 argmax 将标签和预测转换回整数格式。然后应用与基本 IoU
类相同的计算步骤。
请注意,如果标签和预测中只有一个通道,则此类与 IoU
类相同。在这种情况下,请改用 IoU
。
另外,请确保 num_classes
等于数据中的类别数,以避免在计算混淆矩阵时出现“标签超出范围”错误。
参数
ignore_class=None
),将考虑所有类别。False
,则使用 argmax
函数确定每个样本最有可能关联的标签。-1
。示例
>>> y_true = np.array([[0, 0, 1], [1, 0, 0], [0, 1, 0], [1, 0, 0]])
>>> y_pred = np.array([[0.2, 0.3, 0.5], [0.1, 0.2, 0.7], [0.5, 0.3, 0.1],
... [0.1, 0.4, 0.5]])
>>> sample_weight = [0.1, 0.2, 0.3, 0.4]
>>> m = keras.metrics.OneHotIoU(num_classes=3, target_class_ids=[0, 2])
>>> m.update_state(
... y_true=y_true, y_pred=y_pred, sample_weight=sample_weight)
>>> # cm = [[0, 0, 0.2+0.4],
>>> # [0.3, 0, 0],
>>> # [0, 0, 0.1]]
>>> # sum_row = [0.3, 0, 0.7], sum_col = [0.6, 0.3, 0.1]
>>> # true_positives = [0, 0, 0.1]
>>> # single_iou = true_positives / (sum_row + sum_col - true_positives))
>>> # mean_iou = (0 / (0.3 + 0.6 - 0) + 0.1 / (0.7 + 0.1 - 0.1)) / 2
>>> m.result()
0.071
与 compile()
API 一起使用
model.compile(
optimizer='sgd',
loss='mse',
metrics=[keras.metrics.OneHotIoU(
num_classes=3,
target_class_id=[1]
)]
)
OneHotMeanIoU
类keras.metrics.OneHotMeanIoU(
num_classes, name=None, dtype=None, ignore_class=None, sparse_y_pred=False, axis=-1
)
计算 one-hot 编码标签的平均交并比指标。
公式
iou = true_positives / (true_positives + false_positives + false_negatives)
交并比是语义图像分割的常用评估指标。
为了计算交并比,预测结果会累积到一个混淆矩阵中,并按 sample_weight
加权,然后从中计算指标。
如果 sample_weight
为 None
,则权重默认为 1。使用 sample_weight
为 0 来掩盖值。
此类可用于计算多类分类任务的平均交并比,其中标签是 one-hot 编码的(最后一个轴应该每个类别有一个维度)。请注意,预测也应该具有相同的形状。为了计算平均交并比,首先通过对类别轴取 argmax 将标签和预测转换回整数格式。然后应用与基本 MeanIoU
类相同的计算步骤。
请注意,如果标签和预测中只有一个通道,则此类与 MeanIoU
类相同。在这种情况下,请改用 MeanIoU
。
另外,请确保 num_classes
等于数据中的类别数,以避免在计算混淆矩阵时出现“标签超出范围”错误。
参数
ignore_class=None
),将考虑所有类别。False
,则将使用 argmax
函数确定每个样本最有可能关联的标签。-1
。示例
>>> y_true = np.array([[0, 0, 1], [1, 0, 0], [0, 1, 0], [1, 0, 0]])
>>> y_pred = np.array([[0.2, 0.3, 0.5], [0.1, 0.2, 0.7], [0.5, 0.3, 0.1],
... [0.1, 0.4, 0.5]])
>>> sample_weight = [0.1, 0.2, 0.3, 0.4]
>>> m = keras.metrics.OneHotMeanIoU(num_classes=3)
>>> m.update_state(
... y_true=y_true, y_pred=y_pred, sample_weight=sample_weight)
>>> # cm = [[0, 0, 0.2+0.4],
>>> # [0.3, 0, 0],
>>> # [0, 0, 0.1]]
>>> # sum_row = [0.3, 0, 0.7], sum_col = [0.6, 0.3, 0.1]
>>> # true_positives = [0, 0, 0.1]
>>> # single_iou = true_positives / (sum_row + sum_col - true_positives))
>>> # mean_iou = (0 + 0 + 0.1 / (0.7 + 0.1 - 0.1)) / 3
>>> m.result()
0.048
与 compile()
API 一起使用
model.compile(
optimizer='sgd',
loss='mse',
metrics=[keras.metrics.OneHotMeanIoU(num_classes=3)])
MeanIoU
类keras.metrics.MeanIoU(
num_classes,
name=None,
dtype=None,
ignore_class=None,
sparse_y_true=True,
sparse_y_pred=True,
axis=-1,
)
计算平均交并比指标。
公式
iou = true_positives / (true_positives + false_positives + false_negatives)
交并比是语义图像分割的常用评估指标。
为了计算交并比,预测结果会累积到一个混淆矩阵中,并按 sample_weight
加权,然后从中计算指标。
如果 sample_weight
为 None
,则权重默认为 1。使用 sample_weight
为 0 来掩盖值。
请注意,此类首先计算所有单个类别的交并比,然后返回这些值的平均值。
参数
ignore_class=None
),将考虑所有类别。False
,则使用 argmax
函数确定每个样本最有可能关联的标签。False
,则使用 argmax
函数确定每个样本最有可能关联的标签。-1
。示例
示例
>>> # cm = [[1, 1],
>>> # [1, 1]]
>>> # sum_row = [2, 2], sum_col = [2, 2], true_positives = [1, 1]
>>> # iou = true_positives / (sum_row + sum_col - true_positives))
>>> # result = (1 / (2 + 2 - 1) + 1 / (2 + 2 - 1)) / 2 = 0.33
>>> m = keras.metrics.MeanIoU(num_classes=2)
>>> m.update_state([0, 0, 1, 1], [0, 1, 0, 1])
>>> m.result()
0.33333334
>>> m.reset_state()
>>> m.update_state([0, 0, 1, 1], [0, 1, 0, 1],
... sample_weight=[0.3, 0.3, 0.3, 0.1])
>>> m.result().numpy()
0.23809525
与 compile()
API 一起使用
model.compile(
optimizer='sgd',
loss='mse',
metrics=[keras.metrics.MeanIoU(num_classes=2)])