目标检测算法与应用算法 DS集成 接口相关_v0.1

目录

文章目录

    • 目录
    • 0. 目标GPS信息、速度、加速度、航向角信息的输出
    • 1. 目标检测算法接口
      • 1.1 模型相关
      • 1.2 检测结果相关
    • 2. 应用算法接口
      • 2.1 bool cross_line; //跨线(变道压线检测)
      • 2.2 bool break_in; //闯入(目标闯入)
      • 2.3 bool stay; //停留(目标违停)
      • 2.4 bool left_behind; //遗留物(道路遗留、抛散、异常)
      • 2.5 bool retrograde; //逆行(目标逆行)
      • 2.6 目标占道(占用公交车道、应急车道... ...)
      • 2.7 流量统计
    • 2.8 车辆行驶车道
    • 2.9 车身颜色识别
    • 2.10 车牌识别
    • 3 道路信息

0. 目标GPS信息、速度、加速度、航向角信息的输出

接口示例:

// 道路信息配置(GPS信息配置)
struct GPSPosition
{double longitude; //经度double latitude;  //纬度float altitude;  //高度
};struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};struct Row
{std::vector<GPSPosition> gps;	//多个点位经纬度信息std::vector<Point> pos;	// 多个点位像素位置
};
std::vector<Row> rows;

为vector rows赋值示例:

// 长度为3认为标定了3行信息
vector<Row> rows(3); 
int len_rows = rows.size();  // 3
// 第一行信息认为三个点赋值 
rows[0].gps[0].longitude = 100.0281330;
rows[0].gps[0].latitude = 100.5329955;
rows[0].gps[0].altitude = 886.4188;
rows[0].pos[0].x = 0;
rows[0].pos[0].y = 0;
rows[0].gps[1].longitude = 150.0281382;
rows[0].gps[1].latitude = 100.5329584;
rows[0].gps[1].altitude = 886.3948;
rows[0].pos[1].x = 50;
rows[0].pos[1].y = 0;
rows[0].gps[2].longitude = 200.0281402;
rows[0].gps[2].latitude = 100.5329200;
rows[0].gps[2].altitude = 886.3948;
rows[0].pos[2].x = 100;
rows[0].pos[2].y = 0;
// 第二行信息认为两个点赋值
rows[1].gps[0].longitude = 100.0281330;
rows[1].gps[0].latitude = 150.5328777;
rows[1].gps[0].altitude = 883.0678;
rows[1].pos[0].x = 0;
rows[1].pos[0].y =45;
rows[1].gps[1].longitude = 100.0276137;
rows[1].gps[1].latitude = 153.5328084;
rows[1].gps[1].altitude = 883.3948;
rows[1].pos[1].x = 100;
rows[1].pos[1].y = 50;
// 第三行信息认为三个点赋值
rows[2].gps[0].longitude = 100.0281330;
rows[2].gps[0].latitude = 203.5327223;
rows[2].gps[0].altitude = 878.6568;
rows[2].pos[0].x = 0;
rows[2].pos[0].y = 100;
rows[2].gps[1].longitude = 150.0281382;
rows[2].gps[1].latitude = 203.5326848;
rows[2].gps[1].altitude = 878.8278;
rows[2].pos[1].x = 50;
rows[2].pos[1].y = 100;
rows[2].gps[2].longitude = 200.0281402;
rows[2].gps[2].latitude = 200.5326465;
rows[2].gps[2].altitude = 878.9038;
rows[2].pos[2].x = 100;
rows[2].pos[2].y = 100;

1. 目标检测算法接口

1.1 模型相关

​ 模型相关文件及其对应的目标类型。

如下文件:

best.wts
best.cfg
best.engine
labels.txt

其中,labels.txt内容对应模型文件的分类类型,示例如下:

car
truck
bus
elec
bike
pedes
tricycle
coni
warm

1.2 检测结果相关

【注】:跟模型文件一起写死在算法内部。

检测结果涉及目标输出信息和目标所属类别置信度信息。

