main.cpp 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #include "UVCGrabber/UVCDeviceManager.h"
  2. // #include "RTSPGrabber/InfraredManager.hpp"
  3. #include "MppDecoder/MppManager.h"
  4. #include "AIManager/RKNNManager.h"
  5. #include "LogRecorder/LogOutput.h"
  6. #include "DataManager/DataManager.h"
  7. #include "DataManager/DataPackage.h"
  8. #include "ImageTest/ImageTest.h"
  9. #include <stdexcept>
  10. #include <iostream>
  11. #include <thread>
  12. #include <json.hpp>
  13. #define DEVICE_NUM 3
  14. int main(int argc, char **argv)
  15. {
  16. // set usbfs memory to 64MB
  17. std::system("echo 64 > /sys/module/usbcore/parameters/usbfs_memory_mb");
  18. std::system("rm ./TimeLog.txt");
  19. // use json to read config file
  20. nlohmann::json config;
  21. try
  22. {
  23. std::ifstream config_file("./configure/config.json");
  24. config_file >> config;
  25. config_file.close();
  26. }
  27. catch (std::exception &e)
  28. {
  29. std::cerr << "Error reading config file: " << e.what() << std::endl;
  30. return 1;
  31. }
  32. UsbTest::TimeRecorder::getInstance().init();
  33. UsbTest::GlobalResolutionTimer::getInstance().start();
  34. UsbTest::SimulateTrigger::getInstance().startTrigger();
  35. LogConfiguration LogConfig; // 日志结构体
  36. LogConfig.FromFile("./configure/log.json");
  37. LOG_INIT("UsbDevice", LogConfig);
  38. if (OmniLoger::CLoger::get_instance().log_sink != nullptr)
  39. {
  40. std::cout << "Log initialized successfully" << std::endl;
  41. //OmniLoger::CLoger::get_instance().log_sink->error("Error occurred during initialization");
  42. }
  43. // Initialize the UVC manager
  44. UVCManager::getInstance().init(int(config["usb_grab_waiting_time"]));
  45. UVCManager::getInstance().setDeviceNumber(0, config["usb_device_number"][0]);
  46. UVCManager::getInstance().setDeviceNumber(1, config["usb_device_number"][1]);
  47. UVCManager::getInstance().setDeviceNumber(2, config["usb_device_number"][2]);
  48. MppManager::getInstance().addMppDecode();
  49. RKNNManager::getInstance().setGrpcServerAddress(config["grpc_server_address"]);
  50. RKNNManager::getInstance().addRknnTask(config["rknn_model_path"]);
  51. // Start all streaming
  52. UVCManager::getInstance().startAllStreaming();
  53. OmniLoger::CLoger::get_instance().log_sink->info("All streaming started successfully");
  54. // Wait for the user to press a key
  55. while(true){
  56. std::this_thread::sleep_for(std::chrono::seconds(1));
  57. }
  58. // std::cin.get();
  59. std::cout << "Stopping all streaming..." << std::endl;
  60. RKNNManager::getInstance().StopProcessData();
  61. // Stop all streaming
  62. UVCManager::getInstance().stopAllStreaming();
  63. return 0;
  64. }