【特训营第三期】无人机高空红外检测

该项目对2898幅红外热图像进行目标检测,先调整数据集格式,将原test、train、val数据融合后按7:3划分为训练集和验证集,转换为VOC格式。选用PP-YOLOE模型,修改配置文件后训练,评估得mAP为76.60%,未达0.8以上,最后用最佳模型进行了预测。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

【特训营第三期】无人机高空红外检测 - 创想鸟

1. 项目介绍

数据集包含从43470帧中提取的2898幅红外热图像,这些图像由无人机从不同场景(学校、停车场、道路、操场等)捕捉到,涵盖范围广泛,包括物体(人、自行车、汽车、其他车辆)、飞行高度数据(60至130米)、相机透视数据(30至90度)和日光强度(白天和晚上),该次任务主要是自行调整数据集格式,并将给定数据集按7:3的比例划分为训练集和验证集,选择合适的模型,并且在划分的验证集下面评估的map达到0.8以上

2. 环境准备

Clone 代码库和安装 requirements.txt,环境需要在一个 Python>=3.7.0 下的环境,且需要安装 PaddlePaddle>=2.3.2。将代码clone到work目录下去,我们选择的是PaddleDetection,PaddleDetection相关介绍可以参考:https://github.com/PaddlePaddle/PaddleDetection, 进行clone PaddleDetection代码,我这里已经下载好了,直接解压就行,按照要求进行准备环境

In [1]

#!cd work && git clone https://github.com/PaddlePaddle/PaddleDetection.git  # clone# !cd work && unzip PaddleDetection.zip# 如果需要进行持久化安装, 需要使用持久化路径, 如下方代码示例:# !mkdir /home/aistudio/external-libraries!cd work/PaddleDetection-release-2.6 && pip install -r requirements.txt

       

