torcheval.metrics.functional.multiclass_f1_score¶
- torcheval.metrics.functional.multiclass_f1_score(input: Tensor, target: Tensor, *, num_classes: int | None = None, average: str | None = 'micro') Tensor ¶
计算 F1 分数,定义为精确率和召回率的调和平均数。当 F1 分数为 NaN 时,我们将 NaN 转换为零。当精确率或召回率为 NaN,或者精确率和召回率都为零时,就会出现这种情况。它的类版本是
torcheval.metrics.MultiClassF1Score
。- 参数:
input (Tensor) – 标签预测的张量。它可以是预测的标签,形状为 (n_sample, )。它也可以是形状为 (n_sample, n_class) 的概率或 logits。
torch.argmax
将用于将输入转换为预测的标签。target (Tensor) – 形状为 (n_sample, ) 的真实标签张量。
num_classes – 类别数量。
average –
'micro'
[默认]全局计算指标。
'macro'
:分别计算每个类别的指标,并返回它们的未加权平均值。忽略真实实例和预测实例都为 0 的类别。
'weighted'
”分别计算每个类别的指标,并返回它们的加权总和。权重定义为每个类别在“target”中出现的比例。忽略真实实例和预测实例都为 0 的类别。
无
:分别计算每个类别的指标,并返回每个类别的指标。
示例
>>> import torch >>> from torcheval.metrics.functional import multiclass_f1_score >>> input = torch.tensor([0, 2, 1, 3]) >>> target = torch.tensor([0, 1, 2, 3]) >>> multiclass_f1_score(input, target, num_classes=4) tensor(0.5000) >>> input = torch.tensor([0, 2, 1, 3]) >>> target = torch.tensor([0, 1, 2, 3]) >>> multiclass_f1_score(input, target, num_classes=4, average=None) tensor([1., 0., 0., 1.]) >>> input = torch.tensor([0, 0, 1, 1, 1]) >>> target = torch.tensor([0, 0, 0, 0, 1]) >>> multiclass_f1_score(input, target, num_classes=2, average="macro") tensor(0.5833) >>> input = torch.tensor([[0.9, 0.1, 0, 0], [0.1, 0.2, 0.4, 0.3], [0, 1.0, 0, 0], [0, 0, 0.2, 0.8]]) >>> target = torch.tensor([0, 1, 2, 3]) >>> multiclass_f1_score(input, target, num_classes=4) tensor(0.5)