news 2026/5/25 2:25:56

机器学习弃权机制:附加式与融合式实现详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
机器学习弃权机制:附加式与融合式实现详解

1. 项目概述

在机器学习,尤其是分类任务中,我们通常期望模型对每一个输入样本都给出一个明确的类别标签。然而,现实世界的数据充满了模糊性和不确定性。想象一下,你是一位放射科医生,面对一张乳腺X光片,图像特征可能恰好落在良性和恶性病变的边界上,或者图像质量不佳、存在伪影。此时,一个有经验的医生不会贸然给出“良性”或“恶性”的诊断,而是会要求进行进一步的检查,或者明确标注“无法判断”。这种“知之为知之,不知为不知”的审慎态度,正是人类智能在面对不确定性时的核心体现。那么,机器学习模型能否、以及如何具备这种“自知之明”呢?这就是弃权机制(Abstention)要解决的核心问题。

弃权机制允许模型在认为自身预测不可靠时,主动选择“不回答”,而不是给出一个可能错误的答案。这听起来简单,但其背后的技术实现路径却大有不同,主要分为附加式弃权融合式弃权两大类。前者像是在一个成熟的分类器外部加装了一个独立的“质检员”,后者则是将“弃权”内化为模型决策逻辑的一部分。选择哪种方式,不仅影响模型的性能指标,更深远地,它触及了一个有趣的哲学问题:机器的这种“拒绝判断”行为,在多大程度上类似于人类认知中的“悬置判断”?本文将深入拆解这两种弃权机制的技术细节、实现逻辑、适用场景,并探讨其背后的设计哲学与工程权衡。

2. 弃权机制的核心价值与分类依据

在深入技术细节之前,我们必须先厘清:模型为什么需要弃权?以及,什么样的不确定性值得弃权?

2.1 为何弃权:从实用主义到可靠性工程

从最功利的视角看,弃权是为了提升系统的整体可靠性用户体验。在一个二分类系统中,准确率从95%提升到96%可能需要巨大的工程代价,但通过一个设计良好的弃权机制,拒绝掉那最难判断的1%的样本,系统的覆盖准确率(即只对那些做出判断的样本计算的准确率)可能轻松达到99%以上。这在医疗诊断、金融风控、自动驾驶等高风险领域具有决定性意义。一个偶尔“不知道”但极其可靠的系统,远比一个总是“瞎猜”的系统更有价值。

更深层次地,弃权机制促使我们正视机器学习模型的一个根本局限:它们是在有限的、有偏的训练数据上学习到的函数近似器。对于训练数据分布之外的样本(分布外样本)或处于类别决策边界附近的模糊样本,模型的预测本质上是外推或内插,其置信度可能完全失真。弃权机制为模型提供了一种“安全阀”,使其能够承认自身知识的边界。

2.2 不确定性溯源:模糊性与异常值

根据不确定性的来源,弃权通常针对两种典型情况:

  1. 模糊性弃权:输入样本本身特征模糊,导致模型对不同类别的支持度相近。例如,一张狗的照片同时具有哈士奇和阿拉斯加的特征。判断一个样本是否模糊,强烈依赖于已训练好的具体模型。因为模糊性存在于特征空间中不同类别决策边界的重叠区域,而这个区域的形状是由模型参数决定的。仅凭原始训练数据和该样本本身,无法预先判断其是否模糊。

  2. 异常值弃权:输入样本与训练数据整体分布差异巨大,属于模型未曾见过的“新奇”事物。例如,给一个狗品种分类器输入一张猫的图片。判断一个样本是否为异常值,可以相对独立于具体的分类模型,更多地基于该样本与整个训练数据集的相似度(如距离度量、密度估计)。理论上,在模型训练之前,我们就可以通过分析训练数据分布,预先划定一个“正常数据区域”。

理解这两种不确定性的区别至关重要,因为它直接决定了后续弃权机制技术路线的选择。一个旨在处理模糊样本的机制,在应对异常值时可能效果不佳,反之亦然。

3. 技术实现深度解析:附加式弃权

