/** * 车号属性第一步推理前预处理 * */ #ifndef TRAINSTEPONEENGINE_H #define TRAINSTEPONEENGINE_H #include "AppCommon.h" #include "EngineBase.h" #include "EngineFactory.h" #include "yolov5_clearity_inference.h" class TrainStep1InferenceEngine : public ai_matrix::EngineBase { public: TrainStep1InferenceEngine(); ~TrainStep1InferenceEngine(); APP_ERROR Init() override; APP_ERROR DeInit() override; APP_ERROR Process() override; private: //初始化识别模型 APP_ERROR initModel(); //过滤无效信息 void filterInvalidInfo(std::vector &vecInferenceResult, std::shared_ptr &pVTrainStep1Data); void getMaxScoreResult(std::vector &vecInferenceResult); void getTargetType(SingleData &singleData); std::string strPort_; std::string strPort0_; ai_matrix::ModelConfig modelConfig_; ai_matrix::DataSourceConfig dataSourceConfig_; ai_matrix::IdentifyConfig identifyConfig_; YoloV5ClearityInference yolov5model; const char* INPUT_BLOB_NAME = "images"; //输入层名称 const char* OUTPUT_BLOB_NAME = "output"; //输出层名称 unsigned int img_width = IMAGE_WIDTH; unsigned int img_height = IMAGE_HEIGHT; unsigned int model_width = STEP1_INPUT_W; unsigned int model_height = STEP1_INPUT_H; unsigned int clear_num = STEP1_CLEAR_NUM; unsigned int class_num = STEP1_CLASS_NUM; unsigned int input_size = STEP1_INPUT_SIZE; unsigned int output_size = STEP1_OUTPUT_SIZE; unsigned int det_size = STEP1_CLASS_NUM + STEP1_CLEAR_NUM + 5; unsigned int batch_size = STEP1_BATCH_SIZE; float score_threshold = STEP1_SCORE_THRESH; float nms_threshold = STEP1_NMS_THRESH; YoloV5ClearityModelInfo modelinfo; // std::map mapDataSourceCfg_; //[key-数据源id, value-数据源参数配置信息] // std::map mapSameSideFlatcarSid_; //[key-数据源id, value-同侧识别平车数据源id] }; ENGINE_REGIST(TrainStep1InferenceEngine) #endif