【YOLOV5 入门】——Gradio搭建Web GUI

2024-05-15 05:12
文章标签 入门 web 搭建 yolov5 gui gradio

本文主要是介绍【YOLOV5 入门】——Gradio搭建Web GUI,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引入:上节搭建的UI可视化界面只能以运行程序弹出窗口的形式运行,不能在网页Web中使用,本次代码将会非常少!


一、Gradio简介与安装

Gradio 是一个用于构建机器学习模型演示界面和Web应用的开源库。提供了简单易用的界面,使您可以快速地将机器学习模型部署为交互式应用程序,而无需编写大量的前端代码。下面是一些关于 Gradio 的主要特点和功能:

  • 简单易用:Gradio 提供了简洁直观的 API,使得用户能够轻松地创建交互式界面。

  • 多样化的输入和输出:Gradio 支持多种类型的输入和输出,包括文本、图像、视频、音频和数据框。这使得您可以将各种类型的模型部署为交互式应用程序,例如图像分类、文本生成、对象检测等。

  • 自定义界面:Gradio 允许用户自定义界面的布局和样式,以满足特定的需求。您可以轻松地调整输入和输出部件的大小、排列方式和样式。

  • 实时更新:Gradio 提供了实时更新的功能,使得应用程序能够在用户与模型进行交互的同时实时更新输出结果。

  • 多模型集成:Gradio 支持将多个模型集成到同一个应用程序中,使用户能够比较不同模型的性能和结果。

  • 部署和共享:Gradio 允许用户将创建的应用程序部署到云端或本地服务器,并生成一个分享链接,方便用户与他人共享应用程序。

Pycharm终端进入虚拟环境,pip安装:

pip install gradio


二、gradio_demo搭建Web GUI

1、简单界面

import torch
import gradio as grmodel = torch.hub.load("./", "custom", "runs/train/exp9/weights/best", source="local")
gr.Interface(inputs=["image"], outputs=["image"], fn=lambda img:model(img).render()[0]).launch()
"""
用 Gradio 创建了一个界面,该界面接受一个图像作为输入,并输出一个图像:
gradio.Interface: 这是 Gradio 中用于创建交互式界面的主要类。您可以使用它来定义输入和输出以及应用程序的行为。
inputs=["image"]: 这表示输入部分只有一个元素,类型为图像。在这个界面中,用户将能够上传一张图像作为输入。实际用的inputs=[gr.Image]类,这里由于不需要变更直接使用字符串映射实例化
outputs=["image"]: 这表示输出部分也只有一个元素,同样是图像类型。这意味着用户将得到一张图像作为输出。
fn=lambda img:model(img).render()[0]: 这是定义了应用程序行为的部分。在这里,fn 参数接受一个函数,该函数将输入图像作为参数,然后返回一个图像作为输出。在这个函数中,model(img) 调用了一个模型,该模型接受图像作为输入并返回一个结果。.render()[0] 则表示从模型返回的结果中取出第一个元素,这可能是处理后的图像。
launch(): 这是用于启动 Gradio 应用程序的方法。一旦调用了 launch(),Gradio 将根据之前定义的输入、输出和行为创建一个界面,并在默认浏览器中打开该界面,以便用户与之交互。
"""

上面是一个最基本的代码demo,运行上面代码:

ctrl+左击链接可跳转web:


2、充实界面

现在界面太单一,下面完善代码:

import torch
import gradio as grmodel = torch.hub.load("./", "custom", "runs/train/exp9/weights/best", source="local")title = "基于Gradio搭建YOLOv5检测Web GUI"
desc = "这种方式搭建的UI界面代码量很少,不要太方便!!!"base_conf,base_iou = 0.35, 0.55  #定义一个基准的conf和iou参数,刚打开会设置为这个,点击web界面“clear”按钮也可返回默认值def det_image(img, conf_thresh, iou_thresh):model.conf = conf_thresh  #将滑动条对应的conf和iou参数给modelmodel.iou = iou_threshreturn model(img).render()[0]gr.Interface(inputs=["image",gr.Slider(minimum=0,maximum=1, value=base_conf),gr.Slider(minimum=0,maximum=1,value=base_iou)], #inputs=["image","slider", "slider"]slider为调整conf和iou参数的滑动条,默认时0-100,需要调整所以没用这种写法outputs=["image"],fn=det_image,title=title,description=desc).launch()

