计算机视觉·MaskFormer

MaskFormer

借助了DETR 的核心思想,不过将原本的目标检测任务迁移到了语义分割和全景分割领域。

方法

前向过程

  • 和DETR一样,使用骨干网络获取一个低分辨率特征图。再使用一个FPN获得分辨率与输入图像相同的特征图(缘于语义分割任务的特点)。
    + 设置N个查询向量,然后每个查询向量作为Q,特征图作为K和V,进行交叉注意力计算 ,得到对应N个段嵌入。
  • 然后和DETR一致,这N个段嵌入首先通过一个简单的MLP得到维度为N×(K+1)N\times (K+1)N×(K+1)的类别概率分布,也是引入了一个No object类别,K是目标数。
  • 不同的是,需要生成掩码,不能直接通过段嵌入+线性层得到。于是段嵌入会被映射为掩码嵌入 ,掩码嵌入与特征图进行QK矩阵乘法操作,得到N×H×WN\times H\times WN×H×W个语义掩码。
  • 需要注意的是:这些掩码不是二值的!这些掩码不是二值的!这些掩码不是二值的!,只经过了sigmoid进行简单的激活。

训练损失

  • 损失与DETR的原理保持基本一致
  • 生产的N个软掩码与M个真实掩码进行匹配。

如何定义真实掩码GT mask?

图像中可能有x个类别的注释,这x个注释可以看作是一个真实掩码。对于示例分割,还要求这x个注释互相不连通(也就是属于同一类别且连通的掩码才是真实掩码)。

  • 匹配上非no object类 的计算掩码损失:就是语义分割任务中常用的dice和focal损失
  • 所有查询对应的类别概率分布都要计算交叉熵损失

推理方式

  • 对于一般的语义分割任务:每一个查询向量的类别概率分布p_i×\times×生成的软掩码m_i,最后求和即可,得到H*W的类别概率分布,最后取最大值即可。
  • 注意:对于属于no object的类别不进行任何计算
相关推荐
qq_200465051 小时前
数字文明与农耕文明的交响:2025世界金猪日重构产业文化新范式
人工智能·重构·生活·旅游·业界资讯
人邮异步社区1 小时前
完全没接触过AI/NLP,如何系统学习大模型?
人工智能·学习·自然语言处理·大模型
CV码1 小时前
基于MediaPipe的静态手势识别实现
人工智能·opencv·计算机视觉·手势识别
数据的世界011 小时前
重构智慧书-第5条:从 “依赖操控” 到 “价值共生”
人工智能
小霖家的混江龙1 小时前
不再害怕数学,给开发者的 AI 向量 (Vector) 入门课,看完秒懂!
人工智能·llm
湘-枫叶情缘1 小时前
虚拟妻子项目可行性方案:以LLM与多模态AI构建下一代情感陪伴系统
人工智能·生活
蒲公英源码1 小时前
AI智能办公系统:一体化OA解决方案,支持PC/公众号/H5/App/小程序
人工智能·小程序
roman_日积跬步-终至千里1 小时前
【】模式识别与机器学习基础概念
人工智能·机器学习
卢卡上学1 小时前
【AI编码】Claude Code是什么?如何安装和使用Claude Code|小白Claude Code使用教程与完整指南
人工智能·claude·claude code·aicodemirror