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.

helper.py 1.2 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  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 functools
  10. import multiprocessing as mp
  11. from typing import Callable
  12. from megengine.device import get_device_count
  13. from .group import group_barrier, is_distributed
  14. def synchronized(func: Callable):
  15. """Decorator. Decorated function will synchronize when finished.
  16. Specifically, we use this to prevent data race during hub.load"""
  17. @functools.wraps(func)
  18. def wrapper(*args, **kwargs):
  19. if not is_distributed():
  20. return func(*args, **kwargs)
  21. ret = func(*args, **kwargs)
  22. group_barrier()
  23. return ret
  24. return wrapper
  25. def get_device_count_by_fork(device_type: str):
  26. q = mp.Queue()
  27. def worker(queue):
  28. num = get_device_count(device_type)
  29. queue.put(num)
  30. p = mp.Process(target=worker, args=(q,))
  31. p.start()
  32. p.join()
  33. return q.get()

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