丢垃圾视频时间检测 -- 基于状态机的实现

文章目录

Overview

需要考虑的方面

  • 状态定义和转换条件
  • 时序约束
  • 空间约束
  • 异常处理

状态机的设计需要考虑的场景:

  • 没有人
  • 人进入
  • 人携带垃圾
  • 人离开但垃圾留下
  • 垃圾消失
  • 异常情况(检测失败、多人多垃圾等)

Key Points

状态设计

  • NO_PERSON: 初始状态,场景为空
  • PERSON_ONLY: 检测到人
  • PERSON_WITH_LITTER: 人和垃圾共同出现
  • LITTER_ONLY: 人离开,垃圾留下

状态转移路径

NO_PERSON => PERSON_ONLY => PERSON_WITH_LITTER => LITTER_ONLY

状态转移条件

  • NO_PERSON -> PERSON_ONLY: 检测到人
  • PERSON_ONLY -> NO_PERSON: 人消失
  • PERSON_ONLY -> PERSON_WITH_LITTER: 人靠近垃圾
  • PERSON_WITH_LITTER -> LITTER_ONLY: 人离开但垃圾留下
  • PERSON_WITH_LITTER -> PERSON_ONLY: 垃圾消失
  • LITTER_ONLY -> NO_PERSON: 垃圾消失

约束条件

  • 空间约束:人和垃圾的距离阈值
  • 时间约束:状态持续时间的上下限
  • 检测约束:目标检测的置信度阈值
  • 异常处理
    • 状态超时重置
      • PERSON_WITH_LITTER 的持续时间过长,截断当前帧为结束帧
    • 多目标情况处理
      • 遍历每个 (Person - Litter) Pair, 找到距离最近的 Pair.

Pseudo-code

复制代码
定义 状态枚举:
    NO_PERSON = 0        # 场景中没有人和垃圾
    PERSON_ONLY = 1      # 只有人
    PERSON_WITH_LITTER = 2  # 人和垃圾共同出现
    LITTER_ONLY = 3      # 只有垃圾

定义 类 LitteringDetector:
    属性:
        current_state: 当前状态
        frame_start: 事件开始帧
        frame_end: 事件结束帧
        state_duration: 当前状态持续时间
        
        # 配置参数
        MAX_DISTANCE: 人和垃圾的最大距离阈值
        MIN_DURATION: 状态持续最小帧数
        MAX_DURATION: 状态持续最大帧数
        
    方法 初始化():
        current_state = NO_PERSON
        frame_start = None
        frame_end = None
        state_duration = 0
        
    方法 检测单帧(frame, frame_id):
        # 1. 目标检测
        persons = 检测人物()
        litters = 检测垃圾()
        
        # 2. 状态转移逻辑
        如果 current_state == NO_PERSON:
            如果 检测到人:
                转换到 PERSON_ONLY
                重置状态持续时间
                
        否则如果 current_state == PERSON_ONLY:
            如果 没有检测到人:
                转换到 NO_PERSON
            否则如果 检测到人和垃圾且距离小于阈值:
                转换到 PERSON_WITH_LITTER
                记录开始帧 frame_start
                
        否则如果 current_state == PERSON_WITH_LITTER:
            如果 没有检测到人但检测到垃圾:
                转换到 LITTER_ONLY
                记录结束帧 frame_end
                返回检测到丢垃圾事件
            否则如果 没有检测到垃圾:
                转换到 PERSON_ONLY
                
        否则如果 current_state == LITTER_ONLY:
            如果 没有检测到垃圾:
                转换到 NO_PERSON
                
        # 3. 更新状态持续时间
        state_duration += 1
        
        # 4. 状态超时检查
        如果 state_duration > MAX_DURATION:
            重置到初始状态 NO_PERSON
            
        返回 未检测到事件

    方法 检查空间关系(person, litter):
        计算人和垃圾的距离
        返回 距离 < MAX_DISTANCE
相关推荐
摘取一颗天上星️9 分钟前
NLP进化史:从规则模板到思维链推理,七次范式革命全解析
人工智能·自然语言处理
知舟不叙36 分钟前
深度学习——基于PyTorch的MNIST手写数字识别详解
人工智能·pytorch·深度学习·手写数字识别
Jamence39 分钟前
多模态大语言模型arxiv论文略读(118)
论文阅读·人工智能·语言模型·自然语言处理·论文笔记
愚农搬码42 分钟前
LangChain 调用不同类型的多MCP服务
人工智能·后端
AI速译官1 小时前
字节跳动推出视频生成新模型Seedance
人工智能
chenquan2 小时前
ArkFlow 流处理引擎 0.4.0-rc1 发布
人工智能·后端·github
Se7en2582 小时前
使用 Higress AI 网关代理 vLLM 推理服务
人工智能
AI大模型技术社2 小时前
PyTorch手撕CNN:可视化卷积过程+ResNet18训练代码详解
人工智能·神经网络
CSTechEi2 小时前
【IEEE/EI/Scopus检索】2025年第六届模式识别与数据挖掘国际会议 (PRDM 2025)
人工智能·数据挖掘·模式识别·ei学术会议
明明跟你说过3 小时前
FastChat 架构拆解:打造类 ChatGPT 私有化部署解决方案的基石
人工智能·语言模型·chatgpt·openai