如果还想添加功能可继续完善下面函数,比如可以添加几张可供选择的示例图片:

.....
gr.Interface(inputs=["image",gr.Slider(minimum=0,maximum=1, value=base_conf),gr.Slider(minimum=0,maximum=1,value=base_iou)], #inputs=["image","slider", "slider"]slider为调整conf和iou参数的滑动条,默认时0-100,需要调整所以没用这种写法outputs=["image"],fn=det_image,title=title,description=desc,examples = [["./datasets/images/train/y.png", base_conf, base_iou],["./datasets/images/train/l.png", base_conf, base_iou]]).launch()

如果说想调用摄像头检测,可把input参数做调整:

....
gr.Interface(inputs=[gr.Webcam(),gr.Slider(minimum=0,maximum=1, value=base_conf),gr.Slider(minimum=0,maximum=1,value=base_iou)], #inputs=["image","slider", "slider"]slider为调整conf和iou参数的滑动条,默认时0-100,需要调整所以没用这种写法outputs=["image"],fn=det_image,title=title,description=desc,examples = [["./datasets/images/train/y.png", base_conf, base_iou],["./datasets/images/train/l.png", base_conf, base_iou]]).launch()

如果不想要每次点击submit提交,可以加一个参数live =True:

...
gr.Interface(inputs=["image",gr.Slider(minimum=0,maximum=1, value=base_conf),gr.Slider(minimum=0,maximum=1,value=base_iou)], #inputs=["image","slider", "slider"]slider为调整conf和iou参数的滑动条,默认时0-100,需要调整所以没用这种写法outputs=["image"],fn=det_image,title=title,description=desc,live= True,examples = [["./datasets/images/train/y.png", base_conf, base_iou],["./datasets/images/train/l.png", base_conf, base_iou]]).launch()

如果想将其生成一个地址,在公网的任何地方点击都可运行,可指定launch的参数share=True,这样其他人也可通过链接进行使用:

.....
gr.Interface(inputs=["image",gr.Slider(minimum=0,maximum=1, value=base_conf),gr.Slider(minimum=0,maximum=1,value=base_iou)], #inputs=["image","slider", "slider"]slider为调整conf和iou参数的滑动条,默认时0-100,需要调整所以没用这种写法outputs=["image"],fn=det_image,title=title,description=desc,live= True,examples = [["./datasets/images/train/y.png", base_conf, base_iou],["./datasets/images/train/l.png", base_conf, base_iou]]).launch(share=True)

由于服务器在国外,链接什么的加载较慢,可自行试验!

这种是最基础的Web GUI设计方法,如果有更多复杂需求可以使用其他工具!


往期精彩

STM32专栏(9.9)icon-default.png?t=N4N7http://t.csdnimg.cn/A3BJ2

OpenCV-Python专栏(9.9)icon-default.png?t=N4N7http://t.csdnimg.cn/jFJWe

AI底层逻辑专栏(9.9)icon-default.png?t=N4N7http://t.csdnimg.cn/6BVhM

机器学习专栏(免费)icon-default.png?t=N4N7http://t.csdnimg.cn/ALlLlSimulink专栏(免费)icon-default.png?t=N4N7http://t.csdnimg.cn/csDO4电机控制专栏(免费)icon-default.png?t=N4N7http://t.csdnimg.cn/FNWM7 

这篇关于【YOLOV5 入门】——Gradio搭建Web GUI的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/990903

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成