//目标分类数
static constexpr int CLASS_NUM = 9;//输入图像宽高
static constexpr int INPUT_H = 960;  
static constexpr int INPUT_W = 960;//目标框
struct Box {uint16_t x;uint16_t y;uint16_t w;uint16_t h;};//目标置信度
pre-cluster-threshold=0.25// 
//nms-iou-threshold=0.45

2. 应用算法接口

2.0 每帧图像的目标信息如下:

vector<TargetAttribute>;

2.1 bool cross_line; //跨线(变道压线检测)

输入:每帧的目标信息 和 如下结构体的标定信息

// 跨线检测对应标定线结构体定义,可能需要考虑线段id,涉及多条线段需要跨线检测的时候
struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};
struct Line
{uint8_t line_id;			//线段idbool is_able;				//使能vector<Point> line_info;	//线段信息,长度等于2
};
vector <Line> line; 

输出:当前帧图像的目标信息。增加了对应目标信息的TriggerEvent事件结果。

2.2 bool break_in; //闯入(目标闯入)

输入:每帧的目标信息 和 如下结构体的标定信息

//目标闯入的标定区间struct定义
struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};struct Region
{uint8_t region_id;			//区域idbool is_able;				//使能vector<Point> region_info;	//区域信息,长度大于等于3
};
vector <Region> region;

输出:当前帧图像的目标信息。增加了对应目标信息的事件结果。

2.3 bool stay; //停留(目标违停)

输入:每帧的目标信息 和 如下结构体的标定信息

//目标闯入的标定区间struct定义
struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};struct Region
{uint8_t region_id;			//区域idbool is_able;				//使能vector<Point> region_info;	//区域信息,长度大于等于3
};
vector <Region> region;

输出:当前帧图像的目标信息。增加了对应目标信息的事件结果。

2.4 bool left_behind; //遗留物(道路遗留、抛散、异常)

输入:每帧的目标信息 和 如下结构体的标定信息

//目标停留的标定区间struct定义
struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};struct Region
{uint8_t region_id;bool is_able;				//使能vector<Point> region_info; //长度大于等于3
};
vector <Region> region;

输出:当前帧图像的目标信息。增加了对应目标信息的事件结果。

2.5 bool retrograde; //逆行(目标逆行)

输入:每帧的目标信息 和 如下结构体的标定信息

//目标停留的标定区间struct定义
struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};struct Region
{uint8_t region_id;bool is_able;				//使能vector<Point> region_info; 	//长度大于等于3vector<Point> right_direction;//正确方向,长度等于2,两点确定方向向量,[起点, 终点]
};
vector <Region> region;

输出:当前帧图像的目标信息。增加了对应目标信息的事件结果。

2.6 目标占道(占用公交车道、应急车道… …)

输入:每帧的目标信息 和 如下结构体的标定信息

//目标停留的标定区间struct定义
struct Point
{uint16_t x;  //像素xuint16_t y;  //像素y
};struct Region
{uint8_t region_id;			//区域idbool is_able;				//使能vector<Point> region_info; 	//长度大于等于3
};
vector <Region> region;

输出:当前帧图像的目标信息。增加了对应目标信息的事件结果。

2.7 流量统计

参见 2.1 跨线检测 。

2.8 车辆行驶车道

依赖车道识别算法 或 标定车道信息

2.9 车身颜色识别

输入: 一帧图像的Mat信息 和 每帧的目标信息

// 一帧图像的信息,类型为Mat
Mat frames;// 每帧的目标信息,如下:
vector<TargetAttribute> objs;

输出:当前帧图像的目标信息。增加了对应目标信息的事件结果。

2.10 车牌识别

3 道路信息

3.1 车道占用率

3.2 车道空间占用率

3.3 车道车辆数

3.4 是否拥堵

3.5 车道排队车辆数

3.6 车辆排队长度

3.7 队首队尾车辆位置

3.8 车头间距

3.9 车头时距

