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.

softmax.py 3.2 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. # Copyright 2020-2021 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. """generate json desc for softmax"""
  16. from mindspore._extends.graph_kernel.model.model import DataFormat as DF
  17. from ._utils import Expander, ExpanderInfoValidator as VLD
  18. from ._utils import infer_shape_from_fractalNz, get_reduced_ori_shape, to_frac_z_axis
  19. @VLD.add_format(DF.FRAC_NZ)
  20. @VLD.add_format(DF.DEFAULT)
  21. @VLD.check_attrs('axis')
  22. class Softmax(Expander):
  23. """Softmax expander"""
  24. def _expand(self, graph_builder):
  25. input_x = self.inputs[0]
  26. processor = self.processor
  27. axis = self.attrs['axis']
  28. ori_shape = input_x.shape
  29. if input_x.data_format == DF.FRAC_NZ:
  30. ori_shape = infer_shape_from_fractalNz(input_x.shape)
  31. for i, _ in enumerate(list(axis)):
  32. if axis[i] < 0:
  33. axis[i] += len(ori_shape)
  34. ori_reduced_shape = get_reduced_ori_shape(ori_shape, axis)
  35. if input_x.data_format == DF.FRAC_NZ:
  36. axis = to_frac_z_axis(ori_shape, axis)
  37. ori_dtype = input_x.dtype
  38. if ori_dtype != "float16" and processor == "aicore":
  39. input_x_f16 = graph_builder.emit('Cast', [input_x], attrs={'dst_type': 'float16'})
  40. max_x_f16 = graph_builder.emit('ReduceMax', [input_x_f16], attrs={'reduce_axis': axis, 'keep_dims': True})
  41. max_x = graph_builder.emit('Cast', [max_x_f16], attrs={'dst_type': ori_dtype})
  42. else:
  43. max_x = graph_builder.emit('ReduceMax', [input_x], attrs={'reduce_axis': axis, 'keep_dims': True})
  44. if ori_dtype == "float16" and processor == "aicore":
  45. max_x = graph_builder.emit('Cast', [max_x], attrs={'dst_type': "float32"})
  46. input_x = graph_builder.emit('Cast', [input_x], attrs={'dst_type': "float32"})
  47. if input_x.data_format == DF.FRAC_NZ:
  48. max_x = graph_builder.emit('Reshape', [max_x], attrs={'shape': ori_reduced_shape})
  49. data_sub = graph_builder.emit('Sub', [input_x, max_x])
  50. data_exp = graph_builder.emit('Exp', [data_sub])
  51. data_expsum = graph_builder.emit('ReduceSum', [data_exp], attrs={'reduce_axis': axis, 'keep_dims': True})
  52. if input_x.data_format == DF.FRAC_NZ:
  53. data_expsum = graph_builder.emit('Reshape', [data_expsum], attrs={'shape': ori_reduced_shape})
  54. result = graph_builder.emit('RealDiv', [data_exp, data_expsum])
  55. if ori_dtype == "float16" and processor == "aicore":
  56. result = graph_builder.emit('Cast', [result], attrs={'dst_type': ori_dtype})
  57. return result