MobileNet-v2[2018-CVPR]

Linear Bottlenecks

  • ReLU or Linear

           

  1. X' = T^-1(ReLU(T*X))  | 将input数据通过随机矩阵嵌入到高维manifold中使用ReLU作为激活函数进行变换,然后再通过逆变换T^-1将变换后的数据ReLU(T*X)映射到原始的低维manifold空间.
  2. 若映射manifold的维度较小,通过ReLU作用后返回到原始空间中的数据信息丢失较多[原始的流行结构基本被破坏]
  3. 若映射manifold的维度较大,通过ReLU作用后返回到原始空间中的数据依旧能够较好地保留原始数据的流行结构[信息]

Inverted Residuals

  • Residual BlockInverted Residual Block

                     

  1. 在传统的ResBlock[Bottleneck]结构中,feature_map经历:降维、卷积、升维,期间都要按照ReLU(BN(Conv))顺序进行变换,按照Linear Bottlenecks环节的分析,这样的组合拳容易导致feature_map信息的丢失!
  2. 为了解决Bottleneck存在的信息丢失的问题,Inverted-Bottleneck应运而生。feature_map经历:升维、卷积[DSC]、降维.

Mobilev2-Block

                                     

class ConvBNReLU(nn.Sequential):
    def __init__(self, in_planes, out_planes, kernel_size=3, stride=1, groups=1):
        padding = (kernel_size - 1) // 2
        super(ConvBNReLU, self).__init__(
            nn.Conv2d(in_planes, out_planes, kernel_size, stride, padding, groups=groups, bias=False),
            nn.BatchNorm2d(out_planes),
            nn.ReLU6(inplace=True))
class InvertedResidual(nn.Module):
    def __init__(self, inp, oup, stride, expand_ratio):
        super(InvertedResidual, self).__init__()
        self.stride = stride
        assert stride in [1, 2]

        hidden_dim = int(round(inp * expand_ratio))
        self.use_res_connect = self.stride == 1 and inp == oup

        layers = []
        if expand_ratio != 1:
            layers.append(ConvBNReLU(inp, hidden_dim, kernel_size=1)) # pw
        layers.extend([
            ConvBNReLU(hidden_dim, hidden_dim, stride=stride, groups=hidden_dim), # dw
            nn.Conv2d(hidden_dim, oup, 1, 1, 0, bias=False),  # # pw-linear
            nn.BatchNorm2d(oup),
        ])
        self.conv = nn.Sequential(*layers)

    def forward(self, x):
        if self.use_res_connect:
            return x + self.conv(x)
        else:
            return self.conv(x)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ReLuJie

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值