3.10 车流平均速度

3.11 车辆缓行

3.12 超高速

3.13 超低速

3.14

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/47743.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux HOOK机制与Netfilter HOOK

一. 什么是HOOK&#xff08;钩子&#xff09; 在计算机中&#xff0c;基本所有的软件程序都可以通过hook方式进行行为拦截&#xff0c;hook方式就是改变原始的执行流。 二. Linux常见的HOOK方式 1、修改函数指针。 2、用户态动态库拦截。 ①利用环境变量LD_PRELOAD和预装载机…

STM32自己从零开始实操:PCB全过程

一、PCB总体分布 以下只能让大家看到各个模块大致分布在板子的哪一块&#xff0c;只能说每个人画都有自己的理由&#xff1a; 电源&#xff1a;从外部接入电源&#xff0c;5V接到中间&#xff0c;向上变成4V供给无线&#xff0c;向下变成3V供给下面的接口&#xff08;也刻意放…

每日一练 - BGP 路由表中的团体属性

01 真题题目 下面一台路由器的输出信息&#xff0c;关于这段信息描述正确的是? A.目的网段 1.1.1.0/24 所携带的团体属性值是 NO-EXPORT&#xff0c; 表明该路由条目不能通告给任何 BGP 邻居 B.目的网段 1.1.1.0/24 所携带的图体属性值是 NO-EXPORT&#xff0c; 表明试路由…

Three.JS 使用RGBELoader和CubeTextureLoader 添加环境贴图

导入RGBELoader模块&#xff1a; import { RGBELoader } from "three/examples/jsm/loaders/RGBELoader.js"; 使用 addRGBEMappingk(environment, background,url) {rgbeLoader new RGBELoader();rgbeLoader.loadAsync(url).then((texture) > {//贴图模式 经纬…

git使用-命令行+VS Code结合使用

一、Git常用命令 // 显示当分支的状态。它会列出已修改、已暂存和未跟踪的文件 git status// 列出本地仓库中所有的分支&#xff0c;其中会特殊显示当前所在分支 git branch// 在当前分支的基础上创建一个新的分支&#xff0c;并切换到这个新的分支上 git checkout -b 新分支…

问题:向上对齐对象的快捷键是: #学习方法#笔记

问题&#xff1a;向上对齐对象的快捷键是: A、T B、L C、R D、W 参考答案如图所示

Leetcode 1302.层数最深子叶结点的和

大家好&#xff0c;今天我给大家分享一下我关于这个题的想法&#xff0c;我这个题过程比较复杂&#xff0c;但大家如果觉得好的话&#xff0c;就请给个免费的赞吧&#xff0c;谢谢了^ _ ^ 1.题目要求: 给你一棵二叉树的根节点 root &#xff0c;请你返回 层数最深的叶子节点的…

Go语言并发编程-Context上下文

Context上下文 Context概述 Go 1.7 标准库引入 context&#xff0c;译作“上下文”&#xff0c;准确说它是 goroutine 的上下文&#xff0c;包含 goroutine 的运行状态、环境、现场等信息。 context 主要用来在 goroutine 之间传递上下文信息&#xff0c;包括&#xff1a;取…

python爬虫实现简单的代理ip池

python爬虫实现简单的代理ip池 我们在普通的爬虫过程中经常遇到一些网站对ip进行封锁的 下面演示一下普通的爬虫程序 使用requests.get爬取数据 这段代码是爬取豆瓣排行榜的数据&#xff0c;使用f12来查看请求的url和数据格式 代码 def requestData():# 爬取数据的urlur…

数学基础【俗说矩阵】:矩阵相乘

矩阵乘法 矩阵乘法推导过程 一、两个线性方程复合代入 二、X1和X2合并同类项 三、复合后方程组结果 四、线性方程组矩阵表示 五、线性方程组矩阵映射表示 复合映射表示 六、矩阵乘法导出 矩阵乘法法则 1、规则一推导过程 左取行&#xff0c;右取列&#xff0c;对应相乘后…

