SSD架构,你不来看看么?

本文深入解析SSD(Single Shot MultiBox Detector)网络结构,包括VGG16特征提取、多尺度特征图生成及Anchor Boxes设定。阐述了如何计算特征图点在原图中的坐标,以及宽高的确定方法。介绍了物体框与锚点框的匹配过程和损失函数计算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言总结

SSD骨架网络结构

  • VGG16部分作为特征提取

SSD特征提取网络结构

  • SD300 也叫 VGG16Extractor300
  • 提取了6个特征张量

锚点框Anchor Boxes和选框预测

Anchor Box 为了实现特征图上的一个点能预测多个物体!

  • Anchor Box的基础大小有7个
  • 选框可有两个正方形,高宽2:1,1:2, 3:1 1:3 ⇒ 最多六个,最少4个

SSD骨架网络结构

  • 结构采用VGG16的conv4和conv5

图引用自 《深入浅出PyTorch 从模型到源码》
在这里插入图片描述

SSD特征提取网络结构

  1. 和VGG输入大小不一样,这次是 300 × 300 300\times300 300×300输入,VGG16是 224 × 224 224\times224 224×224输入
  2. 最后的输出特征空间大小为 1 × 1 1\times1 1×1,有256张,也就是 256 × 1 × 1 256\times1\times1 256×1×1

图引用自 《深入浅出PyTorch 从模型到源码》
在这里插入图片描述

  1. VGG16Extractor300
    提取了六个特征层
conv4_3
conv7
conv8_2
conv9_2
conv10_2
conv11_2

在这里插入图片描述

锚点框Anchor Boxes和选框预测

  • 六张特征图
  • 七个Anchor Box 基础尺寸
    • 30, 60, 111, 162, 213, 265, 315
  • 特征相对于原图的步长
    • 8, 16, 32, 64, 100, 300

如何根据特征图中的点计算原图中的坐标?

假设$(i,j)$为整数,也就是格子图中的左上角坐标, 那么原图中为
( s t r i d e × ( i + 0.5 ) , s t r i d e × ( j + 0.5 ) ) (stride\times(i+0.5),stride\times(j+0.5)) (stride×(i+0.5),stride×(j+0.5))

那知道了原图中对应的中心点坐标,如何知道对应原输入图像中的宽高呢?

😃

如此计算,也解释了为什么有7个基础尺寸!就是为了一个大正方形!
在这里插入图片描述

我们求到了输入原始图像中,真实框的大小和坐标(x,y,w,h), 然后和神经网络预测的框直接求误差?

不是的!我们要求误差!!但是是一个变换!!!

图引用自 《深入浅出PyTorch 从模型到源码》
在这里插入图片描述

其中 ( x ′ , y ′ , w ′ , h ′ ) (x',y',w',h') (x,y,w,h)是神经网络预测的框

物体选框和锚点框的匹配

我们知道,COCO数据集的标签框是 ( x 1 , y 1 , w , h ) (x_1,y_1,w,h) x1,y1,w,h 即左上角左边和宽高。
因此第一步:

  • 坐标转换成两种:
    • 第一种坐标: ( x c , y c , w , h ) (x_c,y_c,w,h) (xc,yc,w,h)即中心坐标化
    • 第二种坐标: ( x 1 , y 1 , x 2 , y 2 ) (x_1,y_1,x_2,y_2) (x1,y1,x2,y2)即左上角和右下角坐标

匹配物体框和锚点框:

一个锚点框能且只能匹配一个目标框(IOU最大者)
一个目标框却可以匹配多个锚点框,然后计算 ( g x , g y , g w , g h ) (g_x, g_y, g_w, g_h) (gx,gy,gw,gh), 并分配标签。

损失函数

F.smooth_l1_loss
避免异常值影响
Huber Estimator
它其实就是k=1情况下的Huber Estimator!!

### 如何通过 CMD 命令检查 SSD 颗粒类型或健康状态 要在 Windows 的命令提示符 (CMD) 中查看 SSD 的颗粒信息或健康状态,可以借助 `smartctl` 工具或其他内置工具来完成。以下是具体方法: #### 方法一:使用 smartctl 查看 SSD 健康状态 如果已经安装了 `smartctl`(通常作为 Smartmontools 的一部分),可以通过以下方式获取 SSD 的详细信息: 1. 打开命令提示符窗口。 2. 输入以下命令以查询 SMART 数据: ```bash smartctl -a /dev/sda --json=o ``` (注意:在 Windows 下可能需要指定驱动器号,例如 `-d sat,N` 或其他适配选项[^1]) 此命令将返回详细的硬件信息,包括但不限于温度、通电时间、写入次数以及 NAND 类型等。 #### 方法二:利用 Windows 自带功能检测硬盘基本信息 虽然无法直接获得具体的颗粒型号,但可通过系统自带的工具了解部分基础属性: 1. 按下组合键 `Windows + R` 启动运行对话框; 2. 键入 `cmd` 并按回车启动命令行界面; 3. 使用如下指令提取当前设备配置详情: ```batch systeminfo | findstr /B /C:"BIOS Version" wmic diskdrive get model, status ``` 上述操作仅能提供有限的信息关于存储装置的状态描述而非确切的技术规格像闪存单元架构之类的内容[^2]。 #### 方法三:基于第三方软件深入分析 对于更详尽的数据采集需求,则建议采用专门设计用于此类目的的应用程序比如 CrystalDiskInfo 。这些应用不仅支持多平台还具备图形化用户界面便于解读复杂参数集合 。 ```python import subprocess def check_ssd_health(): try: result = subprocess.run(['wmic', 'diskdrive', 'get', 'model,', 'status'], capture_output=True, text=True) return result.stdout.strip() except Exception as e: return str(e) print(check_ssd_health()) ``` 以上 Python 脚本片段展示了如何调用 WMIC 来检索磁盘模型及其状况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万物琴弦光锥之外

给个0.1,恭喜老板发财

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值