ndi.cpp 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #define BOOST_TEST_DYN_LINK
  2. #define BOOST_TEST_MAIN // in only one cpp file
  3. #include "tracker/ndi/ndi_interface.h"
  4. #include "utility/debug_utility.hpp"
  5. #include "utility/global_obj_helper.hpp"
  6. #include "core/basic_obj_types.hpp"
  7. #include <boost/asio/co_spawn.hpp>
  8. #include <boost/asio/detached.hpp>
  9. #include <boost/asio/this_coro.hpp>
  10. #include <boost/asio/use_awaitable.hpp>
  11. #include <boost/test/unit_test.hpp>
  12. #include <chrono>
  13. #include <iostream>
  14. #include <vector>
  15. using boost::asio::awaitable;
  16. using boost::asio::co_spawn;
  17. using boost::asio::detached;
  18. using boost::asio::use_awaitable;
  19. using namespace sophiar;
  20. using namespace std::chrono_literals;
  21. awaitable<void> coro_ndi_test() {
  22. auto interface = std::make_unique<ndi_interface>();
  23. auto init_config = nlohmann::json::parse(
  24. R"({"address_type":"ethernet","ip":"169.254.132.51","tcp_port":8765,"com_port":"COM3","tool_list":[{"rom_path":"D:\\Program\\Robot\\Tools\\roms\\Probe_Small_4Ball.rom","outputs":{"transform":"tracker_probe_transform","marker_uncertainty":"tracker_probe_transform_uncertainty"}},{"rom_path":"D:\\Program\\Robot\\Tools\\roms\\Head_3Ball_2.rom","outputs":{"transform":"tracker_model_ref_transform","marker_uncertainty":"tracker_model_ref_transform_uncertainty"}}]})");
  25. auto start_config = nlohmann::json::parse(
  26. R"({"allow_unreliable":true,"prefer_stream_tracking":true})");
  27. BOOST_TEST(co_await interface->init(init_config));
  28. BOOST_TEST(co_await interface->start(start_config));
  29. auto trans_obj = global_obj_auto_sync_delegate<transform_obj>(
  30. global_sophiar_manager,
  31. "tracker_probe_transform");
  32. int cnt = 0;
  33. FILE_LINE_TRACE
  34. for (;;) {
  35. co_await trans_obj.coro_wait_update();
  36. // if (!trans_obj.empty()) {
  37. // std::cout << trans_obj->value.matrix() << std::endl;
  38. // } else {
  39. // std::cout << "empty" << std::endl;
  40. // }
  41. if (++cnt == 250) break;
  42. }
  43. FILE_LINE_TRACE
  44. co_await interface->reset();
  45. start_config = nlohmann::json::parse(
  46. R"({"allow_unreliable":true,"prefer_stream_tracking":false})");
  47. BOOST_TEST(co_await interface->init(init_config));
  48. BOOST_TEST(co_await interface->start(start_config));
  49. cnt = 0;
  50. FILE_LINE_TRACE
  51. for (;;) {
  52. co_await trans_obj.coro_wait_update();
  53. if (++cnt == 60) break;
  54. }
  55. FILE_LINE_TRACE
  56. co_await interface->reset();
  57. co_return;
  58. }
  59. BOOST_AUTO_TEST_CASE(test_ndi) {
  60. co_spawn(global_context, coro_ndi_test(), detached);
  61. global_context.run();
  62. }