附加式弃权,顾名思义,是在原有的预测模型(我们称之为预测器)之上,附加一个独立的拒绝器模块。预测器和拒绝器各司其职,流程上是分离的。根据拒绝器发挥作用的时间点,又可分为算法前附加算法后附加

3.1 算法前附加弃权:守门员策略

在这种架构中,拒绝器像一个严格的“守门员”,在输入数据进入预测器之前就进行拦截检查。

3.1.1 工作原理与流程其工作流程是线性的、分阶段的:

  1. 输入:样本x进入系统。
  2. 拒绝判断:拒绝器r首先被激活。它基于预设的规则或模型,判断是否应该对该样本弃权。这个判断完全独立于最终的分类结果。
  3. 决策分支
    • 如果拒绝器判断为“弃权”,则流程立即终止,系统直接输出“弃权”结果。预测器f根本不会启动
    • 如果拒绝器判断为“通过”,则样本被传递给预测器f
  4. 预测:预测器f对样本进行常规分类,输出一个类别标签y
  5. 输出:系统输出预测结果y

3.1.2 典型实现与适用场景算法前附加的核心是设计拒绝器的判断逻辑。常见方法包括:

  • 基于距离/密度的异常检测:计算输入样本x到训练集整体或各类别中心的距离(如马氏距离、K近邻距离)。如果距离超过某个阈值τ,则判定为异常值并弃权。这非常适用于异常值弃权
  • 基于重构误差的模型:使用自编码器等模型学习训练数据的正常模式。对于新样本,计算其重构误差。误差过大表明该样本无法被已有模式很好地表示,可能为异常值。
  • 简单规则过滤器:在特定领域,可以设置硬性规则。例如,在医疗图像分析中,如果图像亮度低于某个阈值或信噪比太差,直接拒绝处理。

注意:算法前附加极不适用于模糊性弃权。因为模糊性本质上是样本相对于已训练好的决策边界的位置属性。在预测器尚未运行、决策边界未知的情况下,拒绝器无法获知样本是否处于模糊区域。试图用算法前附加处理模糊性,就像让一个没见过考卷的监考老师提前判断某道题是否超纲一样困难。

3.1.3 优势与局限

  • 优势
    • 计算高效:对于被拒绝的样本,避免了运行可能更复杂的预测模型,节省了计算资源。
    • 概念清晰:模块化设计,拒绝器和预测器可以独立开发和优化。
    • 天然适合异常检测:是处理分布外样本、对抗样本的第一道防线。
  • 局限
    • 无法处理模糊性:这是其最根本的局限。
    • 可能误杀:过于保守的拒绝器可能会拒绝掉许多其实可以被可靠分类的样本,导致覆盖率过低。
    • 阈值调优:拒绝阈值τ的选择需要谨慎,通常需要在验证集上通过权衡弃权率与覆盖准确率来确定。

3.2 算法后附加弃权:事后质检员策略

这是更常见、更直观的附加式弃权。预测器先对所有样本进行常规预测,然后拒绝器再对预测结果的质量进行“质检”。

3.2.1 工作原理与流程

  1. 输入与预测:样本x直接进入预测器ff像在非弃权系统中一样工作,产生一个预测结果。通常,f还会输出一个反映本次预测置信度不确定���的标量值c(例如,神经网络softmax层的最大概率值、支持向量机中到决策边界的距离)。
  2. 质量评估:拒绝器r接收预测结果和置信度c
  3. 阈值决策:拒绝器将置信度c与一个预设的阈值τ进行比较。
    • 如果c >= τ,认为预测足够可靠,输出预测类别。
    • 如果c < τ,认为预测不可靠,输出“弃权”。
  4. 输出:根据比较结果,输出最终决定。

3.2.2 置信度来源与阈值设定置信度c的获取是关键:

  • 模型原生输出:许多模型天然能提供不确定性估计,如贝叶斯神经网络的后验分布、决策树的类别概率、softmax输出向量的熵或最大概率值。
  • 事后校准:对于本身不产出校准概率的模型(如SVM),可以使用Platt缩放、Isotonic回归等方法对原始输出进行校准,使其转化为有意义的概率值。
  • 集成方法:通过多次推理(如MC Dropout)或多个模型的预测(如模型集成),计算预测的方差或一致性,作为不确定性的度量。