【中项】系统集成项目管理工程师-第2章 信息技术发展-2.1信息技术及其发展-2.1.4信息安全

前言&#xff1a;系统集成项目管理工程师专业&#xff0c;现分享一些教材知识点。觉得文章还不错的喜欢点赞收藏的同时帮忙点点关注。 软考同样是国家人社部和工信部组织的国家级考试&#xff0c;全称为“全国计算机与软件专业技术资格&#xff08;水平&#xff09;考试”&…

「Vue组件化」封装i18n国际化

前言 在Vue应用中实现国际化(i18n),通常需要使用一些专门的库,比如vue-i18n。本文主要介绍自定义封装i18n,支持Vue、uniapp等版本。 设计思路 一、预期效果 二、核心代码 2.1 i18n.xlsx文件准备 2.2 脚本执行 根目录main.js根目录locali18n.xlsxnode main.jsmain.js 文件…

【ARM】MDK-解决CMSIS_DAP.DLL missing报错

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 记录解决CMSIS_DAP.DLL missing的报错情况&#xff0c;对应相关报错信息&#xff0c;供后续客户参考&#xff0c;快速解决客户问题。 2、 问题场景 客户进行硬件调试时&#xff0c;发现Target设置内有CMSIS_DAP.DL…

全时守护,无死角监测:重点海域渔港视频AI智能监管方案

一、方案背景 随着海洋经济的快速发展和海洋资源的日益紧缺&#xff0c;对重点海域渔港进行有效监控和管理显得尤为重要。视频监控作为一种高效、实时的管理手段&#xff0c;已成为渔港管理中不可或缺的一部分。当前&#xff0c;我国海域面积广阔&#xff0c;渔港众多&#xf…

uni-app学习HBuilderX学习-微信开发者工具配置

HBuilderX官网&#xff1a;简介 - HBuilderX 文档 (dcloud.net.cn)https://hx.dcloud.net.cn/ uni-app官网&#xff1a; uni-app官网 (dcloud.net.cn)https://uniapp.dcloud.net.cn/quickstart-hx.htmlHBuilder下载安装&#xff1a;打开官网 uni-app项目的微信开发者工具配置…

41 QOS技术(服务质量)

1 QOS 产生背景 对于网络业务&#xff0c;影响服务质量的因素包括传输的带宽、传送的时延、数据的丢包率等。网络资源总是有限的&#xff0c;只要存在抢夺网络资源的情况&#xff0c;就会出现服务质量的要求网络总带宽固定的情况下&#xff0c;如果某类业务占用的带宽越多&am…

Mysql-错误处理: Found option without preceding group in config file

1、问题描述 安装MYSQL时&#xff0c;在cmd中“初始化”数据库时&#xff0c;输入命令&#xff1a; mysqld --initialize --consolecmd报错&#xff1a; D:\mysql-5.7.36-winx64\bin>mysql --initialize --console mysql: [ERROR] Found option without preceding group …

Web开发:ASP.NET CORE的后端小结(基础)

1.后端重定向到指定路由 public IActionResult Index(){return RedirectToAction("Index", "Main");//重定向>Main/Index} 【备注】如果在MainController的Index方法中return View();本质是 return View("Index")&#xff0c;返回和方法同名的…

vscode通过ssh链接远程服务器上的docker

目录 1 编译docker image1.1 编译镜像1.2 启动镜像 2 在docker container中启动ssh服务2.1 确认是否安装ssh server2.2 修改配置文件2.3 启动ssh服务 3 生成ssh key4 添加ssh公钥到docker container中5 vscode安装插件Remote - SSH6 在vscode中配置 1 编译docker image 一般来…

二叉树的前、中、后序遍历(递归法、迭代法)leetcode144/94/145

leetcode144、二叉树的前序遍历 给你二叉树的根节点 root &#xff0c;返回它节点值的 前序 遍历。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,2,3] 示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[] 示例 3&#xff1a;…