Looking in indexes: https://pypi.tuna.tsinghua.edu.cn/simpleRequirement already satisfied: numpy=2.2.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from -r requirements.txt (line 4)) (2.4.0)Collecting opencv-python-r requirements.txt (line 17)) (0.24.2)Collecting typing-extensions>=4.4.0  Downloading https://pypi.tuna.tsinghua.edu.cn/packages/31/25/5abcd82372d3d4a3932e1fa8c3dbf9efac10cc7c0d16e78467460571b404/typing_extensions-4.5.0-py3-none-any.whl (27 kB)Requirement already satisfied: importlib-metadata>=3.6 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from typeguard->-r requirements.txt (line 3)) (4.2.0)Requirement already satisfied: requests in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (2.24.0)Requirement already satisfied: bce-python-sdk in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (0.8.53)Requirement already satisfied: matplotlib in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (2.2.3)Requirement already satisfied: Flask-Babel>=1.0.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (1.0.0)Requirement already satisfied: Pillow>=7.0.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (8.2.0)Requirement already satisfied: flask>=1.1.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (1.1.1)Requirement already satisfied: protobuf>=3.11.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (3.20.0)Requirement already satisfied: pandas in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (1.1.5)Requirement already satisfied: six>=1.14.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from visualdl>=2.2.0->-r requirements.txt (line 4)) (1.16.0)Collecting xmltodict>=0.12.0  Downloading https://pypi.tuna.tsinghua.edu.cn/packages/94/db/fd0326e331726f07ff7f40675cd86aa804bfd2e5016c727fa761c934990e/xmltodict-0.13.0-py2.py3-none-any.whl (10.0 kB)Requirement already satisfied: Werkzeug>=0.15 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from flask>=1.1.1->visualdl>=2.2.0->-r requirements.txt (line 4)) (0.16.0)Requirement already satisfied: click>=5.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from flask>=1.1.1->visualdl>=2.2.0->-r requirements.txt (line 4)) (8.0.4)Requirement already satisfied: Jinja2>=2.10.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from flask>=1.1.1->visualdl>=2.2.0->-r requirements.txt (line 4)) (3.0.0)Requirement already satisfied: itsdangerous>=0.24 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from flask>=1.1.1->visualdl>=2.2.0->-r requirements.txt (line 4)) (1.1.0)Requirement already satisfied: Babel>=2.3 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from Flask-Babel>=1.0.0->visualdl>=2.2.0->-r requirements.txt (line 4)) (2.8.0)Requirement already satisfied: pytz in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from Flask-Babel>=1.0.0->visualdl>=2.2.0->-r requirements.txt (line 4)) (2019.3)Requirement already satisfied: zipp>=0.5 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from importlib-metadata>=3.6->typeguard->-r requirements.txt (line 3)) (3.8.1)Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from matplotlib->visualdl>=2.2.0->-r requirements.txt (line 4)) (3.0.9)Requirement already satisfied: kiwisolver>=1.0.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from matplotlib->visualdl>=2.2.0->-r requirements.txt (line 4)) (1.1.0)Requirement already satisfied: python-dateutil>=2.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from matplotlib->visualdl>=2.2.0->-r requirements.txt (line 4)) (2.8.2)Requirement already satisfied: cycler>=0.10 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from matplotlib->visualdl>=2.2.0->-r requirements.txt (line 4)) (0.10.0)Requirement already satisfied: pycryptodome>=3.8.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from bce-python-sdk->visualdl>=2.2.0->-r requirements.txt (line 4)) (3.9.9)Requirement already satisfied: future>=0.6.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from bce-python-sdk->visualdl>=2.2.0->-r requirements.txt (line 4)) (0.18.0)Requirement already satisfied: certifi>=2017.4.17 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from requests->visualdl>=2.2.0->-r requirements.txt (line 4)) (2019.9.11)Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,=1.21.1 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from requests->visualdl>=2.2.0->-r requirements.txt (line 4)) (1.25.11)Requirement already satisfied: idna=2.5 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from requests->visualdl>=2.2.0->-r requirements.txt (line 4)) (2.8)Requirement already satisfied: chardet=3.0.2 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from requests->visualdl>=2.2.0->-r requirements.txt (line 4)) (3.0.4)Requirement already satisfied: threadpoolctl>=2.0.0 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from scikit-learn->sklearn==0.0->-r requirements.txt (line 17)) (2.1.0)Requirement already satisfied: joblib>=0.11 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from scikit-learn->sklearn==0.0->-r requirements.txt (line 17)) (0.14.1)Requirement already satisfied: MarkupSafe>=2.0.0rc2 in /opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages (from Jinja2>=2.10.1->flask>=1.1.1->visualdl>=2.2.0->-r requirements.txt (line 4)) (2.0.1)Building wheels for collected packages: pycocotools, lap  Building wheel for pycocotools (pyproject.toml) ... done  Created wheel for pycocotools: filename=pycocotools-2.0.6-cp37-cp37m-linux_x86_64.whl size=275122 sha256=eabe5690b267eaaa5d1922f61f11feda71210995782667a0e58fe38a65d7614b  Stored in directory: /home/aistudio/.cache/pip/wheels/f8/94/70/046149e666bd5812b7de6b87a28dcef238f7162f4108e0b3d8  Building wheel for lap (setup.py) ... done  Created wheel for lap: filename=lap-0.4.0-cp37-cp37m-linux_x86_64.whl size=1593873 sha256=6a60a92df414102efcf89f0d1a318c555f45e009f6876daaaf50887e8fc33a0c  Stored in directory: /home/aistudio/.cache/pip/wheels/5c/d0/d2/e331d17a999666b1e2eb99743cfa1742629f9d26c55c657001Successfully built pycocotools lapInstalling collected packages: pyclipper, lap, xmltodict, typing-extensions, opencv-python, typeguard, pycocotools, motmetrics  Attempting uninstall: typing-extensions    Found existing installation: typing_extensions 4.3.0    Uninstalling typing_extensions-4.3.0:      Successfully uninstalled typing_extensions-4.3.0  Attempting uninstall: opencv-python    Found existing installation: opencv-python 4.6.0.66    Uninstalling opencv-python-4.6.0.66:ERROR: Could not install packages due to an OSError: [Errno 13] 权限不够: '__init__.py'Consider using the `--user` option or check the permissions.[notice] A new release of pip available: 22.1.2 -> 23.0.1[notice] To update, run: pip install --upgrade pip

       