阈值τ的选择是一个典型的精度-召回权衡问题。提高τ,系统更保守,弃权更多,覆盖准确率更高,但能做出判断的样本(覆盖率)更少。降低τ,系统更激进,覆盖率上升,但覆盖准确率可能下降。在实际应用中,通常根据业务风险设定一个可接受的最低覆盖准确率目标,然后调整τ以达到该目标。

3.2.3 优势与局限

  • 优势
    • 能有效处理模糊性:因为它利用了模型对已见样本的决策置信度,而模糊样本正在置信度低的区域。
    • 实现简单:无需改动核心预测模型,只需在其输出端增加一个判断逻辑,易于集成到现有系统。
    • 灵活性高:可以方便地更换不同的不确定性估计方法。
  • 局限
    • 对异常值可能失效:一个与训练数据截然不同的异常值,可能会被模型以“高置信度”错误地归入某个已知类别(过度泛化)。算法后附加依赖于模型自身的置信度,而这种置信度对异常值常常是误判的。
    • 计算浪费:即使最终要弃权,也先完成了完整的预测计算。
    • 置信度校准难题:许多模型的原始输出(如softmax概率)并非真实的校准概率,直接用作置信度可能导致系统性偏差,需要额外的校准步骤。

3.3 附加式弃权的本质与哲学映射

无论是算法前还是算法后,附加式弃权的核心特征是预测弃权决策分离。系统实际上回答了两个问题

  1. 核心问题Q:“这个样本属于哪个类别?”(由预测器回答)。
  2. 元问题Q':“我对刚才给出的答案有多大把握?”或“这个样本是否值得回答?”(由拒绝器回答)。

弃权行为,是对元问题Q’的否定回答所触发的结果,而非对核心问题Q的直接回应。从哲学上看,这类似于一种元认知监控:先形成一个初步判断(信念),然后评估这个判断的可靠性。如果评估认为可靠性不足,则选择不采纳这个判断。但这与人类哲学讨论中的“悬置判断”存在微妙差别。悬置判断通常被视为对问题Q本身的直接态度(“我暂时不对Q做出判断”),而非对另一个关于判断质量的元问题的回答。

4. 技术实现深度解析:融合式弃权

融合式弃权采取了截然不同的思路。它不再将弃权视为一个外部附加的质检步骤,而是将其内化为模型预测行为本身的一部分。在融合式架构中,模型被直接训练成能够输出“弃权”这个特殊类别。

4.1 核心思想:弃权作为第(N+1)类

在K类分类问题中,融合式模型将输出空间从原来的K个类别,扩展为K+1个类别,其中第(K+1)类就是“弃权”。模型的目标函数被修改,使得它在面对难以判断的样本时,选择“弃权”所带来的损失,小于强行将其错误分类到某个具体类别所带来的损失。

4.2 实现路径一:有标签弃权

这是最直观的融合式训练方法,将弃权视为一个普通的类别进行监督学习。

4.2.1 训练数据准备你需要手动构建包含“弃权”标签的训练数据。例如,在狗品种分类任务中,训练集不仅包含标注为“哈士奇”、“拉布拉多”的图片,还需要包含一批明确标注为“弃权”的图片。这些“弃权”样本可能包括:

  • 模糊样本:同时像两个品种的狗。
  • 异常样本:非狗的图片(猫、汽车)、低质量图片(模糊、遮挡)。
  • 领域外样本:其他犬科动物(狼、狐狸)。

4.2.2 模型训练与损失函数训练过程与普通多分类任务完全相同。损失函数(如交叉熵损失)被扩展以处理这第(K+1)个类别。模型学习从输入特征到K+1个类别的映射。决策边界不再仅仅是区分K个类别,还需要划分出一个“弃权区域”。

