【Jetson Nano】学习(3)——物体识别后提取出感兴趣的对象,目标检测,语义分割

📒前言

  • 🍊在前面的博客中我写了一篇关于实现目标检测的文章,但是我们只是作为一个测试使用,并没有具体说明他能干什么,感兴趣可以看看❤️【Jetson Nano】学习(2)——两种方法(命令行、openCV)打开摄像头、实现目标检测,语义分割
  • 🍊在这篇文章中我实现了目标检测和语义分割这一块,之前有说我们得到这个图像之后,可以方便我们去做很多事情,在这里我们就提出了,当我们要对某一个目标进行操作时,那怎么去提取出我们感兴趣的目标对象呢? 这篇文章就会带你去实现这个功能🎉🎉🎉
  • ❤️点赞 👍 收藏 ⭐留言 📝 都是博主坚持写作、更新高质量博文的最大动力哦!❤️
    请添加图片描述

📙定位对象

  • 🍊我们在这定位对象的学习中,主要是在jetson-inference库中使用DetectNet完成目标对象的定位的,是通过提取其边界框来查找各种对象在帧中的位置,在这里与图像分类不同,对象检测网络能够每帧检测出许多不同的对象。
  • 🍊该detectNet对象接受图像作为输入,并输入检测到的边界框的坐标列表及其类别和置信度值。detectNet可从pythonC++中使用。我们可以下载各种预训练的模型进行实验,在这里我使用的是在MS COCO数据集上训练的91级SSD-Mobilenet-v2模型,该模型能在使用TensorRTjetson上实现实时推理性能。

📗对象提取代码:

    for  detect in detections:
        ID = detect.ClassID
        top = int(detect.Top)
        bottom = int(detect.Bottom)
        left = int(detect.Left)
        right = int(detect.Right)
        name = net.GetClassDesc(ID)
  • 🍊通过上面的代码,我们可以得到对象的所对应的像素、ID、名称等等信息,同时也为我们后期实现对象跟踪提供了更多的信息。
  • 🍊在这里我把所识别到的cell phonerectangle函数把他填充为绿色,并用putText函数把我们识别出来的名字给标注在图像的左上角。下面给出完整代码。

📘完整代码

import jetson.inference    #引入推理库
import jetson.utils               #引入工具库
import cv2                                #引入openCV
import numpy as np             #引入数值运算库
from time import sleep
width = 1280
height = 720

net = jetson.inference.detectNet("ssd-mobilenet-v2", threshold = 0.5)     #选择检测网络为‘ssd-mobilenet-v2’模型,阈值为0.5
camera = jetson.utils.gstCamera(width,height,'0')  #选择0号摄像头工具
object_pixel_last = 1

while 1:
    img, width, height = camera.CaptureRGBA(zeroCopy = 1)
    detections = net.Detect(img, width, height) 
    image = jetson.utils.cudaToNumpy(img,width, height, 4)   
    image1 = cv2.cvtColor (image, cv2.COLOR_RGBA2BGR).astype (np.uint8)
    
    for  detect in detections:
        ID = detect.ClassID
        top = int(detect.Top)
        bottom=int(detect.Bottom)
        left=int(detect.Left)
        right=int(detect.Right)
        name = net.GetClassDesc(ID)

        if name== 'cell phone':
            cv2.rectangle(image1,(left,top),(right,bottom),(0,255,0),-1)
            cv2.putText(image1,name, (left, top+20) , cv2.FONT_HERSHEY_SIMPLEX , 0.75 , (0, 0 , 255) , 1)

    cv2.imshow ("目标检测",image1)   #显示摄像头读取到的内容

    kk = cv2.waitKey(1)   #从键盘读取
    if kk == ord('q'):  # 按下 q键,退出
        break              #退出循环

📕识别效果

请添加图片描述

❤️点赞 👍 收藏 ⭐留言 📝 都是博主坚持写作、更新高质量博文的最大动力哦!❤️

  • 12
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 22
    评论
YOLOv5是一种目标检测深度学习算法,它在推理速度和精度上都有较好的性能。要在Jetson Nano上部署YOLOv5目标检测,可以按照以下步骤进行操作: 1. 首先,需要将训练好的YOLOv5s权重文件转换为wts文件格式。然后,使用build工具将wts文件转换为TensorRT的engine文件。这样就可以对输入的Tensors进行加速处理并得到推理的输结果。\[2\] 2. 在Jetson Nano上部署YOLOv5目标检测,还需要修改文件夹DeepStream-Yolo/external/yolov5/nvdsinfer_custom_impl_Yolo下的文件yololayer.h和yololayer.cu,以使其可以在YOLOv5 V4.0上正常工作。\[3\] 通过以上步骤,你就可以在Jetson Nano上成功部署YOLOv5目标检测算法了。希望对你有所帮助! #### 引用[.reference_title] - *1* *2* [Jetson Nano 部署(1):YOLOv5 目标检测实战介绍](https://blog.csdn.net/weixin_38346042/article/details/126399006)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Jetson Nano部署实现(一)——Yolov5目标检测-Jetson Nano部署](https://blog.csdn.net/qq_40305597/article/details/117320573)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BC_GAN

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值