generated from zhangwei/Matrixai
188 lines
5.2 KiB
C++
188 lines
5.2 KiB
C++
#ifndef APP_COMMON_H
|
|
#define APP_COMMON_H
|
|
|
|
#include <algorithm>
|
|
#include <assert.h>
|
|
#include <chrono>
|
|
#include <cmath>
|
|
#include <ctime>
|
|
#include <deque>
|
|
#include <fstream>
|
|
#include <functional>
|
|
#include <iostream>
|
|
#include <math.h>
|
|
#include <memory>
|
|
#include <numeric>
|
|
#include <regex>
|
|
#include <sstream>
|
|
#include <stdarg.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <sys/stat.h>
|
|
#include <sys/time.h>
|
|
#include <sys/types.h>
|
|
#include <unistd.h>
|
|
#include <vector>
|
|
|
|
#include <NvInfer.h>
|
|
#include <NvInferPlugin.h>
|
|
#include <NvOnnxParser.h>
|
|
#include <NvCaffeParser.h>
|
|
|
|
#include <cuda.h>
|
|
#include <cuda_runtime.h>
|
|
#include <cuda_runtime_api.h>
|
|
|
|
#include <opencv2/opencv.hpp>
|
|
#include <opencv2/core/core.hpp>
|
|
#include <opencv2/highgui/highgui.hpp>
|
|
#include <opencv2/imgproc/imgproc.hpp>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
#include <libavutil/opt.h>
|
|
#include <libavcodec/avcodec.h>
|
|
#include <libavutil/channel_layout.h>
|
|
#include <libavutil/common.h>
|
|
#include <libavutil/imgutils.h>
|
|
#include <libavutil/samplefmt.h>
|
|
#include <libavformat/avformat.h>
|
|
#include <libavdevice/avdevice.h>
|
|
#include <libavfilter/buffersink.h>
|
|
#include <libavfilter/buffersrc.h>
|
|
#include <libswscale/swscale.h>
|
|
#ifdef __cplusplus
|
|
};
|
|
#endif
|
|
|
|
#include "Utils.h"
|
|
#include "TimeUtil.h"
|
|
#include "StringUtil.h"
|
|
#include "FileUtil.h"
|
|
#include "Config.h"
|
|
#include "Log.h"
|
|
//#include "httplib.h"
|
|
#include "nvidia_acl_datatype.h"
|
|
#include "CommonDataType.h"
|
|
|
|
#include "cuda_utils.h"
|
|
#include "logging.h"
|
|
#include "yolov5_common.h"
|
|
#include "utils.h"
|
|
#include "calibrator.h"
|
|
#include "preprocess.h"
|
|
#include "yololayer.h"
|
|
|
|
#include "CommonEnum.h"
|
|
#include "CommonStruct.h"
|
|
|
|
|
|
using namespace Yolo;
|
|
|
|
|
|
using namespace std;
|
|
using namespace cv;
|
|
using namespace nvinfer1;
|
|
using namespace nvcaffeparser1;
|
|
|
|
#define IMAGE_WIDTH 1920 //1920 2560
|
|
#define IMAGE_HEIGHT 1080 //1080 1440
|
|
|
|
#define USE_FP16 // set USE_INT8 or USE_FP16 or USE_FP32
|
|
#define DEVICE 0 // GPU id
|
|
#define BATCH_SIZE 1 //batch size
|
|
#define MAX_WORKSPAXE_SIZE (16 * (1 << 20)) //工作空间大小
|
|
#define MAX_IMAGE_INPUT_SIZE_THRESH 3000*3000
|
|
#define INPUT_CHANNEL 3 //输入通道数
|
|
|
|
//NVIDIA NX YOLOV5模型推理相关宏(因不与ASCEND冲突放到这)
|
|
#define NMS_THRESH 0.4
|
|
#define CONF_THRESH 0.5
|
|
|
|
|
|
#define GET_INPUT_SIZE(w, h) (INPUT_CHANNEL * w *h)
|
|
#define GET_OUTPUT_SIZE(w, h, cr , ca) (INPUT_CHANNEL * (((h / 32) * ( h / 32)) + ((h / 16) * ( h / 16)) + ((h / 8) * ( h / 8))) * (STEP1_POS_CONF + cr + ca))
|
|
|
|
//STEP0
|
|
#define STEP0_MAX_IMAGE_INPUT_SIZE_THRESH 3000*3000
|
|
|
|
#define STEP0_BATCH_SIZE 1 //batch size
|
|
#define STEP0_NMS_THRESH 0.5 //step1 非极大值抑制阈值
|
|
#define STEP0_SCORE_THRESH 0.4 //step1 置信度(得分)阈值
|
|
#define STEP0_INPUT_CHANNEL 3 //输入通道数
|
|
|
|
#define STEP0_INPUT_H 640 //step0 输入图像高
|
|
#define STEP0_INPUT_W 640 //step0 输入图像宽
|
|
|
|
//STEP1
|
|
#define STEP1_POS_CONF 5
|
|
|
|
#define STEP1_NMS_THRESH 0.3 //step1 非极大值抑制阈值
|
|
#define STEP1_SCORE_THRESH 0.7 //step1 置信度(得分)阈值
|
|
|
|
#define STEP1_CLASS_NUM 19 //step1 7分类
|
|
#define STEP1_CLEAR_NUM 21 //step1 21个清晰度
|
|
|
|
#define STEP1_INPUT_H 960 //step1 输入图像高
|
|
#define STEP1_INPUT_W 960 //step1 输入图像宽
|
|
#define STEP1_BATCH_SIZE 1
|
|
#define STEP1_OUTPUT_HISTOGRAM_N 5 //不能超过139167
|
|
|
|
#define STEP1_BBOX_SIZE1 (STEP1_INPUT_H/32)
|
|
#define STEP1_BBOX_SIZE2 (STEP1_INPUT_H/16)
|
|
#define STEP1_BBOX_SIZE3 (STEP1_INPUT_H/8)
|
|
|
|
#define STEP1_INPUT_SIZE INPUT_CHANNEL*STEP1_INPUT_H*STEP1_INPUT_W //input
|
|
#define STEP1_OUTPUT_SIZE INPUT_CHANNEL*(STEP1_BBOX_SIZE1*STEP1_BBOX_SIZE1+STEP1_BBOX_SIZE2*STEP1_BBOX_SIZE2+STEP1_BBOX_SIZE3*STEP1_BBOX_SIZE3)*(STEP1_CLEAR_NUM+STEP1_CLASS_NUM+STEP1_POS_CONF) //output
|
|
|
|
//STEP1
|
|
#define STEP1_CLASS_NUM_DATE 8
|
|
#define STEP1_CLASS_NUM_CON 7
|
|
|
|
//STEP2
|
|
#define STEP2_POS_CONF 5
|
|
|
|
#define STEP2_NMS_THRESH 0.3 //step2 非极大值抑制阈值
|
|
#define STEP2_SCORE_THRESH 0.7 //step2 置信度(得分)阈值
|
|
|
|
#define STEP2_CLASS_NUM 47 //step2 31分类
|
|
#define STEP2_CLEAR_NUM 5 //step2 5个清晰度
|
|
|
|
#define STEP2_INPUT_H 608 //step2 输入图像高
|
|
#define STEP2_INPUT_W 608 //step2 输入图像宽
|
|
#define STEP2_BATCH_SIZE 1
|
|
#define STEP2_OUTPUT_HISTOGRAM_N 5 //step2 不能超过22743
|
|
|
|
#define STEP2_BBOX_SIZE1 (STEP2_INPUT_H/32)
|
|
#define STEP2_BBOX_SIZE2 (STEP2_INPUT_H/16)
|
|
#define STEP2_BBOX_SIZE3 (STEP2_INPUT_H/8)
|
|
|
|
#define STEP2_INPUT_SIZE INPUT_CHANNEL*STEP2_INPUT_H*STEP2_INPUT_W //input
|
|
#define STEP2_OUTPUT_SIZE INPUT_CHANNEL*(STEP2_BBOX_SIZE1*STEP2_BBOX_SIZE1+STEP2_BBOX_SIZE2*STEP2_BBOX_SIZE2+STEP2_BBOX_SIZE3*STEP2_BBOX_SIZE3)*(STEP2_CLEAR_NUM+STEP2_CLASS_NUM+STEP2_POS_CONF) //output
|
|
|
|
|
|
template<typename _T>
|
|
std::string join_dims(const std::vector<_T>& dims){
|
|
std::stringstream output;
|
|
char buf[64];
|
|
const char* fmts[] = {"%d", " x %d"};
|
|
for(int i = 0; i < dims.size(); ++i){
|
|
snprintf(buf, sizeof(buf), fmts[i != 0], dims[i]);
|
|
output << buf;
|
|
}
|
|
return output.str();
|
|
}
|
|
|
|
inline unsigned int getElementSize(nvinfer1::DataType t);
|
|
|
|
inline int64_t volume(const nvinfer1::Dims& d);
|
|
|
|
// 0 = 停止识别; 1 = 开始识别
|
|
extern std::atomic<int> g_identify_type;
|
|
// -1 = 未知方向; 1 = 向左行驶; 2 = 向右行驶
|
|
extern std::atomic<int> g_come_direction;
|
|
|
|
#endif
|