4.2.3 优势与挑战

  • 优势:概念简单,直接利用成熟的监督学习框架。
  • 挑战
    1. 标注成本与可行性:为“弃权”收集有代表性的样本并准确标注极其困难。什么样的图片应该被标为“弃权”?这个标准本身就很模糊,且高度依赖于模型未来的能力边界。
    2. 概念扭曲:这种方法实质上将“弃权”物化为了一个具体的、与“哈士奇”平级的类别。这背离了弃权“拒绝选择已定义答案”的初衷。模型学习到的是“当输入看起来像这批‘弃权’训练图片时,就输出弃权标签”,而不是“当我对已有类别不确定时,我选择弃权”。这更像是在学习一个包含了“未知”类别的更大分类问题。

4.3 实现路径二:无标签弃权(损失函数修正法)

这是更优雅、也更符合弃权哲学本意的实现方式。训练数据中没有任何样本被标记为“弃权”,所有样本都只有正常的K类标签。弃权能力是通过修改损失函数,让模型在训练中自行“领悟”何时应该弃权。

4.3.1 损失函数设计精髓核心思想是:为“弃权”这一行为赋予一个介于“正确分类”和“错误分类”之间的惩罚成本 α

假设在一个二分类(恶性/良性)任务中,原始损失函数l为0-1损失:

  • 预测正确,损失为 0。
  • 预测错误,损失为 1。

现在我们引入弃权选项,并定义新的损失函数l*

  • 预测正确,损失为 0。
  • 预测错误,损失为 1。
  • 选择弃权,损失为 α,其中0 < α < 1

这个设计的妙处在于:对于一个模型难以判断的样本,如果它强行猜测,有很高概率猜错(期望损失接近1),而选择弃权的损失是固定的α。只要α小于模型在该样本上出错的期望损失,模型从损失最小化的角度出发,就会“理性地”学会对该样本弃权。

4.3.2 训练动态与α的意义参数α是一个超参数,控制着模型的“弃权倾向”。

  • α接近0:弃权成本极低,模型倾向于对大量样本弃权,变得非常保守。
  • α接近1:弃权成本几乎和错误一样高,模型几乎从不弃权,变得非常激进。
  • α = 0.5:在一个���分类问题中,如果模型对两个类别的预测概率都是0.5(完全不确定),那么猜错的期望损失是0.51 + 0.51 = 1,而弃权损失是0.5。此时弃权是更优选择。这符合直觉:当你不确定时,不如明白地说“我不知道”。

更一般化的理论(如Chow规则)指出,对于K类分类,最优的弃权阈值与α有关。模型应该弃权当且仅当其预测的最可能类别的概率小于 (1 - α)。α成为了可靠性与覆盖率之间权衡的直观控制旋钮。

4.3.3 优势与哲学意涵

  • 优势
    • 无需弃权标签:解决了有标签方法最大的数据瓶颈。
    • 符合弃权本质:模型是在学习“何时不应做出确定判断”,而不是学习一个名为“弃权”的静态类别。弃权区域是由模型在训练过程中,根据其自身的不确定性动态形成的。
    • 端到端训练:预测和弃权决策在一个统一的框架下联合优化,可能达到更好的整体性能。
  • 哲学意涵:无标签融合式弃权更接近人类“悬置判断”的认知过程。模型并非被明确告知“这些情况你要说不知道”,而是通过任务目标(最小化损失)的设定,自己推导出在证据不足时,采取一种不同于肯定性信念的、特殊的“悬置”态度是更有利的。这体现了某种内在的、基于代价的理性。

5. 附加式与融合式的综合对比与选型指南

理解了两种机制的细节后,我们可以从多个维度进行系统对比,为实际项目选型提供依据。

