码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 实战|基于YOLOv10与MobileSAM实现目标检测与分割【附完整源码】


    《博主简介》

    小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。
    ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~
    👍感谢小伙伴们点赞、关注!

    《------往期经典推荐------》

    一、AI应用软件开发实战专栏【链接】

    项目名称项目名称
    1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】
    3.【手势识别系统开发】4.【人脸面部活体检测系统开发】
    5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】
    7.【YOLOv8多目标识别与自动标注软件开发】8.【基于YOLOv8深度学习的行人跌倒检测系统】
    9.【基于YOLOv8深度学习的PCB板缺陷检测系统】10.【基于YOLOv8深度学习的生活垃圾分类目标检测系统】
    11.【基于YOLOv8深度学习的安全帽目标检测系统】12.【基于YOLOv8深度学习的120种犬类检测与识别系统】
    13.【基于YOLOv8深度学习的路面坑洞检测系统】14.【基于YOLOv8深度学习的火焰烟雾检测系统】
    15.【基于YOLOv8深度学习的钢材表面缺陷检测系统】16.【基于YOLOv8深度学习的舰船目标分类检测系统】
    17.【基于YOLOv8深度学习的西红柿成熟度检测系统】18.【基于YOLOv8深度学习的血细胞检测与计数系统】
    19.【基于YOLOv8深度学习的吸烟/抽烟行为检测系统】20.【基于YOLOv8深度学习的水稻害虫检测与识别系统】
    21.【基于YOLOv8深度学习的高精度车辆行人检测与计数系统】22.【基于YOLOv8深度学习的路面标志线检测与识别系统】
    23.【基于YOLOv8深度学习的智能小麦害虫检测识别系统】24.【基于YOLOv8深度学习的智能玉米害虫检测识别系统】
    25.【基于YOLOv8深度学习的200种鸟类智能检测与识别系统】26.【基于YOLOv8深度学习的45种交通标志智能检测与识别系统】
    27.【基于YOLOv8深度学习的人脸面部表情识别系统】28.【基于YOLOv8深度学习的苹果叶片病害智能诊断系统】
    29.【基于YOLOv8深度学习的智能肺炎诊断系统】30.【基于YOLOv8深度学习的葡萄簇目标检测系统】
    31.【基于YOLOv8深度学习的100种中草药智能识别系统】32.【基于YOLOv8深度学习的102种花卉智能识别系统】
    33.【基于YOLOv8深度学习的100种蝴蝶智能识别系统】34.【基于YOLOv8深度学习的水稻叶片病害智能诊断系统】
    35.【基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统】36.【基于YOLOv8深度学习的智能草莓病害检测与分割系统】
    37.【基于YOLOv8深度学习的复杂场景下船舶目标检测系统】38.【基于YOLOv8深度学习的农作物幼苗与杂草检测系统】
    39.【基于YOLOv8深度学习的智能道路裂缝检测与分析系统】40.【基于YOLOv8深度学习的葡萄病害智能诊断与防治系统】
    41.【基于YOLOv8深度学习的遥感地理空间物体检测系统】42.【基于YOLOv8深度学习的无人机视角地面物体检测系统】
    43.【基于YOLOv8深度学习的木薯病害智能诊断与防治系统】44.【基于YOLOv8深度学习的野外火焰烟雾检测系统】
    45.【基于YOLOv8深度学习的脑肿瘤智能检测系统】46.【基于YOLOv8深度学习的玉米叶片病害智能诊断与防治系统】
    47.【基于YOLOv8深度学习的橙子病害智能诊断与防治系统】48.【车辆检测追踪与流量计数系统】
    49.【行人检测追踪与双向流量计数系统】50.【基于YOLOv8深度学习的反光衣检测与预警系统】
    51.【危险区域人员闯入检测与报警系统】52.【高压输电线绝缘子缺陷智能检测系统】

    二、机器学习实战专栏【链接】,已更新31期,欢迎关注,持续更新中~~
    三、深度学习【Pytorch】专栏【链接】
    四、【Stable Diffusion绘画系列】专栏【链接】
    五、YOLOv8改进专栏【链接】,持续更新中~~
    六、YOLO性能对比专栏【链接】,持续更新中~

    《------正文------》

    实现效果

    原始图片
    在这里插入图片描述
    使用YOLOv10检测与MobileSAM分割后的结果如下:
    在这里插入图片描述

    引言

    本文基于前沿的YOLOv10目标检测模型与轻量化分割一切的MobileSAM模型实现物体的目标检测与分割效果。本文给出了完整的实现步骤与代码详解,供小伙伴们学习。**所有相关文件、模型及相关资料均已打包,文末可免费获取。**有任何问题的话,欢迎在评论区留言讨论。

    实现步骤

    首先我们需要下载YOLOv10源码与MobileSAM源码并解压,地址如下:

    https://github.com/ChaoningZhang/MobileSAM
    https://github.com/THU-MIG/yolov10

    环境配置

    我们进入到yolov10源码的项目目录,然后使用conda进行项目虚拟环境配置:

    conda create -n yolov10 python=3.9
    conda activate yolov10
    pip install -r requirements.txt
    pip install -e .
    

    YOLOv10进行目标检测

    这里我们直接使用官方提供的yolov10n.pt进行检测,并获取检测框的位置信息,用于后续MobileSAM进行分割,代码如下:

    # 读取图像
    image = cv2.imread('test1.jpg')
    # 加载YOLOv10模型
    model = YOLOv10("yolov10_main/yolov10n.pt")
    results = model.predict(image)
    # 绘制检测结果
    results[0].show()
    # 获取结果
    res = results[0]
    # 获取检测框位置信息
    box_locations = res.boxes.xyxy.cpu().numpy().astype(int)
    print(box_locations)
    

    检测结果如下所示:
    在这里插入图片描述

    MobilseSAM进行分割

    我们将上述检测框信息作为提示信息,传入MobileSAM对目标进行分割,具体代码如下:
    加载MobileSAM模型:

    from mobile_encoder.setup_mobile_sam import setup_model
    from segment_anything import SamPredictor
    # 加载分割模型
    checkpoint = torch.load('MobileSAM-master/weights/mobile_sam.pt',map_location=torch.device('cpu'))
    mobile_sam = setup_model()
    mobile_sam.load_state_dict(checkpoint,strict=True)
    device = "cpu"
    mobile_sam.to(device=device)
    mobile_sam.eval()
    predictor = SamPredictor(mobile_sam)
    predictor.set_image(image)
    

    使用模型对目标进行分割:

    # 矩形框提示
    for box in box_locations:
        input_box = np.array([box[0], box[1], box[2], box[3]])
        masks, _, _ = predictor.predict(
            point_coords=None,
            point_labels=None,
            box=input_box[None, :],
            multimask_output=False,
        )
        # masks为布尔值
        # 显示mask
        image = add_mask(image, masks[0])
        # 显示检测框
        image = show_box(image, box)
    cv2.imshow("res", image)
    cv2.imwrite("res.jpg", image)
    cv2.waitKey(0)
    

    显示结果如下:
    在这里插入图片描述
    可以看到,MobileSAM可以很好的对YOLOv10检测后的结果进行分割。MobileSAM同样可以与其他目标检测模型以这种方式进行结合使用,达到分割目标的效果。

    好了,这篇文章就介绍到这里,感谢点赞关注,更多精彩内容持续更新中~

    资料获取

    关于本文的相关代码及数据集资料都已打包好,供需要的小伙伴们学习,获取方式如下:
    在这里插入图片描述

    关注文末名片G-Z-H:【阿旭算法与机器学习】,发送【YOLO】即可获取下载方式

  • 相关阅读:
    人工神经网络
    ESP32FreeRTOS开发笔记:1.双核并行
    一个简易的低代码
    springboot下的mybatis打印sql语句
    NarrowBERT: Accelerating Masked Language Model Pretraining and Inference
    Vue操作数组的几种常用方法(map、filter、forEach、find 和 findIndex 、some 和 every)
    nginx系列第二篇:nginx源码调试
    DevOps|1024程序员节怎么做?介绍下我的思路
    包装类知识点
    中国平安接近触底
  • 原文地址:https://blog.csdn.net/qq_42589613/article/details/139474064
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号