Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix typo: upsampe_cfg -> upsample_cfg #449

Merged
merged 4 commits into from
Mar 30, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion mmseg/apis/test.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ def single_gpu_test(model,
Args:
model (nn.Module): Model to be tested.
data_loader (utils.data.Dataloader): Pytorch data loader.
show (bool): Whether show results during infernece. Default: False.
show (bool): Whether show results during inference. Default: False.
out_dir (str, optional): If specified, the results will be dumped into
the directory to save output results.
efficient_test (bool): Whether save the results as local numpy files to
Expand Down
2 changes: 1 addition & 1 deletion mmseg/core/evaluation/metrics.py
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,7 @@ def eval_metrics(results,
Returns:
float: Overall accuracy on all images.
ndarray: Per category accuracy, shape (num_classes, ).
ndarray: Per category evalution metrics, shape (num_classes, ).
ndarray: Per category evaluation metrics, shape (num_classes, ).
"""
if isinstance(metrics, str):
metrics = [metrics]
Expand Down
1 change: 0 additions & 1 deletion mmseg/core/seg/sampler/base_pixel_sampler.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,3 @@ def __init__(self, **kwargs):
@abstractmethod
def sample(self, seg_logit, seg_label):
"""Placeholder for sample function."""
pass
5 changes: 2 additions & 3 deletions mmseg/datasets/custom.py
Original file line number Diff line number Diff line change
Expand Up @@ -214,8 +214,8 @@ def prepare_test_img(self, idx):
idx (int): Index of data.

Returns:
dict: Testing data after pipeline with new keys intorduced by
piepline.
dict: Testing data after pipeline with new keys introduced by
pipeline.
"""

img_info = self.img_infos[idx]
Expand All @@ -225,7 +225,6 @@ def prepare_test_img(self, idx):

def format_results(self, results, **kwargs):
"""Place holder to format result to dataset specific output."""
pass

def get_gt_seg_maps(self, efficient_test=False):
"""Get ground truth segmentation maps for evaluation."""
Expand Down
4 changes: 2 additions & 2 deletions mmseg/datasets/pipelines/transforms.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ class Resize(object):
contains the key "scale", then the scale in the input dict is used,
otherwise the specified scale in the init method is used.

``img_scale`` can be Nong, a tuple (single-scale) or a list of tuple
``img_scale`` can be None, a tuple (single-scale) or a list of tuple
(multi-scale). There are 4 multiscale modes:

- ``ratio_range is not None``:
Expand Down Expand Up @@ -89,7 +89,7 @@ def random_sample(img_scales):
Args:
img_scales (list[tuple]): Images scale range for sampling.
There must be two tuples in img_scales, which specify the lower
and uper bound of image scales.
and upper bound of image scales.

Returns:
(tuple, None): Returns a tuple ``(img_scale, None)``, where
Expand Down
4 changes: 2 additions & 2 deletions mmseg/models/backbones/cgnet.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
class GlobalContextExtractor(nn.Module):
"""Global Context Extractor for CGNet.

This class is employed to refine the joFint feature of both local feature
This class is employed to refine the joint feature of both local feature
and surrounding context.

Args:
Expand Down Expand Up @@ -357,7 +357,7 @@ def init_weights(self, pretrained=None):
raise TypeError('pretrained must be a str or None')

def train(self, mode=True):
"""Convert the model into training mode whill keeping the normalization
"""Convert the model into training mode will keeping the normalization
layer freezed."""
super(CGNet, self).train(mode)
if mode and self.norm_eval:
Expand Down
2 changes: 1 addition & 1 deletion mmseg/models/backbones/hrnet.py
Original file line number Diff line number Diff line change
Expand Up @@ -545,7 +545,7 @@ def forward(self, x):
return y_list

def train(self, mode=True):
"""Convert the model into training mode whill keeping the normalization
"""Convert the model into training mode will keeping the normalization
layer freezed."""
super(HRNet, self).train(mode)
if mode and self.norm_eval:
Expand Down
6 changes: 3 additions & 3 deletions mmseg/models/backbones/mobilenet_v3.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ class MobileNetV3(nn.Module):
<https://ieeexplore.ieee.org/document/9008835>`_.

Args:
arch (str): Architechture of mobilnetv3, from {'small', 'large'}.
arch (str): Architecture of mobilnetv3, from {'small', 'large'}.
Default: 'small'.
conv_cfg (dict): Config dict for convolution layer.
Default: None, which means using conv2d.
Expand All @@ -28,13 +28,13 @@ class MobileNetV3(nn.Module):
out_indices (tuple[int]): Output from which layer.
Default: (0, 1, 12).
frozen_stages (int): Stages to be frozen (all param fixed).
Defualt: -1, which means not freezing any parameters.
Default: -1, which means not freezing any parameters.
norm_eval (bool): Whether to set norm layers to eval mode, namely,
freeze running stats (mean and var). Note: Effect on Batch Norm
and its variants only. Default: False.
with_cp (bool): Use checkpoint or not. Using checkpoint will save
some memory while slowing down the training speed.
Defualt: False.
Default: False.
"""
# Parameters to build each block:
# [kernel size, mid channels, out channels, with_se, act type, stride]
Expand Down
28 changes: 14 additions & 14 deletions mmseg/models/backbones/unet.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ class BasicConvBlock(nn.Module):
Default: dict(type='BN').
act_cfg (dict | None): Config dict for activation layer in ConvModule.
Default: dict(type='ReLU').
dcn (bool): Use deformable convoluton in convolutional layer or not.
dcn (bool): Use deformable convolution in convolutional layer or not.
Default: None.
plugins (dict): plugins for convolutional layers. Default: None.
"""
Expand Down Expand Up @@ -171,7 +171,7 @@ class InterpConv(nn.Module):
kernel_size (int): Kernel size of the convolutional layer. Default: 1.
stride (int): Stride of the convolutional layer. Default: 1.
padding (int): Padding of the convolutional layer. Default: 1.
upsampe_cfg (dict): Interpolation config of the upsample layer.
upsample_cfg (dict): Interpolation config of the upsample layer.
Default: dict(
scale_factor=2, mode='bilinear', align_corners=False).
"""
Expand All @@ -188,7 +188,7 @@ def __init__(self,
kernel_size=1,
stride=1,
padding=0,
upsampe_cfg=dict(
upsample_cfg=dict(
scale_factor=2, mode='bilinear', align_corners=False)):
super(InterpConv, self).__init__()

Expand All @@ -202,7 +202,7 @@ def __init__(self,
conv_cfg=conv_cfg,
norm_cfg=norm_cfg,
act_cfg=act_cfg)
upsample = nn.Upsample(**upsampe_cfg)
upsample = nn.Upsample(**upsample_cfg)
if conv_first:
self.interp_upsample = nn.Sequential(conv, upsample)
else:
Expand Down Expand Up @@ -232,17 +232,17 @@ class UNet(nn.Module):
strides (Sequence[int 1 | 2]): Strides of each stage in encoder.
len(strides) is equal to num_stages. Normally the stride of the
first stage in encoder is 1. If strides[i]=2, it uses stride
convolution to downsample in the correspondance encoder stage.
convolution to downsample in the correspondence encoder stage.
Default: (1, 1, 1, 1, 1).
enc_num_convs (Sequence[int]): Number of convolutional layers in the
convolution block of the correspondance encoder stage.
convolution block of the correspondence encoder stage.
Default: (2, 2, 2, 2, 2).
dec_num_convs (Sequence[int]): Number of convolutional layers in the
convolution block of the correspondance decoder stage.
convolution block of the correspondence decoder stage.
Default: (2, 2, 2, 2).
downsamples (Sequence[int]): Whether use MaxPool to downsample the
feature map after the first stage of encoder
(stages: [1, num_stages)). If the correspondance encoder stage use
(stages: [1, num_stages)). If the correspondence encoder stage use
stride convolution (strides[i]=2), it will never use MaxPool to
downsample, even downsamples[i-1]=True.
Default: (True, True, True, True).
Expand All @@ -263,14 +263,14 @@ class UNet(nn.Module):
norm_eval (bool): Whether to set norm layers to eval mode, namely,
freeze running stats (mean and var). Note: Effect on Batch Norm
and its variants only. Default: False.
dcn (bool): Use deformable convoluton in convolutional layer or not.
dcn (bool): Use deformable convolution in convolutional layer or not.
Default: None.
plugins (dict): plugins for convolutional layers. Default: None.

Notice:
The input image size should be devisible by the whole downsample rate
The input image size should be divisible by the whole downsample rate
of the encoder. More detail of the whole downsample rate can be found
in UNet._check_input_devisible.
in UNet._check_input_divisible.

"""

Expand Down Expand Up @@ -373,7 +373,7 @@ def __init__(self,
in_channels = base_channels * 2**i

def forward(self, x):
self._check_input_devisible(x)
self._check_input_divisible(x)
enc_outs = []
for enc in self.encoder:
x = enc(x)
Expand All @@ -395,15 +395,15 @@ def train(self, mode=True):
if isinstance(m, _BatchNorm):
m.eval()

def _check_input_devisible(self, x):
def _check_input_divisible(self, x):
h, w = x.shape[-2:]
whole_downsample_rate = 1
for i in range(1, self.num_stages):
if self.strides[i] == 2 or self.downsamples[i - 1]:
whole_downsample_rate *= 2
assert (h % whole_downsample_rate == 0) \
and (w % whole_downsample_rate == 0),\
f'The input image size {(h, w)} should be devisible by the whole '\
f'The input image size {(h, w)} should be divisible by the whole '\
f'downsample rate {whole_downsample_rate}, when num_stages is '\
f'{self.num_stages}, strides is {self.strides}, and downsamples '\
f'is {self.downsamples}.'
Expand Down
2 changes: 1 addition & 1 deletion mmseg/models/decode_heads/apc_head.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ class ACM(nn.Module):

Args:
pool_scale (int): Pooling scale used in Adaptive Context
Module to extract region fetures.
Module to extract region features.
fusion (bool): Add one conv to fuse residual feature.
in_channels (int): Input channels.
channels (int): Channels after modules, before conv_seg.
Expand Down
8 changes: 4 additions & 4 deletions mmseg/models/decode_heads/dm_head.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,23 +59,23 @@ def __init__(self, filter_size, fusion, in_channels, channels, conv_cfg,

def forward(self, x):
"""Forward function."""
generted_filter = self.filter_gen_conv(
generated_filter = self.filter_gen_conv(
F.adaptive_avg_pool2d(x, self.filter_size))
x = self.input_redu_conv(x)
b, c, h, w = x.shape
# [1, b * c, h, w], c = self.channels
x = x.view(1, b * c, h, w)
# [b * c, 1, filter_size, filter_size]
generted_filter = generted_filter.view(b * c, 1, self.filter_size,
self.filter_size)
generated_filter = generated_filter.view(b * c, 1, self.filter_size,
self.filter_size)
pad = (self.filter_size - 1) // 2
if (self.filter_size - 1) % 2 == 0:
p2d = (pad, pad, pad, pad)
else:
p2d = (pad + 1, pad, pad + 1, pad)
x = F.pad(input=x, pad=p2d, mode='constant', value=0)
# [1, b * c, h, w]
output = F.conv2d(input=x, weight=generted_filter, groups=b * c)
output = F.conv2d(input=x, weight=generated_filter, groups=b * c)
# [b, c, h, w]
output = output.view(b, c, h, w)
if self.norm is not None:
Expand Down
2 changes: 1 addition & 1 deletion mmseg/models/decode_heads/gc_head.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ class GCHead(FCNHead):
pooling_type (str): The pooling type of context aggregation.
Options are 'att', 'avg'. Default: 'avg'.
fusion_types (tuple[str]): The fusion type for feature fusion.
Options are 'channel_add', 'channel_mul'. Defautl: ('channel_add',)
Options are 'channel_add', 'channel_mul'. Default: ('channel_add',)
"""

def __init__(self,
Expand Down
6 changes: 3 additions & 3 deletions mmseg/models/losses/lovasz_loss.py
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ def lovasz_softmax_flat(probs, labels, classes='present', class_weight=None):
probs (torch.Tensor): [P, C], class probabilities at each prediction
(between 0 and 1).
labels (torch.Tensor): [P], ground truth labels (between 0 and C - 1).
classes (str | list[int], optional): Classes choosed to calculate loss.
classes (str | list[int], optional): Classes chosen to calculate loss.
'all' for all classes, 'present' for classes present in labels, or
a list of classes to average. Default: 'present'.
class_weight (list[float], optional): The weight for each class.
Expand Down Expand Up @@ -183,7 +183,7 @@ def lovasz_softmax(probs,
prediction (between 0 and 1).
labels (torch.Tensor): [B, H, W], ground truth labels (between 0 and
C - 1).
classes (str | list[int], optional): Classes choosed to calculate loss.
classes (str | list[int], optional): Classes chosen to calculate loss.
'all' for all classes, 'present' for classes present in labels, or
a list of classes to average. Default: 'present'.
per_image (bool, optional): If per_image is True, compute the loss per
Expand Down Expand Up @@ -232,7 +232,7 @@ class LovaszLoss(nn.Module):
Args:
loss_type (str, optional): Binary or multi-class loss.
Default: 'multi_class'. Options are "binary" and "multi_class".
classes (str | list[int], optional): Classes choosed to calculate loss.
classes (str | list[int], optional): Classes chosen to calculate loss.
'all' for all classes, 'present' for classes present in labels, or
a list of classes to average. Default: 'present'.
per_image (bool, optional): If per_image is True, compute the loss per
Expand Down
6 changes: 3 additions & 3 deletions mmseg/models/utils/inverted_residual.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
from mmcv.cnn import ConvModule
from torch import nn as nn
from torch import nn
from torch.utils import checkpoint as cp

from .se_layer import SELayer
Expand Down Expand Up @@ -101,10 +101,10 @@ class InvertedResidualV3(nn.Module):
in_channels (int): The input channels of this Module.
out_channels (int): The output channels of this Module.
mid_channels (int): The input channels of the depthwise convolution.
kernel_size (int): The kernal size of the depthwise convolution.
kernel_size (int): The kernel size of the depthwise convolution.
Default: 3.
stride (int): The stride of the depthwise convolution. Default: 1.
se_cfg (dict): Config dict for se layer. Defaul: None, which means no
se_cfg (dict): Config dict for se layer. Default: None, which means no
se layer.
with_expand_conv (bool): Use expand conv or not. If set False,
mid_channels must be the same with in_channels. Default: True.
Expand Down
6 changes: 3 additions & 3 deletions mmseg/models/utils/se_layer.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,10 @@ class SELayer(nn.Module):
conv_cfg (None or dict): Config dict for convolution layer.
Default: None, which means using conv2d.
act_cfg (dict or Sequence[dict]): Config dict for activation layer.
If act_cfg is a dict, two activation layers will be configurated
If act_cfg is a dict, two activation layers will be configured
by this dict. If act_cfg is a sequence of dicts, the first
activation layer will be configurated by the first dict and the
second activation layer will be configurated by the second dict.
activation layer will be configured by the first dict and the
second activation layer will be configured by the second dict.
Default: (dict(type='ReLU'), dict(type='HSigmoid', bias=3.0,
divisor=6.0)).
"""
Expand Down
2 changes: 1 addition & 1 deletion mmseg/models/utils/up_conv_block.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ class UpConvBlock(nn.Module):
high-level feature map is the same as that of skip feature map
(low-level feature map from encoder), it does not need upsample the
high-level feature map and the upsample_cfg is None.
dcn (bool): Use deformable convoluton in convolutional layer or not.
dcn (bool): Use deformable convolution in convolutional layer or not.
Default: None.
plugins (dict): plugins for convolutional layers. Default: None.
"""
Expand Down
10 changes: 5 additions & 5 deletions mmseg/ops/encoding.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import torch
from torch import nn as nn
from torch import nn
from torch.nn import functional as F


Expand Down Expand Up @@ -43,14 +43,14 @@ def scaled_l2(x, codewords, scale):
return scaled_l2_norm

@staticmethod
def aggregate(assigment_weights, x, codewords):
def aggregate(assignment_weights, x, codewords):
num_codes, channels = codewords.size()
reshaped_codewords = codewords.view((1, 1, num_codes, channels))
batch_size = x.size(0)

expanded_x = x.unsqueeze(2).expand(
(batch_size, x.size(1), num_codes, channels))
encoded_feat = (assigment_weights.unsqueeze(3) *
encoded_feat = (assignment_weights.unsqueeze(3) *
(expanded_x - reshaped_codewords)).sum(dim=1)
return encoded_feat

Expand All @@ -61,10 +61,10 @@ def forward(self, x):
# [batch_size, height x width, channels]
x = x.view(batch_size, self.channels, -1).transpose(1, 2).contiguous()
# assignment_weights: [batch_size, channels, num_codes]
assigment_weights = F.softmax(
assignment_weights = F.softmax(
self.scaled_l2(x, self.codewords, self.scale), dim=2)
# aggregate
encoded_feat = self.aggregate(assigment_weights, x, self.codewords)
encoded_feat = self.aggregate(assignment_weights, x, self.codewords)
return encoded_feat

def __repr__(self):
Expand Down
Loading