特性维度附加式弃权 (Attached Abstention)融合式弃权 (Merged Abstention)
核心架构预测器 + 独立的拒绝器(附加模块)单一的、具备弃权输出能力的预测器(融合模型)
弃权决策点在预测前(算法前)或预测后(算法后)与分类决策同时进行,作为同一前向传播过程的一部分
与预测的关系分离、顺序执行融合、同时学习与执行
主要适用场景算法前:异常值检测。算法后:模糊样本处理、校准后置信度过滤。有标签:可明确界定弃权样本的领域。无标签:通用不确定性处理,尤其是模糊性。
训练数据需求无需改变原有训练数据(拒绝器可能需单独训练)。有标签:需要大量标注“弃权”的样本,成本高。无标签:只需正常标注数据,通过损失函数引导。
训练过程通常分阶段训练:先训练预测器,再训练/配置拒绝器。有标签:端到端多分类训练。无标签:端到端训练,但使用修正的损失函数。
可解释性较高。拒绝逻辑(如阈值、距离)通常清晰可解释。较低。弃权决策隐含在复杂的模型参数中,较难追溯具体原因。
计算效率算法前:对拒绝样本效率高。算法后:总有预测计算,可能浪费算力。一次前向传播同时完成预测和弃权决策,效率固定。
与哲学“悬置”的相似度较低。更像是“元认知检查”后的否决,而非对原问题的直接悬置态度。较高(尤指无标签)。弃权是模型对原问题的一种直接输出选项,更接近“无法判断”的悬置状态。

选型建议:

  • 如果你的核心风险来自“未知的未知”(如系统可能遇到完全没见过的数据类型),算法前附加弃权(结合异常检测)应是你的第一道防线。
  • 如果你主要处理已知类别内的模糊案例,并且拥有一个能产出较校准置信度的模型(如现代深度学习模型),算法后附加弃权简单有效,易于集成。
  • 如果你追求端到端的性能最优,且有能力设计、调试复杂的损失函数,无标签融合式弃权是前沿且潜力巨大的方向,它能让模型更“自主”地学会何时放弃。
  • 除非有极其明确和充足的“弃权”场景数据,否则应尽量避免有标签融合式弃权,因为它容易扭曲任务本质,且数据准备成本过高。

6. 实战:为图像分类模型实现算法后附加弃权

让我们以一个具体的PyTorch图像分类项目为例,展示如何为一个训练好的ResNet模型添加算法后附加弃权逻辑。

6.1 环境与模型准备假设我们已有一个在CIFAR-10上预训练好的ResNet-18模型,用于10类图像分类。

import torch import torch.nn as nn import torch.nn.functional as F from torchvision import models, transforms from torch.utils.data import DataLoader import numpy as np # 加载预训练模型 model = models.resnet18(pretrained=False, num_classes=10) # 假设已加载训练好的权重 # model.load_state_dict(torch.load('best_model.pth')) model.eval() # 数据预处理 transform = transforms.Compose([ transforms.ToTensor(), transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5)) ])

6.2 置信度计算与弃权函数我们使用模型softmax输出的最大类别概率作为置信度估计。

def predict_with_abstention(model, input_tensor, threshold=0.8): """ 带弃权功能的预测函数 Args: model: 训练好的分类模型 input_tensor: 输入图像张量 (C, H, W) 或 (B, C, H, W) threshold: 弃权阈值,置信度低于此值则弃权 Returns: predicted_class: 预测的类别索引(若未弃权) confidence: 预测置信度 abstention_flag: 是否弃权 (True/False) """ with torch.no_grad(): outputs = model(input_tensor.unsqueeze(0) if input_tensor.dim() == 3 else input_tensor) probabilities = F.softmax(outputs, dim=1) confidence, predicted = torch.max(probabilities, dim=1) # 应用阈值进行弃权判断 abstention_flag = confidence < threshold # 如果弃权,将预测类别设为-1(或一个特殊值) final_prediction = torch.where(abstention_flag, torch.tensor(-1, device=predicted.device), predicted) return final_prediction.item() if final_prediction.numel() == 1 else final_prediction, confidence.item(), abstention_flag.item()

6.3 阈值τ的选择与调优阈值的选择不能拍脑袋决定,需要基于一个验证集来系统性地权衡。

