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.

matmul.py 2.3 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. # Copyright 2020 Huawei Technologies Co., Ltd
  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. # ============================================================================
  15. """MatMul op"""
  16. from mindspore.ops.op_info_register import op_info_register, TBERegOp, DataType
  17. matmul_op_info = TBERegOp("MatMul") \
  18. .fusion_type("OPAQUE") \
  19. .async_flag(False) \
  20. .binfile_name("mat_mul.so") \
  21. .compute_cost(10) \
  22. .kernel_name("mat_mul") \
  23. .partial_flag(True) \
  24. .attr("transpose_x1", "required", "bool", "all") \
  25. .attr("transpose_x2", "required", "bool", "all") \
  26. .attr("offset_x", "optional", "int", "all") \
  27. .input(0, "x1", False, "required", "all") \
  28. .input(1, "x2", False, "required", "all") \
  29. .input(2, "bias", False, "optional", "all") \
  30. .input(3, "offset_w", False, "optional", "all") \
  31. .output(0, "y", False, "required", "all") \
  32. .dtype_format(DataType.I32_Default, DataType.I32_Default, DataType.I32_Default, DataType.I8_Default,
  33. DataType.I32_Default) \
  34. .dtype_format(DataType.F16_FracNZ, DataType.F16_FracNZ, DataType.F16_Default, DataType.I8_Default,
  35. DataType.F16_FracNZ) \
  36. .dtype_format(DataType.F16_FracNZ, DataType.F16_FracNZ, DataType.F32_Default, DataType.I8_Default,
  37. DataType.F32_FracNZ) \
  38. .dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.I8_Default,
  39. DataType.F32_NHWC) \
  40. .dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.I8_Default,
  41. DataType.F32_Default) \
  42. .dtype_format(DataType.I32_NHWC, DataType.I32_NHWC, DataType.I32_NHWC, DataType.I8_Default,
  43. DataType.I32_NHWC) \
  44. .get_op_info()
  45. @op_info_register(matmul_op_info)
  46. def _matmul_tbe():
  47. """Mul TBE register"""
  48. return