123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- #include "UVCGrabber/UVCDeviceManager.h"
- // #include "RTSPGrabber/InfraredManager.hpp"
- #include "MppDecoder/MppManager.h"
- #include "AIManager/RKNNManager.h"
- #include "LogRecorder/LogOutput.h"
- #include "DataManager/DataManager.h"
- #include "DataManager/DataPackage.h"
- #include "ImageTest/ImageTest.h"
- #include <stdexcept>
- #include <iostream>
- #include <json.hpp>
- #define DEVICE_NUM 3
- int main(int argc, char **argv)
- {
- // set usbfs memory to 64MB
- std::system("echo 64 > /sys/module/usbcore/parameters/usbfs_memory_mb");
- std::system("rm ./TimeLog.txt");
- // use json to read config file
- nlohmann::json config;
- try
- {
- std::ifstream config_file("./configure/config.json");
- config_file >> config;
- config_file.close();
- }
- catch (std::exception &e)
- {
- std::cerr << "Error reading config file: " << e.what() << std::endl;
- return 1;
- }
- UsbTest::TimeRecorder::getInstance().init();
- UsbTest::GlobalResolutionTimer::getInstance().start();
- UsbTest::SimulateTrigger::getInstance().startTrigger();
- LogConfiguration LogConfig; // 日志结构体
- LogConfig.FromFile("./configure/log.json");
- LOG_INIT("UsbDevice", LogConfig);
- if (OmniLoger::CLoger::get_instance().log_sink != nullptr)
- {
- std::cout << "Log initialized successfully" << std::endl;
- OmniLoger::CLoger::get_instance().log_sink->error("Error occurred during initialization");
- }
- // Initialize the UVC manager
- UVCManager::getInstance().init();
- MppManager::getInstance().addMppDecode();
- RKNNManager::getInstance().setGrpcServerAddress(config["grpc_server_address"]);
- RKNNManager::getInstance().addRknnTask(config["rknn_model_path"]);
- // Start all streaming
- UVCManager::getInstance().startAllStreaming();
- // Wait for the user to press a key
- std::cin.get();
- RKNNManager::getInstance().StopProcessData();
- // Stop all streaming
- UVCManager::getInstance().stopAllStreaming();
- return 0;
- }
|