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.

external.py 2.2 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. # -*- coding: utf-8 -*-
  2. # MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  3. #
  4. # Copyright (c) 2014-2020 Megvii Inc. All rights reserved.
  5. #
  6. # Unless required by applicable law or agreed to in writing,
  7. # software distributed under the License is distributed on an
  8. # "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. import numpy as np
  10. from ..functional.external import (
  11. atlas_subgraph,
  12. cambricon_subgraph,
  13. extern_opr_subgraph,
  14. )
  15. from .module import Module
  16. class CambriconSubgraph(Module):
  17. r"""Load a serialized Cambricon subgraph.
  18. See :func:`~.cambricon_subgraph` for more details.
  19. """
  20. def __init__(
  21. self, data, symbol, tensor_dim_mutable,
  22. ):
  23. super(CambriconSubgraph, self).__init__()
  24. self._data = data
  25. self.symbol = symbol
  26. self.tensor_dim_mutable = tensor_dim_mutable
  27. @property
  28. def data(self):
  29. return self._data.tobytes()
  30. @data.setter
  31. def data(self, val):
  32. self._data = np.frombuffer(val, dtype=np.uint8)
  33. def forward(self, inputs):
  34. outputs = cambricon_subgraph(
  35. inputs, self._data, self.symbol, self.tensor_dim_mutable,
  36. )
  37. return outputs
  38. class AtlasSubgraph(Module):
  39. r"""Load a serialized Atlas subgraph.
  40. See :func:`~.atlas_subgraph` for more details.
  41. """
  42. def __init__(self, data):
  43. super(AtlasSubgraph, self).__init__()
  44. self._data = data
  45. @property
  46. def data(self):
  47. return self._data.tobytes()
  48. @data.setter
  49. def data(self, val):
  50. self._data = np.frombuffer(val, dtype=np.uint8)
  51. def forward(self, inputs):
  52. outputs = atlas_subgraph(inputs, self._data)
  53. return outputs
  54. class ExternOprSubgraph(Module):
  55. r"""Load a serialized extern opr subgraph.
  56. """
  57. def __init__(self, data, name, output_shapes):
  58. super(ExternOprSubgraph, self).__init__()
  59. self.data = data
  60. self.name = name
  61. self.output_shapes = output_shapes
  62. def forward(self, inputs):
  63. outputs = extern_opr_subgraph(inputs, self.output_shapes, self.name, self.data,)
  64. return outputs

MegEngine 安装包中集成了使用 GPU 运行代码所需的 CUDA 环境,不用区分 CPU 和 GPU 版。 如果想要运行 GPU 程序,请确保机器本身配有 GPU 硬件设备并安装好驱动。 如果你想体验在云端 GPU 算力平台进行深度学习开发的感觉,欢迎访问 MegStudio 平台