def evaluate_abstention_threshold(model, val_loader, threshold_candidates): """ 评估不同弃权阈值下的模型性能 Args: model: 模型 val_loader: 验证集DataLoader threshold_candidates: 待评估的阈值列表,如 [0.5, 0.6, 0.7, 0.8, 0.9] Returns: results: 字典,记录每个阈值下的覆盖率、覆盖准确率等指标 """ results = {} device = next(model.parameters()).device for tau in threshold_candidates: correct = 0 total = 0 abstained = 0 for images, labels in val_loader: images, labels = images.to(device), labels.to(device) outputs = model(images) probs = F.softmax(outputs, dim=1) confidence, preds = torch.max(probs, dim=1) # 弃权判断 not_abstain_mask = confidence >= tau abstained += (confidence < tau).sum().item() # 只计算未弃权样本的准确率 if not_abstain_mask.any(): correct += (preds[not_abstain_mask] == labels[not_abstain_mask]).sum().item() total += not_abstain_mask.sum().item() coverage = total / len(val_loader.dataset) # 覆盖率 covered_accuracy = correct / total if total > 0 else 0.0 # 覆盖准确率 abstention_rate = abstained / len(val_loader.dataset) # 弃权率 results[tau] = { 'coverage': coverage, 'covered_accuracy': covered_accuracy, 'abstention_rate': abstention_rate } print(f"Threshold {tau}: Coverage={coverage:.3f}, Covered Acc={covered_accuracy:.3f}, Abstention Rate={abstention_rate:.3f}") return results # 假设有验证集 val_dataset 和 val_loader # thresholds = np.arange(0.1, 1.0, 0.05) # results = evaluate_abstention_threshold(model, val_loader, thresholds)

6.4 结果分析与业务决策运行上述评估后,你会得到一条准确率-覆盖率曲线(或类似曲线)。你需要与业务方共同决策:

  • 高风险场景(如医疗):可能要求覆盖准确率 > 99%,即使这意味着覆盖率只有85%。选择能达成此目标的最低阈值。
  • 体验优先场景(如内容推荐):可能要求覆盖率 > 95%,同时准确率不能低于某个值。选择能满足覆盖率要求下,准确率最高的阈值。

实操心得:阈值调优不是一劳永逸的。当模型更新、数据分布漂移时,需要重新评估和调整阈值。可以考虑在线学习或定期回测来监控弃权机制的有效性。

7. 常见陷阱、问题排查与进阶思考

7.1 置信度校准:你的概率可信吗?许多深度学习模型(特别是使用交叉熵损失和softmax的)输出的“概率”并非真实的校准概率。它们往往倾向于“过度自信”,即对正确预测的置信度估计过高,对错误预测的置信度又估计不足。直接使用这种未校准的置信度进行弃权,会导致系统要么过于激进(该弃权的不弃),要么过于保守(弃权过多)。

解决方案

  • 温度缩放:在softmax函数中引入一个温度参数T,在验证集上优化T,使得模型输出的置信度分布与真实准确率对齐。这是最常用且简单的后处理校准方法。
  • Platt缩放/等渗回归:适用于二分类或可将问题转化为二分类的情况。
  • 使用贝叶斯方法:如MC Dropout、深度集成,它们能提供更好的不确定性估计。

7.2 分布外检测的挑战算法后附加弃权依赖模型自身的置信度,但模型对OOD样本常常会给出高置信度的错误预测。如何让模型对OOD样本也产生低置信度?

解决方案

  • 专门化的OOD检测模块:这正是算法前附加弃权的用武之地。可以训练一个独立的能量模型或使用马氏距离等度量,专门检测输入是否偏离训练分布。
  • 改进训练方式:在训练时混入一些OOD样本(标注为一个统一的“其他”类或使用特定的损失函数),让模型显式地学习识别未知。
  • 基于梯度的特征:研究发现,OOD样本在模型特征空间中的梯度统计特性与ID样本不同,可用于检测。

7.3 损失函数中的α如何设定?在无标签融合式弃权中,损失函数中的弃权惩罚α是关键。除了通过验证集网格搜索,还有一些理论指导:

  • 基于类别先验:如果各类别样本数量严重不均衡,可以对不同类别设置不同的α。例如,在疾病诊断中,对罕见病样本的误判惩罚应更高,相应地,对其弃权的惩罚α可以设得低一些,鼓励模型在不确定时对罕见病弃权。
  • 动态α:α不一定是一个固定标量。可以设计为与样本特征或模型中间状态相关的动态值,实现更精细的控制。

