torcheval.metrics.functional.multiclass_precision_recall_curve¶
- torcheval.metrics.functional.multiclass_precision_recall_curve(input: Tensor, target: Tensor, *, num_classes: int | None = None) Tuple[List[Tensor], List[Tensor], List[Tensor]] ¶
返回多类分类任务的精度-召回对及其对应的阈值。如果目标张量中缺少某个类,则其召回值将设置为 1.0。
其类版本为
torcheval.metrics.MulticlassPrecisionRecallCurve
。- 参数:
input (Tensor) – 标签预测的张量,其形状应为 (n_sample, n_class),表示概率或 logits。
target (Tensor) – 真实标签的张量,其形状为 (n_samples, )。
num_classes (Optional) – 类别数量。如果 num_classes 为 None,则设置为输入的第二维度。
- 返回:
- List[torch.Tensor], recall: List[torch.Tensor], thresholds: List[torch.Tensor])
precision: 精度结果列表。每个索引表示一个类的结果。recall: 召回结果列表。每个索引表示一个类的结果。thresholds: 阈值列表。每个索引表示一个类的结果。
- 返回类型:
一个包含 (precision
示例
>>> import torch >>> from torcheval.metrics.functional import multiclass_precision_recall_curve >>> input = torch.tensor([[0.1, 0.1, 0.1, 0.1], [0.5, 0.5, 0.5, 0.5], [0.7, 0.7, 0.7, 0.7], [0.8, 0.8, 0.8, 0.8]]) >>> target = torch.tensor([0, 1, 2, 3]) >>> multiclass_precision_recall_curve(input, target, num_classes=4) ([tensor([0.2500, 0.0000, 0.0000, 0.0000, 1.0000]), tensor([0.2500, 0.3333, 0.0000, 0.0000, 1.0000]), tensor([0.2500, 0.3333, 0.5000, 0.0000, 1.0000]), tensor([0.2500, 0.3333, 0.5000, 1.0000, 1.0000])], [tensor([1., 0., 0., 0., 0.]), tensor([1., 1., 0., 0., 0.]), tensor([1., 1., 1., 0., 0.]), tensor([1., 1., 1., 1., 0.])], [tensor([0.1000, 0.5000, 0.7000, 0.8000]), tensor([0.1000, 0.5000, 0.7000, 0.8000]), tensor([0.1000, 0.5000, 0.7000, 0.8000]), tensor([0.1000, 0.5000, 0.7000, 0.8000])])