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.

io_remote.cpp 2.4 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /**
  2. * \file imperative/src/test/io_remote.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 "./helper.h"
  12. #include "megbrain/imperative/ops/io_remote.h"
  13. #include "megbrain/opr/mm_handler.h"
  14. using namespace mgb;
  15. using namespace imperative;
  16. TEST(TestImperative, IORemote) {
  17. REQUIRE_GPU(2);
  18. const char* server_addr = "127.0.0.1";
  19. uint32_t port = 4567;
  20. mgb_assert(create_zmqrpc_server(server_addr, port) > 0);
  21. HostTensorGenerator<> gen;
  22. CompNode cn0 = CompNode::load("gpu0"), cn1 = CompNode::load("gpu1");
  23. size_t vector_size = 233;
  24. auto host_x = gen({vector_size}, cn0), host_y = gen({vector_size}, cn1);
  25. auto expect = gen({vector_size});
  26. for (size_t i = 0; i < vector_size; ++i) {
  27. expect->ptr<float>()[i] = host_x->ptr<float>()[i];
  28. }
  29. auto run_send = [&](std::shared_ptr<HostTensorND> hnd) {
  30. imperative::RemoteSend def{"io_remote_test", server_addr, port, 1};
  31. auto inp = Tensor::make(*hnd);
  32. auto oup = OpDef::apply_on_physical_tensor(def, {inp});
  33. };
  34. auto run_recv = [&](std::shared_ptr<HostTensorND> hnd) {
  35. // auto&& shape = std::initializer_list{vector_size};
  36. imperative::RemoteRecv def{"io_remote_test",
  37. server_addr,
  38. port,
  39. 0,
  40. {
  41. vector_size,
  42. },
  43. CompNode::load("gpu1"),
  44. dtype::Float32()};
  45. auto inp = Tensor::make(*hnd);
  46. auto oup = OpDef::apply_on_physical_tensor(def, {inp});
  47. HostTensorND host_v;
  48. host_v.copy_from(oup[0]->dev_tensor()).sync();
  49. MGB_ASSERT_TENSOR_NEAR(*expect, host_v, 1e-6);
  50. };
  51. std::thread t0(std::bind(run_send, host_x));
  52. std::thread t1(std::bind(run_recv, host_y));
  53. t0.join();
  54. t1.join();
  55. }
  56. // vim: syntax=cpp.doxygen foldmethod=marker foldmarker=f{{{,f}}}
  57. // ./imperative_test --gtest_filter TestIORemote

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