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 2.2 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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. """generate json desc for softmax"""
  16. from mindspore._extends.graph_kernel.model import model_builder as builder
  17. def expand_softmax(expand_info):
  18. """Softmax expander"""
  19. # get op info.
  20. input_desc = expand_info['input_desc'][0]
  21. attrs = expand_info['attr']
  22. axis = None
  23. for item in attrs:
  24. if 'axis' in item:
  25. axis = item['axis']
  26. graph_builder = builder.GraphBuilder()
  27. # generate a graph.
  28. with graph_builder.graph_scope('main') as graph_scope:
  29. # create tensor input.
  30. input_x = graph_builder.tensor(input_desc['shape'], input_desc['data_type'], input_desc['format'])
  31. # cal softmax.
  32. if input_x.dtype == 'float32':
  33. input_x_cast = graph_builder.emit('Cast', [input_x], attrs={'dst_type': 'float16'})
  34. max_x = graph_builder.emit('ReduceMax', [input_x_cast], attrs={'reduce_axis': axis, 'keep_dims': True})
  35. max_x = graph_builder.emit('Cast', [max_x], attrs={'dst_type': 'float32'})
  36. else:
  37. max_x = graph_builder.emit('ReduceMax', [input_x], attrs={'reduce_axis': axis, 'keep_dims': True})
  38. data_sub = graph_builder.emit('Sub', [input_x, max_x])
  39. data_exp = graph_builder.emit('Exp', [data_sub])
  40. data_expsum = graph_builder.emit('ReduceSum', [data_exp], attrs={'reduce_axis': axis, 'keep_dims': True})
  41. result = graph_builder.emit('RealDiv', [data_exp, data_expsum])
  42. # set graph output.
  43. graph_scope.set_output(result)
  44. graph = graph_builder.get()[0]
  45. return graph