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.

tqt.cpp 2.6 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /**
  2. * \file src/opr/impl/dnn/tqt.cpp
  3. * MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  4. *
  5. * Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
  6. *
  7. * Unless required by applicable law or agreed to in writing,
  8. * software distributed under the License is distributed on an
  9. * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or
  10. * implied.
  11. */
  12. #include "megbrain/opr/dnn/tqt.h"
  13. #include "../internal/megdnn_opr_wrapper.inl"
  14. #include "megbrain/graph/grad_impl.h"
  15. #include "megbrain/opr/basic_arith_wrapper.h"
  16. #include "megbrain/opr/internal/out_shape_by_sym_var.h"
  17. #include "megbrain/opr/tensor_manip.h"
  18. #include "megbrain/opr/utility.h"
  19. using namespace mgb;
  20. using namespace opr;
  21. MGB_DYN_TYPE_OBJ_FINAL_IMPL(TQTForward);
  22. MEGDNN_OPR_INIT2(TQTForward, "tqt_fwd");
  23. #ifdef MGB_ENABLE_GRAD
  24. MGB_IMPL_OPR_GRAD(TQTForward) {
  25. SymbolVarArray grad =
  26. TQTBackward::make(out_grad[0], opr.input(0), opr.input(1), opr.param());
  27. if (wrt_idx == 0) {
  28. return grad[0].node();
  29. } else if (wrt_idx == 1) {
  30. return reduce_sum(grad[1], GetVarShape::make(opr.input(wrt_idx))).node();
  31. } else {
  32. return nullptr;
  33. }
  34. }
  35. #endif
  36. MGB_DYN_TYPE_OBJ_FINAL_IMPL(TQTBackward);
  37. TQTBackward::TQTBackward(
  38. VarNode* y_grad, VarNode* x, VarNode* scale, const Param& param,
  39. const OperatorNodeConfig& config)
  40. : Super({x->owner_graph(), config, "tqt_bwd", {y_grad, x, scale}}, 1, true) {
  41. init_megdnn_opr(*this, param);
  42. add_input({y_grad, x, scale});
  43. }
  44. SymbolVarArray TQTBackward::make(
  45. SymbolVar y_grad, SymbolVar x, SymbolVar scale, const Param& param,
  46. const OperatorNodeConfig& config) {
  47. auto&& out = x.node()->owner_graph()
  48. ->insert_opr(std::make_unique<TQTBackward>(
  49. y_grad.node(), x.node(), scale.node(), param, config))
  50. ->output();
  51. SymbolVarArray ret(out.size());
  52. for (size_t i = 0; i < ret.size(); ++i) {
  53. ret[i] = out[i];
  54. }
  55. return ret;
  56. }
  57. void TQTBackward::init_output_static_infer_desc() {
  58. using namespace cg::static_infer;
  59. auto&& mgr = owner_graph()->static_infer_manager();
  60. mgr.register_shape_infer(output(0), ShapeInferDesc::make_identity(input(1)));
  61. mgr.register_shape_infer(output(1), ShapeInferDesc::make_identity(input(1)));
  62. this->init_output_static_infer_desc_workspace(
  63. intl::AutoAddWorkspaceNeedLimitGetter<megdnn::TQTBackward>::val);
  64. }
  65. void TQTBackward::init_output_dtype() {
  66. output(0)->dtype(input(1)->dtype());
  67. output(1)->dtype(input(2)->dtype());
  68. }