You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
234 lines
7.5 KiB
234 lines
7.5 KiB
# Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved. |
|
# |
|
# Licensed under the Apache License, Version 2.0 (the "License"); |
|
# you may not use this file except in compliance with the License. |
|
# You may obtain a copy of the License at |
|
# |
|
# http://www.apache.org/licenses/LICENSE-2.0 |
|
# |
|
# Unless required by applicable law or agreed to in writing, software |
|
# distributed under the License is distributed on an "AS IS" BASIS, |
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
# See the License for the specific language governing permissions and |
|
# limitations under the License. |
|
|
|
import platform |
|
from itertools import cycle |
|
|
|
import paddlers |
|
from rs_models.test_model import TestModel |
|
|
|
__all__ = [ |
|
'TestBITModel', 'TestCDNetModel', 'TestChangeStarModel', 'TestDSAMNetModel', |
|
'TestDSIFNModel', 'TestFCEarlyFusionModel', 'TestFCSiamConcModel', |
|
'TestFCSiamDiffModel', 'TestSNUNetModel', 'TestSTANetModel', |
|
'TestChangeFormerModel' |
|
] |
|
|
|
|
|
class TestCDModel(TestModel): |
|
EF_MODE = 'None' # Early-fusion strategy |
|
|
|
def check_output(self, output, target): |
|
self.assertIsInstance(output, list) |
|
self.check_output_equal(len(output), len(target)) |
|
for o, t in zip(output, target): |
|
o = o.numpy() |
|
self.check_output_equal(o.shape[0], t.shape[0]) |
|
self.check_output_equal(len(o.shape), 4) |
|
self.check_output_equal(o.shape[2:], t.shape[2:]) |
|
|
|
def set_inputs(self): |
|
if self.EF_MODE == 'Concat': |
|
# Early-fusion |
|
def _gen_data(specs): |
|
for spec in specs: |
|
c = spec['in_channels'] // 2 |
|
assert c * 2 == spec['in_channels'] |
|
yield [self.get_randn_tensor(c), self.get_randn_tensor(c)] |
|
elif self.EF_MODE == 'None': |
|
# Late-fusion |
|
def _gen_data(specs): |
|
for spec in specs: |
|
c = spec.get('in_channels', 3) |
|
yield [self.get_randn_tensor(c), self.get_randn_tensor(c)] |
|
else: |
|
raise ValueError |
|
self.inputs = _gen_data(self.specs) |
|
|
|
def set_targets(self): |
|
def _gen_data(specs): |
|
for spec in specs: |
|
c = spec.get('num_classes', 2) |
|
yield [self.get_zeros_array(c)] |
|
|
|
self.targets = _gen_data(self.specs) |
|
|
|
|
|
class TestBITModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.BIT |
|
|
|
def set_specs(self): |
|
base_spec = dict(in_channels=3, num_classes=2) |
|
self.specs = [ |
|
base_spec, |
|
dict(**base_spec, backbone='resnet34'), |
|
dict(**base_spec, n_stages=3), |
|
dict(**base_spec, enc_depth=4, dec_head_dim=16), |
|
dict(in_channels=4, num_classes=2), |
|
dict(in_channels=3, num_classes=8) |
|
] # yapf: disable |
|
|
|
|
|
class TestCDNetModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.CDNet |
|
EF_MODE = 'Concat' |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(in_channels=6, num_classes=2), |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=6, num_classes=8) |
|
] # yapf: disable |
|
|
|
|
|
class TestChangeStarModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.ChangeStar |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(num_classes=2), dict(num_classes=10), |
|
dict(num_classes=2, mid_channels=128, num_convs=2), |
|
dict(num_classes=2, _phase='eval', _stop_grad=True) |
|
] # yapf: disable |
|
|
|
def set_targets(self): |
|
# Avoid allocation of large memories |
|
tar_c2 = [self.get_zeros_array(2)] * 4 |
|
self.targets = [ |
|
tar_c2, |
|
[self.get_zeros_array(10)] * 2 + [self.get_zeros_array(2)] * 2, |
|
tar_c2, [self.get_zeros_array(2)] |
|
] |
|
|
|
|
|
class TestDSAMNetModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.DSAMNet |
|
|
|
def set_specs(self): |
|
base_spec = dict(in_channels=3, num_classes=2) |
|
self.specs = [ |
|
base_spec, |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=3, num_classes=8), |
|
dict(**base_spec, ca_ratio=4, sa_kernel=5), |
|
dict(**base_spec, _phase='eval', _stop_grad=True) |
|
] # yapf: disable |
|
|
|
def set_targets(self): |
|
# Avoid allocation of large memories |
|
tar_c2 = [self.get_zeros_array(2)] * 3 |
|
self.targets = [ |
|
tar_c2, tar_c2, [self.get_zeros_array(8)] * 3, tar_c2, |
|
[self.get_zeros_array(2)] |
|
] |
|
|
|
|
|
class TestDSIFNModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.DSIFN |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(num_classes=2), dict(num_classes=10), |
|
dict(num_classes=2, use_dropout=True), |
|
dict(num_classes=2, _phase='eval', _stop_grad=True) |
|
] # yapf: disable |
|
|
|
def set_targets(self): |
|
# Avoid allocation of large memories |
|
tar_c2 = [self.get_zeros_array(2)] * 5 |
|
self.targets = [ |
|
tar_c2, [self.get_zeros_array(10)] * 5, tar_c2, |
|
[self.get_zeros_array(2)] |
|
] |
|
|
|
|
|
class TestFCEarlyFusionModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.FCEarlyFusion |
|
EF_MODE = 'Concat' |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(in_channels=6, num_classes=2), |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=6, num_classes=8), |
|
dict(in_channels=6, num_classes=2, use_dropout=True) |
|
] # yapf: disable |
|
|
|
|
|
class TestFCSiamConcModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.FCSiamConc |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(in_channels=3, num_classes=2), |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=3, num_classes=8), |
|
dict(in_channels=3, num_classes=2, use_dropout=True) |
|
] # yapf: disable |
|
|
|
|
|
class TestFCSiamDiffModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.FCSiamDiff |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(in_channels=3, num_classes=2), |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=3, num_classes=8), |
|
dict(in_channels=3, num_classes=2, use_dropout=True) |
|
] # yapf: disable |
|
|
|
|
|
class TestSNUNetModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.SNUNet |
|
|
|
def set_specs(self): |
|
self.specs = [ |
|
dict(in_channels=3, num_classes=2), |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=3, num_classes=8), |
|
dict(in_channels=3, num_classes=2, width=64) |
|
] # yapf: disable |
|
|
|
|
|
class TestSTANetModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.STANet |
|
|
|
def set_specs(self): |
|
base_spec = dict(in_channels=3, num_classes=2) |
|
self.specs = [ |
|
base_spec, |
|
dict(in_channels=8, num_classes=2), |
|
dict(in_channels=3, num_classes=8), |
|
dict(**base_spec, att_type='PAM'), |
|
dict(**base_spec, ds_factor=4) |
|
] # yapf: disable |
|
|
|
|
|
class TestChangeFormerModel(TestCDModel): |
|
MODEL_CLASS = paddlers.rs_models.cd.ChangeFormer |
|
|
|
def set_specs(self): |
|
base_spec = dict(in_channels=3, num_classes=2) |
|
self.specs = [ |
|
base_spec, |
|
dict(**base_spec, decoder_softmax=True), |
|
dict(**base_spec, embed_dim=56) |
|
] # yapf: disable |
|
|
|
|
|
# HACK:FIXME: We observe an OOM error when running TestSTANetModel.test_forward() on a Windows machine. |
|
# Currently, we do not perform this test. |
|
if platform.system() == 'Windows': |
|
TestSTANetModel.test_forward = lambda self: None
|
|
|