model_helper_test.py 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. """unittest for ModelHelper class"""
  2. import unittest
  3. from caffe2.python import brew, model_helper
  4. class ModelHelperTest(unittest.TestCase):
  5. def test_get_complete_net_type(self):
  6. model = model_helper.ModelHelper("test_orig")
  7. brew.conv(
  8. model,
  9. "input",
  10. "conv",
  11. dim_in=3,
  12. dim_out=16,
  13. weight_init=("MSRAFill", {}),
  14. kernel=3,
  15. stride=1,
  16. pad=0,
  17. )
  18. model.net.Proto().type = "async_scheduling"
  19. net = model.GetCompleteNet()
  20. model2 = model_helper.ModelHelper("test_new")
  21. model2.ConstructInitTrainNetfromNet(net)
  22. self.assertTrue(model2.net.Proto().type, "async_scheduling")
  23. self.assertTrue(model2.param_init_net.Proto().type, "async_scheduling")
  24. def test_get_complete_net(self):
  25. model = model_helper.ModelHelper("test_orig")
  26. conv = brew.conv(
  27. model,
  28. "input",
  29. "conv",
  30. dim_in=3,
  31. dim_out=16,
  32. weight_init=("MSRAFill", {}),
  33. kernel=3,
  34. stride=1,
  35. pad=0,
  36. )
  37. conv = brew.spatial_bn(model, conv, "conv_bn", 16, epsilon=1e-3, is_test=False)
  38. conv = brew.relu(model, conv, "conv_relu")
  39. pred = brew.fc(model, conv, "pred", dim_in=16 * 3 * 3, dim_out=10)
  40. brew.softmax(model, pred, "softmax")
  41. net = model.GetCompleteNet()
  42. model2 = model_helper.ModelHelper("test_new")
  43. model2.ConstructInitTrainNetfromNet(net)
  44. net = model.param_init_net
  45. net2 = model2.param_init_net
  46. for op1, op2 in zip(net.Proto().op, net2.Proto().op):
  47. op1.debug_info = op1.debug_info + "/param_init_net"
  48. self.assertEqual(
  49. op1, op2, "op mismatch between {}\n and {}\n".format(op1, op2)
  50. )
  51. net = model.net
  52. net2 = model2.net
  53. for op1, op2 in zip(net.Proto().op, net2.Proto().op):
  54. self.assertEqual(
  55. op1, op2, "op mismatch between {}\n and {}\n".format(op1, op2)
  56. )
  57. # this is not guaranteed in other situations where user define own net
  58. self.assertEqual(
  59. sorted(map(str, net.external_inputs)),
  60. sorted(map(str, net2.external_inputs)),
  61. )