3. 数据准备

3.1 分析数据

数据挂载的目录为/home/aistudio/data/data191179/HIT-UAV.zip,将挂载的数据集解压到work/datasets/到目录下去

In [ ]

!mkdir work/datasets!unzip -d work/datasets/ /home/aistudio/data/data191179/HIT-UAV.zip

   

数据集部分图片展示如下:

【特训营第三期】无人机高空红外检测 - 创想鸟 【特训营第三期】无人机高空红外检测 - 创想鸟【特训营第三期】无人机高空红外检测 - 创想鸟 【特训营第三期】无人机高空红外检测 - 创想鸟        

解压后的数据集路径为/home/aistudio/work/datasets/hit-uav,观察数据集,发现数据集已经划分为了test,train,val三个部分,图片数量为571, 2008, 287,不满足7:3比例的训练集和验证集,所以我们需要调整这个数据集,来达到我们任务的需求,先将所有的数据融合在一起,执行以下代码:

In [10]

!mv /home/aistudio/work/datasets/hit-uav/images/test/* /home/aistudio/work/datasets/hit-uav/images/val/!mv /home/aistudio/work/datasets/hit-uav/labels/test/* /home/aistudio/work/datasets/hit-uav/labels/val/!mv /home/aistudio/work/datasets/hit-uav/images/val/* /home/aistudio/work/datasets/hit-uav/images/train/!mv /home/aistudio/work/datasets/hit-uav/labels/val/* /home/aistudio/work/datasets/hit-uav/labels/train/

   

同时观察数据格式是yolo格式,不满足paddleDetection需要的voc或者coco的数据格式,这里需要做一个数据格式转换,转换脚本可以参考adjustData.py:

In [11]

from xml.dom.minidom import Documentimport osimport cv2# def makexml(txtPath, xmlPath, picPath):  # txt所在文件夹路径,xml文件保存路径,图片所在文件夹路径def makexml(picPath, txtPath, xmlPath):  # txt所在文件夹路径,xml文件保存路径,图片所在文件夹路径    """此函数用于将yolo格式txt标注文件转换为voc格式xml标注文件    在自己的标注图片文件夹下建三个子文件夹,分别命名为picture、txt、xml    """    dic = {           '0': "Person",           '1': "Car",  # 创建字典用来对类型进行转换           '2': "Bicycle",  # 此处的字典要与自己的classes.txt文件中的类对应,且顺序要一致           '3': "OtherVehicle",           '4': "DontCare"           }    files = os.listdir(txtPath)    for i, name in enumerate(files):        xmlBuilder = Document()        annotation = xmlBuilder.createElement("annotation")  # 创建annotation标签        xmlBuilder.appendChild(annotation)        txtFile = open(txtPath + name)        txtList = txtFile.readlines()        img = cv2.imread(picPath + name[0:-4] + ".jpg")        Pheight, Pwidth, Pdepth = img.shape        folder = xmlBuilder.createElement("folder")  # folder标签        foldercontent = xmlBuilder.createTextNode("driving_annotation_dataset")        folder.appendChild(foldercontent)        annotation.appendChild(folder)  # folder标签结束        filename = xmlBuilder.createElement("filename")  # filename标签        filenamecontent = xmlBuilder.createTextNode(name[0:-4] + ".jpg")        filename.appendChild(filenamecontent)        annotation.appendChild(filename)  # filename标签结束        size = xmlBuilder.createElement("size")  # size标签        width = xmlBuilder.createElement("width")  # size子标签width        widthcontent = xmlBuilder.createTextNode(str(Pwidth))        width.appendChild(widthcontent)        size.appendChild(width)  # size子标签width结束        height = xmlBuilder.createElement("height")  # size子标签height        heightcontent = xmlBuilder.createTextNode(str(Pheight))        height.appendChild(heightcontent)        size.appendChild(height)  # size子标签height结束        depth = xmlBuilder.createElement("depth")  # size子标签depth        depthcontent = xmlBuilder.createTextNode(str(Pdepth))        depth.appendChild(depthcontent)        size.appendChild(depth)  # size子标签depth结束        annotation.appendChild(size)  # size标签结束        for j in txtList:            oneline = j.strip().split(" ")            object = xmlBuilder.createElement("object")  # object 标签            picname = xmlBuilder.createElement("name")  # name标签            namecontent = xmlBuilder.createTextNode(dic[oneline[0]])            picname.appendChild(namecontent)            object.appendChild(picname)  # name标签结束            pose = xmlBuilder.createElement("pose")  # pose标签            posecontent = xmlBuilder.createTextNode("Unspecified")            pose.appendChild(posecontent)            object.appendChild(pose)  # pose标签结束            truncated = xmlBuilder.createElement("truncated")  # truncated标签            truncatedContent = xmlBuilder.createTextNode("0")            truncated.appendChild(truncatedContent)            object.appendChild(truncated)  # truncated标签结束            difficult = xmlBuilder.createElement("difficult")  # difficult标签            difficultcontent = xmlBuilder.createTextNode("0")            difficult.appendChild(difficultcontent)            object.appendChild(difficult)  # difficult标签结束            bndbox = xmlBuilder.createElement("bndbox")  # bndbox标签            xmin = xmlBuilder.createElement("xmin")  # xmin标签            mathData = int(((float(oneline[1])) * Pwidth + 1) - (float(oneline[3])) * 0.5 * Pwidth)            xminContent = xmlBuilder.createTextNode(str(mathData))            xmin.appendChild(xminContent)            bndbox.appendChild(xmin)  # xmin标签结束            ymin = xmlBuilder.createElement("ymin")  # ymin标签            mathData = int(((float(oneline[2])) * Pheight + 1) - (float(oneline[4])) * 0.5 * Pheight)            yminContent = xmlBuilder.createTextNode(str(mathData))            ymin.appendChild(yminContent)            bndbox.appendChild(ymin)  # ymin标签结束            xmax = xmlBuilder.createElement("xmax")  # xmax标签            mathData = int(((float(oneline[1])) * Pwidth + 1) + (float(oneline[3])) * 0.5 * Pwidth)            xmaxContent = xmlBuilder.createTextNode(str(mathData))            xmax.appendChild(xmaxContent)            bndbox.appendChild(xmax)  # xmax标签结束            ymax = xmlBuilder.createElement("ymax")  # ymax标签            mathData = int(((float(oneline[2])) * Pheight + 1) + (float(oneline[4])) * 0.5 * Pheight)            ymaxContent = xmlBuilder.createTextNode(str(mathData))            ymax.appendChild(ymaxContent)            bndbox.appendChild(ymax)  # ymax标签结束            object.appendChild(bndbox)  # bndbox标签结束            annotation.appendChild(object)  # object标签结束        f = open(xmlPath + name[0:-4] + ".xml", 'w')        xmlBuilder.writexml(f, indent='t', newl='n', addindent='t', encoding='utf-8')        f.close()if __name__ == "__main__":    picPath = "/home/aistudio/work/datasets/hit-uav/images/train/"    txtPath = "/home/aistudio/work/datasets/hit-uav/labels/train/"    xmlPath = "/home/aistudio/work/datasets/hit-uav/labels/Annotations/"    if not os.path.exists(xmlPath):        os.mkdir(xmlPath)    makexml(picPath, txtPath, xmlPath)

   

3.2 整理数据

将数据转换完成后,我们按照训练集和测试集7:3的比例进行分割图片和标签,并按照voc的目录结构整理数据集,voc数据集目录如下:

dataset/xxx/├── annotations│   ├── xxx1.xml│   ├── xxx2.xml│   ├── xxx3.xml│   |   ...├── images│   ├── xxx1.jpg│   ├── xxx2.jpg│   ├── xxx3.jpg│   |   ...├── label_list.txt (必须提供,且文件名称必须是label_list.txt )├── train.txt (训练数据集文件列表, ./images/xxx1.jpg ./annotations/xxx1.xml)└── valid.txt (测试数据集文件列表)

   In [12]

!cd /home/aistudio/work/datasets/hit-uav/images && rm -r test val && mv train/* ./ && rm -r train !cd /home/aistudio/work/datasets/hit-uav/labels && rm -r test val train && mv Annotations/* ./ && rm -r Annotations

   

使用脚本将数据集划分,参考脚本SplitData.py,制作train.txt与valid.txt:

In [13]

import osimport randomimgs_path = r"/home/aistudio/work/datasets/hit-uav/images"  #所有数据图片xmls_path = r"/home/aistudio/work/datasets/hit-uav/labels" #所有xmlsave_path = r"/home/aistudio/work/datasets/hit-uav"def write_File(txt_path, imgsList):    with open(txt_path, "w") as F:        for img_name in imgsList:            xml_name = img_name.split(".")[0] + ".xml"            img_path = os.path.join(imgs_path, img_name)            xml_path = os.path.join(xmls_path, xml_name)            F.write(f"{img_path} {xml_path}n")imgsList = os.listdir(imgs_path)dataLen = len(imgsList)rate = 0.7trainNum = int(dataLen * rate)trainList = random.sample(imgsList,trainNum)for name in trainList:    imgsList.remove(name)valList = imgsListtrain_txt_path = os.path.join(save_path, "train.txt")val_txt_path = os.path.join(save_path, "valid.txt")write_File(train_txt_path, trainList)write_File(val_txt_path, valList)

   

接着制作label_list.txt,label_list.txt主要是放标签的类别,这里参考dataset.yaml文件,直接写一个label_list.txt的文件即可,放在/home/aistudio/work/datasets/hit-uav目录下,至此,所有的txt都已经准备好了

Levity Levity

AI帮你自动化日常任务

Levity 206 查看详情 Levity In [ ]

!cp /home/aistudio/work/label_list.txt /home/aistudio/work/datasets/hit-uav/

   

4. 训练

4.1 选取模型

大致观察了一下数据集的内容,发现这个任务是一个比较简单目标检测的任务,我这里选用的是PP-YOLOE来进行训练

4.2 修改配置文件

对应的配置文件路径为configs/ppyoloe/voc/ppyoloe_plus_crn_s_30e_voc.yml,可以打开发现使用的voc配置文件路径为configs/datasets/voc.yml,将其中的数据集路径和类别改为自己数据集:

metric: VOCmap_type: 11pointnum_classes: 5TrainDataset:  name: VOCDataSet  dataset_dir: /home/aistudio/work/datasets/hit-uav  anno_path: train.txt  label_list: label_list.txt  data_fields: ['image', 'gt_bbox', 'gt_class', 'difficult']EvalDataset:  name: VOCDataSet  dataset_dir: /home/aistudio/work/datasets/hit-uav  anno_path: valid.txt  label_list: label_list.txt  data_fields: ['image', 'gt_bbox', 'gt_class', 'difficult']TestDataset:  name: ImageFolder  anno_path: /home/aistudio/work/datasets/hit-uav/label_list.txt

   

4.3开始训练

训练命令参考如下:

In [ ]

!pip install pycocotools!cd /home/aistudio/work/PaddleDetection-release-2.6 && python -m paddle.distributed.launch tools/train.py -c configs/ppyoloe/voc/ppyoloe_plus_crn_s_30e_voc.yml --eval

   

[03/27 17:46:39] ppdet.engine INFO: Epoch: [99] [  0/250] learning_rate: 0.000000 loss: 1.478661 loss_cls: 0.675399 loss_iou: 0.190062 loss_dfl: 0.650721 loss_l1: 0.242178 eta: 0:01:30 batch_cost: 0.3718 data_cost: 0.0218 ips: 21.5151 images/s[03/27 17:47:28] ppdet.engine INFO: Epoch: [99] [100/250] learning_rate: 0.000000 loss: 1.461851 loss_cls: 0.679879 loss_iou: 0.182444 loss_dfl: 0.655111 loss_l1: 0.234927 eta: 0:00:54 batch_cost: 0.3825 data_cost: 0.0017 ips: 20.9153 images/s[03/27 17:48:15] ppdet.engine INFO: Epoch: [99] [200/250] learning_rate: 0.000000 loss: 1.503901 loss_cls: 0.688840 loss_iou: 0.193698 loss_dfl: 0.650233 loss_l1: 0.251345 eta: 0:00:18 batch_cost: 0.3548 data_cost: 0.0011 ips: 22.5503 images/s[03/27 17:48:38] ppdet.utils.checkpoint INFO: Save checkpoint: output/ppyoloe_plus_crn_s_30e_voc[03/27 17:48:38] ppdet.engine INFO: Eval iter: 0[03/27 17:48:55] ppdet.engine INFO: Eval iter: 100[03/27 17:49:10] ppdet.engine INFO: Eval iter: 200[03/27 17:49:12] ppdet.metrics.metrics INFO: Accumulating evaluatation results...[03/27 17:49:14] ppdet.metrics.metrics INFO: mAP(0.50, 11point) = 76.57%[03/27 17:49:14] ppdet.engine INFO: Total sample number: 860, average FPS: 25.12995198704822[03/27 17:49:14] ppdet.engine INFO: Best test bbox ap is 0.766.LAUNCH INFO 2023-03-27 17:49:18,173 Pod completedLAUNCH INFO 2023-03-27 17:49:18,174 Exit code 0

   

4.4 开始评估

这里选用训练时综合表现最好的模型进行评估

In [ ]

# !pip install pycocotools!cd /home/aistudio/work/PaddleDetection-release-2.6 && python tools/eval.py -c configs/ppyoloe/voc/ppyoloe_plus_crn_s_30e_voc.yml -o weights=output/ppyoloe_plus_crn_s_30e_voc/best_model.pdparams

   

评估结果如下:

W0327 22:50:30.666767   800 gpu_resources.cc:61] Please NOTE: device: 0, GPU Compute Capability: 7.0, Driver API Version: 11.2, Runtime API Version: 11.2W0327 22:50:30.671360   800 gpu_resources.cc:91] device: 0, cuDNN Version: 8.2.[03/27 22:50:33] ppdet.utils.checkpoint INFO: Finish loading model weights: output/ppyoloe_plus_crn_s_30e_voc/best_model.pdparams[03/27 22:50:35] ppdet.engine INFO: Eval iter: 0[03/27 22:50:46] ppdet.engine INFO: Eval iter: 100[03/27 22:50:58] ppdet.engine INFO: Eval iter: 200[03/27 22:50:59] ppdet.metrics.metrics INFO: Accumulating evaluatation results...[03/27 22:51:01] ppdet.metrics.metrics INFO: mAP(0.50, 11point) = 76.60%[03/27 22:51:01] ppdet.engine INFO: Total sample number: 860, average FPS: 32.777653149867966

   

4.5 开始预测

训练完成后,在/home/aistudio/work/PaddleDetection-release-2.6/output/ppyoloe_plus_crn_s_30e_voc路径下保存了训练之后的权重文件,我们使用表现最好的模型进行预测,预测命令参考如下:

In [19]

# inference single image!cd /home/aistudio/work/PaddleDetection-release-2.6 && CUDA_VISIBLE_DEVICES=0 python tools/infer.py -c configs/ppyoloe/voc/ppyoloe_plus_crn_s_30e_voc.yml -o weights=/home/aistudio/work/PaddleDetection-release-2.6/output/ppyoloe_plus_crn_s_30e_voc/best_model.pdparams --infer_img=/home/aistudio/work/datasets/hit-uav/images/0_100_80_0_08238.jpg

       

/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/matplotlib/__init__.py:107: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated, and in 3.8 it will stop working  from collections import MutableMapping/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/matplotlib/rcsetup.py:20: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated, and in 3.8 it will stop working  from collections import Iterable, Mapping/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/matplotlib/colors.py:53: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated, and in 3.8 it will stop working  from collections import SizedWarning: Unable to use MOT metric, please install motmetrics, for example: `pip install motmetrics`, see https://github.com/longcw/py-motmetricsWarning: Unable to use MCMOT metric, please install motmetrics, for example: `pip install motmetrics`, see https://github.com/longcw/py-motmetricsWarning: import ppdet from source directory without installing, run 'python setup.py install' to install ppdet firstlyW0316 19:06:54.391429 28048 gpu_resources.cc:61] Please NOTE: device: 0, GPU Compute Capability: 7.0, Driver API Version: 11.2, Runtime API Version: 11.2W0316 19:06:54.396050 28048 gpu_resources.cc:91] device: 0, cuDNN Version: 8.2.[03/16 19:06:56] ppdet.utils.checkpoint INFO: Finish loading model weights: /home/aistudio/work/PaddleDetection-release-2.6/output/ppyoloe_plus_crn_s_30e_voc/best_model.pdparams100%|█████████████████████████████████████████████| 1/1 [00:01<00:00,  1.30s/it][03/16 19:06:57] ppdet.engine INFO: Detection bbox results save in output/0_100_80_0_08238.jpg

       

预测结果如下:

【特训营第三期】无人机高空红外检测 - 创想鸟        

以上就是【特训营第三期】无人机高空红外检测的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/741032.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Java中基本语法规范和命名规则
上一篇 2025年11月25日 15:23:09
Windows安装后无法连接网络的驱动问题
下一篇 2025年11月25日 15:23:17

相关推荐

  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • 获取日期中的周数:CodeIgniter 教程

    本教程旨在帮助开发者在 CodeIgniter 框架中,从日期字符串中准确提取周数。我们将使用 PHP 内置的 DateTime 类,并提供详细的代码示例和注意事项,确保您能够轻松地在项目中实现此功能。 使用 DateTime 类获取周数 PHP 的 DateTime 类提供了一种便捷的方式来处理日…

    2026年5月10日
    100
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • Go语言mgo查询构建:深入理解bson.M与日期范围查询的正确实践

    本文旨在解决go语言mgo库中构建复杂查询时,特别是涉及嵌套`bson.m`和日期范围筛选的常见错误。我们将深入剖析`bson.m`的类型特性,解释为何直接索引`interface{}`会导致“invalid operation”错误,并提供一种推荐的、结构清晰的代码重构方案,以确保查询条件能够正确…

    2026年5月10日
    100
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    100
  • 创建指定大小并填充特定数据的Golang文件教程

    本文将介绍如何使用Golang创建一个指定大小的文件,并用特定数据填充它。我们将使用 `os` 包提供的函数来创建和截断文件,从而实现快速生成大文件的目的。示例代码展示了如何创建一个10MB的文件,并将其填充为全零数据。掌握这些方法,可以方便地在例如日志系统或磁盘队列等场景中,预先创建测试文件或初始…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • 使用 WebCodecs VideoDecoder 实现精确逐帧回退

    本文档旨在解决在使用 WebCodecs VideoDecoder 进行视频解码时,实现精确逐帧回退的问题。通过比较帧的时间戳与目标帧的时间戳,可以避免渲染中间帧,从而提高用户体验。本文将提供详细的解决方案和示例代码,帮助开发者实现精确的视频帧控制。 在使用 WebCodecs VideoDecod…

    2026年5月10日
    000
  • 如何插入查询结果数据_SQL插入Select查询结果方法

    如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法

    使用INSERT INTO…SELECT语句可高效插入数据,通过NOT EXISTS、LEFT JOIN、MERGE语句或唯一约束避免重复;表结构不一致时可通过别名、类型转换、默认值或计算字段处理;结合存储过程可提升可维护性,支持参数化与动态SQL。 将查询结果数据插入到另一个表中,可以…

    2026年5月10日 用户投稿
    000
  • Discord.py 交互按钮超时与持久化解决方案

    本教程旨在解决Discord.py中交互按钮在一段时间后出现“This Interaction Failed”错误的问题。我们将深入探讨视图(View)的超时机制,并提供通过正确设置timeout参数以及利用bot.add_view()方法实现按钮持久化的具体方案,确保您的机器人交互功能稳定可靠,即…

    2026年5月10日
    000
  • Debian Copilot的社区活跃度如何

    debian copilot是codeberg社区维护的ai助手,旨在为debian用户提供服务。尽管搜索结果中没有直接提供关于debian copilot社区支持活跃度的具体数据,但我们可以通过debian社区的整体活跃度和特点来推断其活跃性。 Debian社区的一般情况: Debian拥有详尽的…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信