#pragma once #define RET_OK nullptr #ifdef _WIN32 #include #include #include #endif #include #include #include #include #include "onnxruntime_cxx_api.h" #ifdef USE_CUDA #include #endif enum MODEL_TYPE { //FLOAT32 MODEL YOLO_ORIGIN_V5 = 0, YOLO_ORIGIN_V8 = 1,//only support v8 detector currently YOLO_POSE_V8 = 2, YOLO_CLS_V8 = 3, YOLO_ORIGIN_V8_HALF = 4, YOLO_POSE_V8_HALF = 5, YOLO_CLS_V8_HALF = 6 }; typedef struct _DCSP_INIT_PARAM { std::string ModelPath; MODEL_TYPE ModelType = YOLO_ORIGIN_V8; std::vector imgSize = {640, 640}; float RectConfidenceThreshold = 0.6; float iouThreshold = 0.5; bool CudaEnable = false; int LogSeverityLevel = 3; int IntraOpNumThreads = 1; } DCSP_INIT_PARAM; typedef struct _DCSP_RESULT { int classId; float confidence; cv::Rect box; } DCSP_RESULT; class DCSP_CORE { public: DCSP_CORE(); ~DCSP_CORE(); public: char *CreateSession(DCSP_INIT_PARAM &iParams); char *RunSession(cv::Mat &iImg, std::vector &oResult); char *WarmUpSession(); template char *TensorProcess(clock_t &starttime_1, cv::Mat &iImg, N &blob, std::vector &inputNodeDims, std::vector &oResult); char* PreProcess(cv::Mat& iImg, std::vector iImgSize, cv::Mat& oImg); std::vector classes{}; private: Ort::Env env; Ort::Session *session; bool cudaEnable; Ort::RunOptions options; std::vector inputNodeNames; std::vector outputNodeNames; MODEL_TYPE modelType; std::vector imgSize; float rectConfidenceThreshold; float iouThreshold; float resizeScales;//letterbox scale };