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.

logsoftmax.py 2.1 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  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 LogSoftmax"""
  16. from mindspore._extends.graph_kernel.model.model import DataFormat as DF
  17. from ._utils import Expander, ExpanderInfoValidator as VLD
  18. @VLD.add_format(DF.DEFAULT)
  19. @VLD.check_attrs('axis')
  20. class LogSoftmax(Expander):
  21. """LogSoftmax expander"""
  22. def _expand(self, graph_builder):
  23. input_x = self.inputs[0]
  24. axis = self.attrs['axis']
  25. processor = self.processor
  26. if isinstance(axis, int):
  27. axis = (axis,)
  28. ori_dtype = input_x.dtype
  29. if ori_dtype != "float16" and processor == "aicore":
  30. input_x_f16 = graph_builder.emit('Cast', [input_x], attrs={'dst_type': 'float16'})
  31. max_x_f16 = graph_builder.emit('ReduceMax', [input_x_f16], attrs={'reduce_axis': axis, 'keep_dims': True})
  32. max_x = graph_builder.emit('Cast', [max_x_f16], attrs={'dst_type': ori_dtype})
  33. else:
  34. max_x = graph_builder.emit('ReduceMax', [input_x], attrs={'reduce_axis': axis, 'keep_dims': True})
  35. data_sub = graph_builder.emit('Sub', [input_x, max_x])
  36. data_exp = graph_builder.emit('Exp', [data_sub])
  37. data_expsum = graph_builder.emit('ReduceSum', [data_exp], attrs={'reduce_axis': axis, 'keep_dims': True})
  38. log_expsum = graph_builder.emit('Log', [data_expsum])
  39. result = graph_builder.emit('Sub', [data_sub, log_expsum])
  40. return result