You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

nn_ConvTranspose2d.cpp 2.6 kB

11 months ago
11 months ago
11 months ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // Copyright 2021 Tencent
  2. // SPDX-License-Identifier: BSD-3-Clause
  3. #include "fuse_module_pass.h"
  4. #include "utils.h"
  5. namespace pnnx {
  6. class ConvTranspose2d : public FuseModulePass
  7. {
  8. public:
  9. const char* match_type_str() const
  10. {
  11. return "__torch__.torch.nn.modules.conv.ConvTranspose2d";
  12. }
  13. const char* type_str() const
  14. {
  15. return "nn.ConvTranspose2d";
  16. }
  17. void write(Operator* op, const TorchGraphProxy& graph, const TorchModuleProxy& mod) const
  18. {
  19. const TorchNodeProxy* convolution = graph.find_node_by_kind("aten::_convolution");
  20. const TorchTensorProxy& weight = mod.hasattr("weight") ? mod.attr("weight") : mod.attr("weight_v");
  21. op->params["groups"] = convolution->namedInput("groups");
  22. op->params["in_channels"] = weight.size(0);
  23. op->params["out_channels"] = weight.size(1) * op->params["groups"].i;
  24. op->params["kernel_size"] = Parameter{weight.size(2), weight.size(3)};
  25. op->params["stride"] = convolution->namedInput("stride");
  26. op->params["padding"] = convolution->namedInput("padding");
  27. op->params["output_padding"] = convolution->namedInput("output_padding");
  28. op->params["dilation"] = convolution->namedInput("dilation");
  29. op->params["bias"] = mod.hasattr("bias");
  30. op->attrs["weight"] = weight;
  31. if (!mod.hasattr("weight"))
  32. {
  33. // weight norm
  34. Attribute weight_g = mod.attr("weight_g");
  35. std::vector<float> weight_data = op->attrs["weight"].get_float32_data();
  36. std::vector<float> weight_g_data = weight_g.get_float32_data();
  37. int inch = op->params.at("in_channels").i;
  38. int outch = op->params.at("out_channels").i * op->params.at("kernel_size").ai[0] * op->params.at("kernel_size").ai[1];
  39. apply_weight_norm(weight_data, weight_g_data, inch, outch);
  40. op->attrs["weight"].set_float32_data(weight_data);
  41. // drop the additional weight input
  42. op->inputs[1]->remove_consumer(op);
  43. op->inputs.resize(1);
  44. }
  45. if (mod.hasattr("bias"))
  46. {
  47. op->attrs["bias"] = mod.attr("bias");
  48. }
  49. if (op->inputs.size() > 1)
  50. {
  51. fprintf(stderr, "ConvTranspose2d arg output_size detected and dropped !\n");
  52. for (size_t i = 1; i < op->inputs.size(); i++)
  53. {
  54. op->inputs[i]->remove_consumer(op);
  55. }
  56. op->inputs.resize(1);
  57. }
  58. }
  59. };
  60. REGISTER_GLOBAL_PNNX_FUSE_MODULE_PASS(ConvTranspose2d)
  61. } // namespace pnnx