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.

base.py 4.9 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. # -*- coding: utf-8 -*-
  2. # This file is part of MegEngine, a deep learning framework developed by
  3. # Megvii.
  4. #
  5. # Copyright (c) Copyright (c) 2020-2021 Megvii Inc. All rights reserved.
  6. import ctypes
  7. import glob
  8. import logging
  9. import os
  10. import sys
  11. from ctypes import *
  12. if sys.platform == "win32":
  13. lib_path = os.path.join(os.path.dirname(__file__), "libs")
  14. dll_paths = list(filter(os.path.exists, [lib_path,]))
  15. assert len(dll_paths) > 0
  16. kernel32 = ctypes.WinDLL("kernel32.dll", use_last_error=True)
  17. has_load_library_attr = hasattr(kernel32, "AddDllDirectory")
  18. old_error_mode = kernel32.SetErrorMode(0x0001)
  19. kernel32.LoadLibraryW.restype = ctypes.c_void_p
  20. if has_load_library_attr:
  21. kernel32.AddDllDirectory.restype = ctypes.c_void_p
  22. kernel32.LoadLibraryExW.restype = ctypes.c_void_p
  23. for dll_path in dll_paths:
  24. if sys.version_info >= (3, 8):
  25. os.add_dll_directory(dll_path)
  26. elif has_load_library_attr:
  27. res = kernel32.AddDllDirectory(dll_path)
  28. if res is None:
  29. err = ctypes.WinError(ctypes.get_last_error())
  30. err.strerror += ' Error adding "{}" to the DLL search PATH.'.format(
  31. dll_path
  32. )
  33. raise err
  34. else:
  35. print("WARN: python or OS env have some issue, may load DLL failed!!!")
  36. import glob
  37. dlls = glob.glob(os.path.join(lib_path, "*.dll"))
  38. path_patched = False
  39. for dll in dlls:
  40. is_loaded = False
  41. if has_load_library_attr:
  42. res = kernel32.LoadLibraryExW(dll, None, 0x00001100)
  43. last_error = ctypes.get_last_error()
  44. if res is None and last_error != 126:
  45. err = ctypes.WinError(last_error)
  46. err.strerror += ' Error loading "{}" or one of its dependencies.'.format(
  47. dll
  48. )
  49. raise err
  50. elif res is not None:
  51. is_loaded = True
  52. if not is_loaded:
  53. if not path_patched:
  54. os.environ["PATH"] = ";".join(dll_paths + [os.environ["PATH"]])
  55. path_patched = True
  56. res = kernel32.LoadLibraryW(dll)
  57. if res is None:
  58. err = ctypes.WinError(ctypes.get_last_error())
  59. err.strerror += ' Error loading "{}" or one of its dependencies.'.format(
  60. dll
  61. )
  62. raise err
  63. kernel32.SetErrorMode(old_error_mode)
  64. class _LiteCLib:
  65. def __init__(self):
  66. cwd = os.getcwd()
  67. package_dir = os.path.dirname(os.path.realpath(__file__))
  68. debug_path = os.getenv("LITE_LIB_PATH")
  69. os.chdir(package_dir)
  70. lite_libs = glob.glob("libs/liblite*")
  71. os.chdir(cwd)
  72. if debug_path is None:
  73. assert len(lite_libs) == 1
  74. self._lib = CDLL(os.path.join(package_dir, lite_libs[0]))
  75. else:
  76. self._lib = CDLL(debug_path)
  77. self._register_api(
  78. "LITE_get_version", [POINTER(c_int), POINTER(c_int), POINTER(c_int)]
  79. )
  80. self.lib.LITE_get_version.restype = None
  81. self._register_api("LITE_set_log_level", [c_int])
  82. self._register_api("LITE_get_log_level", [])
  83. self._register_api("LITE_get_last_error", [], False)
  84. self.lib.LITE_get_last_error.restype = c_char_p
  85. def _errcheck(self, result, func, args):
  86. if result:
  87. error = self.lib.LITE_get_last_error()
  88. msg = error.decode("utf-8")
  89. logging.error("{}".format(msg))
  90. raise RuntimeError("{}".format(msg))
  91. return result
  92. def _register_api(self, api_name, arg_types, error_check=True):
  93. func = getattr(self.lib, api_name)
  94. func.argtypes = arg_types
  95. func.restype = c_int
  96. if error_check:
  97. func.errcheck = self._errcheck
  98. @property
  99. def lib(self):
  100. return self._lib
  101. @property
  102. def version(self):
  103. major = c_int()
  104. minor = c_int()
  105. patch = c_int()
  106. self.lib.LITE_get_version(byref(major), byref(minor), byref(patch))
  107. return "{}.{}.{}".format(major.value, minor.value, patch.value)
  108. def set_log_level(self, level):
  109. self.lib.LITE_set_log_level(level)
  110. def get_log_level(self):
  111. return self.lib.LITE_get_log_level()
  112. _lib = _LiteCLib()
  113. version = _lib.version
  114. set_log_level = _lib.set_log_level
  115. get_log_level = _lib.get_log_level
  116. _Cnetwork = c_void_p
  117. _Ctensor = c_void_p
  118. class _LiteCObjMetaClass(type):
  119. """metaclass for lite object"""
  120. def __new__(cls, name, bases, attrs):
  121. for api in attrs["_api_"]:
  122. _lib._register_api(*api)
  123. del attrs["_api_"]
  124. attrs["_lib"] = _lib.lib
  125. return super().__new__(cls, name, bases, attrs)
  126. class _LiteCObjBase(metaclass=_LiteCObjMetaClass):
  127. _api_ = []

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