基于YOLOv8的暴力行为分类系统

本项目旨在通过计算机视觉技术实现暴力行为的实时监测和分类。利用先进的目标检测算法YOLOv8,结合Streamlit开发的前端界面,该系统能够高效地从图像或视频中识别出暴力行为,并及时报警。系统支持对实时摄像头输入进行分析,以及上传的图像和视频文件。

技术栈:
  • YOLOv8: 目标检测模型,用于检测图像中的物体。
  • Streamlit: Python Web应用框架,用于构建用户界面。
功能特点:
  • 支持图片、视频及实时摄像头输入。
  • 实现暴力行为与正常行为的二分类。
  • 提供直观的用户界面,便于操作和监控。
混淆矩阵示例(假设数据):
复制代码
          预测值
          正常  暴力
实际值
正常   95    5
暴力   10   85

这表明模型在测试集上具有较高的准确率,其中95%的正常行为被正确分类为正常,而85%的暴力行为被正确识别。

关键代码示例

下面是一些关键代码片段,包括如何使用YOLOv8进行预测以及如何用Streamlit构建用户界面。

YOLOv8预测代码

首先确保安装了ultralytics库:

复制代码
pip install ultralytics

然后编写预测函数:

复制代码
from ultralytics import YOLO

def predict(image_path, model):
    """
    使用YOLOv8模型进行预测。
    :param image_path: 图像路径
    :param model: 加载的YOLOv8模型
    :return: 预测结果
    """
    results = model.predict(image_path)
    return results[0].boxes.cls
Streamlit前端代码

创建一个简单的Web应用:

复制代码
import streamlit as st
from PIL import Image
import torch

# 加载模型
model = YOLO('path/to/yolov8_model.pt')

# Streamlit应用
st.title("暴力行为分类系统")

# 文件上传
uploaded_file = st.file_uploader("上传图片或视频", type=["jpg", "jpeg", "png", "mp4"])

if uploaded_file is not None:
    # 保存上传的文件到临时目录
    temp_file_path = f"temp_{uploaded_file.name}"
    with open(temp_file_path, mode='wb') as f:
        f.write(uploaded_file.read())

    # 显示上传的文件
    if uploaded_file.name.endswith(('jpg', 'jpeg', 'png')):
        image = Image.open(uploaded_file)
        st.image(image, caption='Uploaded Image.', use_column_width=True)
    elif uploaded_file.name.endswith('mp4'):
        st.video(uploaded_file)

    # 进行预测
    predictions = predict(temp_file_path, model)

    # 输出预测结果
    if 0 in predictions:
        st.write("预测结果: 正常")
    elif 1 in predictions:
        st.write("预测结果: 暴力")
    else:
        st.write("无法识别的行为")

注意事项

  • 上述代码需要根据实际情况调整模型路径等细节。
  • 对于实时摄像头的支持,您可以使用OpenCV来捕获视频流并将其传递给预测函数。
  • 在部署前,请确保所有依赖项都已经安装并且兼容。
相关推荐
studytosky6 分钟前
深度学习理论与实战:MNIST 手写数字分类实战
人工智能·pytorch·python·深度学习·机器学习·分类·matplotlib
做萤石二次开发的哈哈11 分钟前
11月27日直播预告 | 萤石智慧台球厅创新场景化方案分享
大数据·人工智能
AGI前沿15 分钟前
AdamW的继任者?AdamHD让LLM训练提速15%,性能提升4.7%,显存再省30%
人工智能·算法·语言模型·aigc
后端小肥肠34 分钟前
小佛陀漫画怎么做?深扒中老年高互动赛道,用n8n流水线批量打造
人工智能·aigc·agent
是店小二呀34 分钟前
本地绘图工具也能远程协作?Excalidraw+cpolar解决团队跨网画图难题
人工智能
i爱校对1 小时前
爱校对团队服务全新升级
人工智能
KL132881526931 小时前
AI 介绍的东西大概率是不会错的,包括这款酷铂达 VGS耳机
人工智能
vigel19901 小时前
人工智能的7大应用领域
人工智能
人工智能训练1 小时前
windows系统中的docker,xinference直接运行在容器目录和持载在宿主机目录中的区别
linux·服务器·人工智能·windows·ubuntu·docker·容器
南蓝1 小时前
【AI 日记】调用大模型的时候如何按照 sse 格式输出
前端·人工智能