基于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来捕获视频流并将其传递给预测函数。
  • 在部署前,请确保所有依赖项都已经安装并且兼容。
相关推荐
DisonTangor16 分钟前
阿里通义千问开源Qwen2.5系列模型:Qwen2-VL-72B媲美GPT-4
人工智能·计算机视觉
豆浩宇17 分钟前
Halcon OCR检测 免训练版
c++·人工智能·opencv·算法·计算机视觉·ocr
LLSU1321 分钟前
聚星文社AI软件小说推文软件
人工智能
JackieZhengChina24 分钟前
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
人工智能·智能手机
ShuQiHere25 分钟前
【ShuQiHere】 探索数据挖掘的世界:从概念到应用
人工智能·数据挖掘
嵌入式杂谈25 分钟前
OpenCV计算机视觉:探索图片处理的多种操作
人工智能·opencv·计算机视觉
时光追逐者27 分钟前
分享6个.NET开源的AI和LLM相关项目框架
人工智能·microsoft·ai·c#·.net·.netcore
东隆科技27 分钟前
PicoQuant公司:探索铜铟镓硒(CIGS)太阳能电池技术,引领绿色能源革新
人工智能·能源
DisonTangor39 分钟前
上海AI气象大模型提前6天预测“贝碧嘉”台风登陆浦东 今年已多次精准预测
人工智能
人工智能培训咨询叶梓1 小时前
生成式人工智能在无人机群中的应用、挑战和机遇
人工智能·语言模型·自然语言处理·aigc·无人机·多模态·生成式人工智能