首页 > 其他分享 >FPN理论合集

FPN理论合集

时间:2022-10-24 22:14:21浏览次数:109  
标签:特征 理论 FPN 网络 卷积 图像 金字塔 合集

FPN(Feature Pyramid Networks)

FPN提出原因

卷积网络中,深层网络容易响应语义特征,浅层网络容易响应图像特征。然而,在目标检测中往往因为卷积网络的这个特征带来了不少麻烦:

高层网络虽然能响应语义特征,但是由于Feature Map的尺寸太小,拥有的几何信息并不多,不利于目标的检测;浅层网络虽然包含比较多的几何信息,但是图像的语义特征并不多,不利于图像的分类。这个问题在小目标检测中更为突出。

因此,如果我们能够合并深层和浅层特征的话,那么将同时满足目标检测和图像分类的需要。

FPN具体思路

img

  • 图(a): 图像金字塔,先对原始图像构造图像金字塔,然后在图像金字塔的每一层提出不同的特征,然后进行相应的预测,最后统计所有尺寸的预测结果。优点:精度不错;缺点:计算量大,占用内存大。

  • 图(b):Feature Map: 使用神经网络某一层输出的feature map进行预测,一般是网络最后一层feature map(例如Fast R-CNN,Faster R-CNN等); 然后靠近网络输入层的feature map包含粗略的位置信息,导致预测的目标框bbox不准确,靠近网络最后一层的feature map会忽略小物体信息。优点:速度快,内存少;缺点:仅关注深层网络中最后一层的特征,却忽略了其他层的特征

  • 图(c):特征金字塔:同时利用低层特征和高层特征。就是首先在原始图片上面进行深度卷积,然后分别在不同的特征层上面进行预测。

    优点:在不同的层上面输出对应的目标,不需要经过所有曾才输出对应的目标,速度更快,又提高了算法的检测性能;缺点:获得的特征不鲁棒,都是一些弱特征。

  • 图(d):特征金字塔网络:对对底层的特征进行向上采样,并与底层特征进行融合,得到高分辨率、强语义的特征(即加强了特征的提取)。简单概括来说就是:自下而上,自上而下,横向连接和卷积融合。

整体过程:

(1)自下而上:先把预处理好的图片送进预训练的网络,比如像ResNet这些,这一步就是构建自下而上的网络,就是对应下图中的(1,2,3)这一组金字塔。

(2)自上而下:将层3进行一个复制变成层4,对层4进行上采样操作(就是2 * up),再用1 * 1卷积对层2进行降维处理,然后将两者对应元素相加(这里就是高低层特征的一个汇总),这样我们就得到了层5,层6以此类推,是由层5和层1进行上述操作得来的。这样就构成了自上而下网络,对应下图(4,5,6)金字塔。(其中的层2与上采样后的层4进行相加,就是横向连接的操作)

(3)卷积融合:最后我们对层4,5,6分别来一个3 * 3卷积操作得到最终的预测(对应下图的predict)。

img

标签:特征,理论,FPN,网络,卷积,图像,金字塔,合集
From: https://www.cnblogs.com/horolee/p/fpn.html

相关文章

  • Java BigDecimal 合集
    HDU17532个小数相加importjava.math.*;importjava.util.*;publicclasshdu1753{publicstaticvoidmain(StringArgs[]){Scannercin=newScanner(Syste......
  • 误差理论与测量平差基础——例题补充推导Part2
      ......
  • Faster R-CNN理论合集
    FasterR-CNNR-CNN(RegionwithCNNfeature)算法流程​ RCNN算法流程可分为4个步骤一张图像生成1k~2k个候选区域(使用SelectiveSearch方法)对每个候选区域,使用......
  • python面试-理论面试题
    1.变量与值在内存中的关系变量通过变量指针,引用对象变量指针指向具体对象的内存空间,取对象的值。1.对象,类型已知,每个对象都包含一个头部信息(头部信息:类型标识符和引用......
  • 大厂Istio基础与实践 云原生“薪”能力合集,一线大厂实战
    大厂Istio基础与实践云原生“薪”能力合集,一线大厂实战导言:上一篇章给大家介绍了服务治理方案ServiceMesh(服务网格)产生的背景、逻辑架构、应用场景。本篇将要介绍的......
  • 【算法训练营day10】理论基础 LeetCode232. 用栈实现队列 LeetCode225. 用队列实现栈
    【算法训练营day10】理论基础LeetCode232.用栈实现队列LeetCode225.用队列实现栈理论基础栈常用函数#include<stack>stack<int>s;s.empty();//如果栈为......
  • 2022年十大接口测试工具合集《建议.收藏》
    接口测试的全称是应用程序编程接口(API)测试,从原理上来说,接口测试是模拟客户端向服务器端发送请求,然后检查能否获得正确的返回信息。接口测试用于测试RESTfulAPI、SOAPWeb服......
  • Java开发必学知识合集(一)
    前言Java开发过程中,常用且重要的知识点是开发中最基本的,尤其是刚接触Java开发不久的开发者来说,基本功很重要,是直接做Java工作的基本,那么本文就来分享一下在Java开发过程中的......
  • Linux Vim(vi) 常使用命令快捷键合集
    vi命令是UNIX操作系统和类UNIX操作系统中最通用的全屏幕纯文本编辑器。Linux中的vi编辑器叫vim,它是vi的增强版(viImproved),与vi编辑器完全兼容,而且实现了很多增强功能,下面......
  • CSP 普及 & 提高 考点 模板合集
    CSP普及&提高考点零、杂项加速cin/cout:ios::sync_with_stdio(false);。注:放在main函数的第一行,但使用它之后不能使用scanf/printf。避坑/防爆0指南。快读:inl......