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.

mock_client.h 2.0 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /**
  2. * \file src/opr-mm/test/mock_client.cpp
  3. * MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  4. *
  5. * Copyright (c) 2014-2020 Megvii Inc. All rights reserved.
  6. *
  7. * Unless required by applicable law or agreed to in writing,
  8. * software distributed under the License is distributed on an
  9. * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. */
  11. #include "megbrain/opr/group_manager.h"
  12. namespace mgb {
  13. namespace test {
  14. class MockGroupClient final : public opr::GroupClient {
  15. public:
  16. using RegisterInfo = opr::GroupManager::RegisterInfo;
  17. MockGroupClient(const std::string& server_addr = "mock_addr") :
  18. m_addr(server_addr) {
  19. }
  20. ~MockGroupClient() override = default;
  21. const std::string& get_addr() const {
  22. return m_addr;
  23. }
  24. RegisterInfo opr_register(const std::string& key, size_t nr_devices,
  25. bool is_root, int rank, uint64_t comp_node_hash) override {
  26. return m_mgr.opr_register(key, nr_devices, is_root, rank, comp_node_hash);
  27. }
  28. void bcast_addr(std::string& master_ip, int& port,
  29. const std::string& key, uint32_t size,
  30. uint32_t rank, uint32_t root) override {
  31. return m_mgr.bcast_addr(master_ip, port, key, size, rank, root);
  32. }
  33. void set_output_shape(const std::string& key,
  34. const TensorShape& shape) override {
  35. m_mgr.set_output_shape(key, shape);
  36. }
  37. TensorShape get_output_shape(const std::string& key) override {
  38. return m_mgr.get_output_shape(key);
  39. }
  40. uint32_t group_barrier(uint32_t size, uint32_t rank) override {
  41. return m_mgr.group_barrier(size, rank);
  42. }
  43. private:
  44. const std::string m_addr;
  45. opr::GroupManager m_mgr;
  46. };
  47. } // namespace test
  48. } // namespace mgb
  49. // vim: syntax=cpp.doxygen foldmethod=marker foldmarker=f{{{,f}}}

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