7.4 弃权后的流程闭环设计弃权机制时,必须想清楚:模型弃权之后,该怎么办?这是一个系统工程问题。

  • 人工复核:将弃权的样本交给人类专家处理。需要设计高效的人机交互界面。
  • 移交下级模型:使用一个更复杂、更耗资源但更准确的模型(如集成模型、更大的模型)对弃权样本进行二次判断。
  • 请求更多信息:在交互式系统中,可以主动向用户提问,获取更多特征信息(如“请从另一个角度拍摄照片”)。
  • 延迟决策:在某些流式处理中,可以暂时搁置,等待更多上下文数据到来后再做判断。

7.5 评估指标:超越准确率引入弃权后,传统的准确率不再适用。需要一套新的评估体系:

  • 覆盖率:模型做出非弃权预测的样本比例。
  • 覆盖准确率/选择性准确率:在模型做出预测的样本子集上的准确率。
  • 风险-覆盖率曲线:绘制覆盖准确率随覆盖率变化的曲线,曲线下的面积可用于比较不同弃权策略。
  • 代价敏感评估:为正确分类、错误分类和弃权分别赋予不同的代价(如C_correct=0,C_error=10,C_abstain=1),计算系统的总体期望代价。这能直接反映弃权机制在业务层面的价值。

弃权机制不是机器学习模型的“失败模式”,而是其走向成熟、可靠和负责任的关键一步。它标志着我们从单纯追求预测的“锐度”,转向同时追求预测的“信度”。无论是选择附加式的清晰架构,还是拥抱融合式的端到端学习,其核心都是让机器在面对世界的复杂与不确定时,能够像一位谨慎的专家那样,懂得何时该说:“此事,我需存疑。”

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 2:22:11

Unity Oculus VR开发避坑指南:Quest 2/3环境配置与真机验证全链路

1. 为什么Oculus环境是Unity VR开发绕不开的“第一道关卡”在Unity做VR全平台游戏开发这条路上&#xff0c;我见过太多团队把“支持所有头显”当成一句口号写进立项文档&#xff0c;结果三个月后卡死在Oculus Quest 2的打包环节——不是黑屏就是手柄失联&#xff0c;调试日志里…

作者头像 李华
网站建设 2026/5/25 2:21:09

Cube MatMul:为什么矩阵乘法选了 Cube 而不是 Vector

本文基于昇腾CANN和昇腾NPU&#xff0c;围绕 Cube MatMul 矩阵乘法技术展开。 想象你在一个巨大的停车场里搬箱子。方案 A&#xff1a;一次搬一个箱子&#xff0c;走 100 趟——这是 Vector 的做法。方案 B&#xff1a;用叉车一次叉起 1616 个箱子&#xff0c;一趟搞定——这是…

作者头像 李华
网站建设 2026/5/25 2:20:20

Arm嵌入式开发中的代码覆盖率分析实践

1. 在Arm开发环境中实现代码覆盖率分析的核心思路对于嵌入式开发者而言&#xff0c;代码覆盖率分析是验证测试完备性的重要手段。Arm Toolchain for Embedded&#xff08;ATfE&#xff09;基于LLVM工具链&#xff0c;提供了完整的代码覆盖率解决方案。与传统的gcov方案相比&…

作者头像 李华
网站建设 2026/5/25 2:19:52

Ubuntu 20.04上源码编译ROS2 Humble,我踩过的那些坑和最终解决方案

Ubuntu 20.04源码编译ROS2 Humble避坑指南&#xff1a;从崩溃边缘到完美运行 当你在Ubuntu 20.04上尝试源码编译ROS2 Humble时&#xff0c;官方文档看起来就像是一份完美的食谱——直到你真正开始动手。作为一名经历过无数次失败才最终成功的开发者&#xff0c;我想分享那些官方…

作者头像 李华
网站建设 2026/5/25 2:12:52

2026年最值得用的10款免费AI写作工具推荐

AI写作工具在2026年迎来了爆发式增长&#xff0c;越来越多的免费工具让普通人也能高效创作。本文整理了10款最值得用的免费AI写作工具&#xff0c;涵盖博客、营销文案、学术写作等多个场景。一、AI Writing Assistant - 全能型免费写作工具AI Writing Assistant&#xff08;use…

作者头像 李华