提交 1499b0e5 编写于 作者: W weishengyu

add nn

上级 6520a801
...@@ -22,7 +22,6 @@ import paddle ...@@ -22,7 +22,6 @@ import paddle
from paddle import ParamAttr from paddle import ParamAttr
import paddle.nn as nn import paddle.nn as nn
import paddle.nn.functional as F import paddle.nn.functional as F
from paddle.nn import Conv2D, BatchNorm, Linear
from paddle.nn import AdaptiveAvgPool2D, MaxPool2D, AvgPool2D from paddle.nn import AdaptiveAvgPool2D, MaxPool2D, AvgPool2D
from paddle.nn.initializer import Uniform from paddle.nn.initializer import Uniform
...@@ -59,7 +58,7 @@ class ConvBNLayer(TheseusLayer): ...@@ -59,7 +58,7 @@ class ConvBNLayer(TheseusLayer):
name=None): name=None):
super(ConvBNLayer, self).__init__() super(ConvBNLayer, self).__init__()
self._conv = Conv2D( self._conv = nn.Conv2D(
in_channels=num_channels, in_channels=num_channels,
out_channels=num_filters, out_channels=num_filters,
kernel_size=filter_size, kernel_size=filter_size,
...@@ -69,7 +68,7 @@ class ConvBNLayer(TheseusLayer): ...@@ -69,7 +68,7 @@ class ConvBNLayer(TheseusLayer):
weight_attr=ParamAttr(name=name + "_weights"), weight_attr=ParamAttr(name=name + "_weights"),
bias_attr=False) bias_attr=False)
bn_name = name + '_bn' bn_name = name + '_bn'
self._batch_norm = BatchNorm( self._batch_norm = nn.BatchNorm(
num_filters, num_filters,
act=act, act=act,
param_attr=ParamAttr(name=bn_name + '_scale'), param_attr=ParamAttr(name=bn_name + '_scale'),
...@@ -321,7 +320,7 @@ class SELayer(TheseusLayer): ...@@ -321,7 +320,7 @@ class SELayer(TheseusLayer):
med_ch = int(num_channels / reduction_ratio) med_ch = int(num_channels / reduction_ratio)
stdv = 1.0 / math.sqrt(num_channels * 1.0) stdv = 1.0 / math.sqrt(num_channels * 1.0)
self.squeeze = Linear( self.squeeze = nn.Linear(
num_channels, num_channels,
med_ch, med_ch,
weight_attr=ParamAttr( weight_attr=ParamAttr(
...@@ -329,7 +328,7 @@ class SELayer(TheseusLayer): ...@@ -329,7 +328,7 @@ class SELayer(TheseusLayer):
bias_attr=ParamAttr(name=name + '_sqz_offset')) bias_attr=ParamAttr(name=name + '_sqz_offset'))
stdv = 1.0 / math.sqrt(med_ch * 1.0) stdv = 1.0 / math.sqrt(med_ch * 1.0)
self.excitation = Linear( self.excitation = nn.Linear(
med_ch, med_ch,
num_filters, num_filters,
weight_attr=ParamAttr( weight_attr=ParamAttr(
...@@ -628,7 +627,7 @@ class HRNet(TheseusLayer): ...@@ -628,7 +627,7 @@ class HRNet(TheseusLayer):
stdv = 1.0 / math.sqrt(2048 * 1.0) stdv = 1.0 / math.sqrt(2048 * 1.0)
self.out = Linear( self.out = nn.Linear(
2048, 2048,
class_dim, class_dim,
weight_attr=ParamAttr( weight_attr=ParamAttr(
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册