c++ vector 添加结构体元素,检测结果坐标的几个写法

1、用向量vector ,添加的时候判断,相同名字的元素,置信度最大的框进行保存,如果有了就替换相关值,或者全部push 后遍历一遍删除相同的框子中,置信度最低的那个框

cpp 复制代码
// 检测 //
struct Detect
{
    std::string name;
    float prob;
    cv::Rect rect;
};


void add_det(std::vector<Detect>& dets)
// 输入引用类型的 数据方便修改
// 在每次添加的时候遍历判断一下,如果没有就添加,如果有,就比较判断更新最大的那个元素
{
    bool found = false;
    for (auto& det : dets) {
        if (det.name == label) {
            if (conf > det.prob) {
                det.prob = conf;
                det.rect = bbox;
            }
            found = true;
            break;
        }
    }

    if (!found) {
        dets.push_back({label, conf, bbox});
    }
 }



/
	std::vector<Detect> dets;

    std::string label = "狗";
    cv::Rect bbox(363, 388, 69, 57); //xywh
    float conf = 0.797;
    dets.push_back({label, conf, bbox});

    bbox = cv::Rect(366, 209, 101, 91); //xywh
    dets.push_back({"猫", 0.702, bbox});

    bbox = cv::Rect(113, 94, 533, 453); //xywh
    dets.push_back({"猫", 0.669, bbox});

2、用字典,添加自定义结构体变量框数据

cpp 复制代码
// std::map中的一个键值对。键值对由键和值组成,通过it->first可以访问键,通过it->second可以访问值
struct Detect
{
    std::string name;
    float prob;
    cv::Rect rect;
};
//


std::map<std::string, Detect> detectMap;

std::string label = "猫";
cv::Rect bbox(363, 388, 69, 57); //xywh
float conf = 0.797;

// 查找是否已存在相同标签的元素
auto it = detectMap.find(label);
if (it != detectMap.end()) {
    // 如果已存在,比较置信度并更新
    if (conf > it->second.prob) {
        it->second.prob = conf;
        it->second.rect = bbox;
    }
} else {
    // 如果不存在,添加新元素
    detectMap.insert({label, {label, conf, bbox}});
}

3、 重载操作符 opreate 写法

cpp 复制代码
//当你想要对自定义的结构体进行排序时,你可以通过重载operator<来定义排序的规则。
//以下是一个示例,展示了如何在结构体中重载operator<来按照置信度(prob)进行排序:

cpp
struct Detect {
    std::string name;
    float prob;
    cv::Rect rect;

    bool operator<(const Detect& other) const {
        return prob < other.prob;
    }
};

//在这个示例中,我们将operator<重载为比较两个Detect结构体的置信度(prob)大小。根据你的需求,你也可以选择比较其他的字段。

// 然后,你可以使用标准库中的排序算法(例如std::sort)对dets向量进行排序,如下所示:

cpp
std::vector<Detect> dets;

// 添加元素到dets...

std::sort(dets.begin(), dets.end());
这将使用重载的operator<来对dets中的元素进行排序,按照置信度从低到高的顺序进行排列。

希望这对你有帮助!👍🏻
相关推荐
闻缺陷则喜何志丹几秒前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
charlie11451419112 分钟前
C++ STL CookBook
开发语言·c++·stl·c++20
袁袁袁袁满12 分钟前
100天精通Python(爬虫篇)——第113天:‌爬虫基础模块之urllib详细教程大全
开发语言·爬虫·python·网络爬虫·爬虫实战·urllib·urllib模块教程
ELI_He99918 分钟前
PHP中替换某个包或某个类
开发语言·php
小林熬夜学编程23 分钟前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
m0_7482361125 分钟前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust
倔强的石头10634 分钟前
【C++指南】类和对象(九):内部类
开发语言·c++
Watermelo61738 分钟前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
A懿轩A2 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
机器视觉知识推荐、就业指导2 小时前
C++设计模式:享元模式 (附文字处理系统中的字符对象案例)
c++