test_cd_models.py 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. # Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved.
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License");
  4. # you may not use this file except in compliance with the License.
  5. # You may obtain a copy of the License at
  6. #
  7. # http://www.apache.org/licenses/LICENSE-2.0
  8. #
  9. # Unless required by applicable law or agreed to in writing, software
  10. # distributed under the License is distributed on an "AS IS" BASIS,
  11. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. # See the License for the specific language governing permissions and
  13. # limitations under the License.
  14. from itertools import cycle
  15. import paddlers
  16. from rs_models.test_model import TestModel, allow_oom
  17. __all__ = [
  18. 'TestBITModel', 'TestCDNetModel', 'TestChangeStarModel', 'TestDSAMNetModel',
  19. 'TestDSIFNModel', 'TestFCEarlyFusionModel', 'TestFCSiamConcModel',
  20. 'TestFCSiamDiffModel', 'TestSNUNetModel', 'TestSTANetModel',
  21. 'TestChangeFormerModel'
  22. ]
  23. class TestCDModel(TestModel):
  24. EF_MODE = 'None' # Early-fusion strategy
  25. def check_output(self, output, target):
  26. self.assertIsInstance(output, list)
  27. self.check_output_equal(len(output), len(target))
  28. for o, t in zip(output, target):
  29. o = o.numpy()
  30. self.check_output_equal(o.shape, t.shape)
  31. def set_inputs(self):
  32. if self.EF_MODE == 'Concat':
  33. # Early-fusion
  34. def _gen_data(specs):
  35. for spec in specs:
  36. c = spec['in_channels'] // 2
  37. assert c * 2 == spec['in_channels']
  38. yield [self.get_randn_tensor(c), self.get_randn_tensor(c)]
  39. elif self.EF_MODE == 'None':
  40. # Late-fusion
  41. def _gen_data(specs):
  42. for spec in specs:
  43. c = spec.get('in_channels', 3)
  44. yield [self.get_randn_tensor(c), self.get_randn_tensor(c)]
  45. else:
  46. raise ValueError
  47. self.inputs = _gen_data(self.specs)
  48. def set_targets(self):
  49. def _gen_data(specs):
  50. for spec in specs:
  51. c = spec.get('num_classes', 2)
  52. yield [self.get_zeros_array(c)]
  53. self.targets = _gen_data(self.specs)
  54. class TestBITModel(TestCDModel):
  55. MODEL_CLASS = paddlers.rs_models.cd.BIT
  56. def set_specs(self):
  57. base_spec = dict(in_channels=3, num_classes=2)
  58. self.specs = [
  59. base_spec,
  60. dict(**base_spec, backbone='resnet34'),
  61. dict(**base_spec, n_stages=3),
  62. dict(**base_spec, enc_depth=4, dec_head_dim=16),
  63. dict(in_channels=4, num_classes=2),
  64. dict(in_channels=3, num_classes=8)
  65. ] # yapf: disable
  66. class TestCDNetModel(TestCDModel):
  67. MODEL_CLASS = paddlers.rs_models.cd.CDNet
  68. EF_MODE = 'Concat'
  69. def set_specs(self):
  70. self.specs = [
  71. dict(in_channels=6, num_classes=2),
  72. dict(in_channels=8, num_classes=2),
  73. dict(in_channels=6, num_classes=8)
  74. ] # yapf: disable
  75. class TestChangeStarModel(TestCDModel):
  76. MODEL_CLASS = paddlers.rs_models.cd.ChangeStar
  77. def set_specs(self):
  78. self.specs = [
  79. dict(num_classes=2), dict(num_classes=10),
  80. dict(num_classes=2, mid_channels=128, num_convs=2),
  81. dict(num_classes=2, _phase='eval', _stop_grad=True)
  82. ] # yapf: disable
  83. def set_targets(self):
  84. # Avoid allocation of large memories
  85. tar_c2 = [self.get_zeros_array(2)] * 4
  86. self.targets = [
  87. tar_c2,
  88. [self.get_zeros_array(10)] * 2 + [self.get_zeros_array(2)] * 2,
  89. tar_c2, [self.get_zeros_array(2)]
  90. ]
  91. class TestDSAMNetModel(TestCDModel):
  92. MODEL_CLASS = paddlers.rs_models.cd.DSAMNet
  93. def set_specs(self):
  94. base_spec = dict(in_channels=3, num_classes=2)
  95. self.specs = [
  96. base_spec,
  97. dict(in_channels=8, num_classes=2),
  98. dict(in_channels=3, num_classes=8),
  99. dict(**base_spec, ca_ratio=4, sa_kernel=5),
  100. dict(**base_spec, _phase='eval', _stop_grad=True)
  101. ] # yapf: disable
  102. def set_targets(self):
  103. # Avoid allocation of large memories
  104. tar_c2 = [self.get_zeros_array(2)] * 3
  105. self.targets = [
  106. tar_c2, tar_c2, [self.get_zeros_array(8)] * 3, tar_c2,
  107. [self.get_zeros_array(2)]
  108. ]
  109. class TestDSIFNModel(TestCDModel):
  110. MODEL_CLASS = paddlers.rs_models.cd.DSIFN
  111. def set_specs(self):
  112. self.specs = [
  113. dict(num_classes=2), dict(num_classes=10),
  114. dict(num_classes=2, use_dropout=True),
  115. dict(num_classes=2, _phase='eval', _stop_grad=True)
  116. ] # yapf: disable
  117. def set_targets(self):
  118. # Avoid allocation of large memories
  119. tar_c2 = [self.get_zeros_array(2)] * 5
  120. self.targets = [
  121. tar_c2, [self.get_zeros_array(10)] * 5, tar_c2,
  122. [self.get_zeros_array(2)]
  123. ]
  124. class TestFCEarlyFusionModel(TestCDModel):
  125. MODEL_CLASS = paddlers.rs_models.cd.FCEarlyFusion
  126. EF_MODE = 'Concat'
  127. def set_specs(self):
  128. self.specs = [
  129. dict(in_channels=6, num_classes=2),
  130. dict(in_channels=8, num_classes=2),
  131. dict(in_channels=6, num_classes=8),
  132. dict(in_channels=6, num_classes=2, use_dropout=True)
  133. ] # yapf: disable
  134. class TestFCSiamConcModel(TestCDModel):
  135. MODEL_CLASS = paddlers.rs_models.cd.FCSiamConc
  136. def set_specs(self):
  137. self.specs = [
  138. dict(in_channels=3, num_classes=2),
  139. dict(in_channels=8, num_classes=2),
  140. dict(in_channels=3, num_classes=8),
  141. dict(in_channels=3, num_classes=2, use_dropout=True)
  142. ] # yapf: disable
  143. class TestFCSiamDiffModel(TestCDModel):
  144. MODEL_CLASS = paddlers.rs_models.cd.FCSiamDiff
  145. def set_specs(self):
  146. self.specs = [
  147. dict(in_channels=3, num_classes=2),
  148. dict(in_channels=8, num_classes=2),
  149. dict(in_channels=3, num_classes=8),
  150. dict(in_channels=3, num_classes=2, use_dropout=True)
  151. ] # yapf: disable
  152. class TestSNUNetModel(TestCDModel):
  153. MODEL_CLASS = paddlers.rs_models.cd.SNUNet
  154. def set_specs(self):
  155. self.specs = [
  156. dict(in_channels=3, num_classes=2),
  157. dict(in_channels=8, num_classes=2),
  158. dict(in_channels=3, num_classes=8),
  159. dict(in_channels=3, num_classes=2, width=64)
  160. ] # yapf: disable
  161. @allow_oom
  162. class TestSTANetModel(TestCDModel):
  163. MODEL_CLASS = paddlers.rs_models.cd.STANet
  164. def set_specs(self):
  165. base_spec = dict(in_channels=3, num_classes=2)
  166. self.specs = [
  167. base_spec,
  168. dict(in_channels=8, num_classes=2),
  169. dict(in_channels=3, num_classes=8),
  170. dict(**base_spec, att_type='PAM'),
  171. dict(**base_spec, ds_factor=4)
  172. ] # yapf: disable
  173. @allow_oom
  174. class TestChangeFormerModel(TestCDModel):
  175. MODEL_CLASS = paddlers.rs_models.cd.ChangeFormer
  176. def set_specs(self):
  177. base_spec = dict(in_channels=3, num_classes=2)
  178. self.specs = [
  179. base_spec,
  180. dict(**base_spec, decoder_softmax=True),
  181. dict(**base_spec, embed_dim=56)
  182. ] # yapf: disable