Skip to content

Latest commit

 

History

History
135 lines (91 loc) · 5.93 KB

README.md

File metadata and controls

135 lines (91 loc) · 5.93 KB

WatchDuck

프로젝트 주제

실시간 CCTV 도난 의심 행동 감지 앱

선정 배경

24시간 무인으로 운영되는 매장에서의 도난 범죄에 신속히 대응하기 위해 특정 매장에 특화된 도난 의심 행동 감지 모델을 만들고자 함

기대 효과

  • 실시간으로 도난 의심 알림을 받아 실제 도난이 발생하기 전 조치를 취할 수 있음
  • 도난 의심 행동 구간을 따로 확인할 수 있어 모든 CCTV 영상을 볼 필요가 없어 사용자 피로도 감소에도 효과적임

1. Dataset

AI-Hub 실내 사람 이상행동 데이터

  • Format: 영상 이미지
  • Labeling: 물건을 가방이나 주머니에 넣는 순간을 Doubt, 그 외 모든 구간은 Normal
  • 801개의 데이터 중 무인매장에 적합한 583개의 데이터를 선별 후 사용

2. Model

🔧 Pytorch

image

  • 구조: CNN+RNN

    • CNN: 클립 영상의 프레임 별 feature 추출
    • RNN: CNN의 output을 입력으로 받아 영상 속 행동 맥락을 파악한 후 결과를 예측

    MobileNet_v2 + GRU

2.1. Process

2.1.1. Training

  • Dataset: Normal과 Doubt 클립을 같은 비율로 추출
  • 한 클립의 프레임들을 한 번에 모델에 통과시킨 후 마지막 프레임 기준으로 클립 클래스 예측, 예측된 클래스와 정답 클래스 비교

2.1.2. Validation

  • Dataset: validation 영상을 학습 데이터 클립과 같은 길이로 1초마다 샘플링

2.1.3. Inference

  • 실시간 스트리밍 영상을 0.1초 간격으로 프레임을 샘플링하여 버퍼에 저장
  • 1초마다 버퍼에서 학습 데이터 클립과 같은 길이로 프레임을 가져와 inference 진행
  • 프레임 샘플링 작업과 추론 작업은 개별 스레드로 진행되어 실시간 추론 가능
  • Doubt 클래스로 예측한 경우 확률값과 함께 backend로 결과 전달

3. Frontend

🔧 Figma React Native Expo

  • Figma: 디자인 툴로 사용, 댓글 기능 활용 1차, 2차 피드백을 거치며 디자인/기능적 합의
  • Expo: Android, iOS, Web 모두 같은 코드로 호환 가능한 개발
  • 푸시 알림: Polling 방식을 사용하여 새 도난 탐지 기록 발생 시 푸시 알림 발생

3.1.페이지 목록

페이지명 페이지 상세 기능
회원가입 1. 약관 동의
2. 이메일 인증
3. 비밀번호 입력
4. URL 등록
5. 매장 이름 등록
6. 사용자 이름 등록
로그인 1. 로그인
Tab1 도난 탐지 기록 도난 탐지 기록 리스트 기본 화면
1. 검색 기능(날짜, CCTV 이름으로 검색)
도난 탐지 기록별 상세 리스트의 각 아이템 클릭 시 상세 페이지로 이동
1. 피드백 남기기
2. 영상 다운로드
3. 기록 삭제하기
Tab2 실시간 스트리밍 최대 16개 CCTV 동시 스트리밍 가능
1. 각 CCTV 클릭 시 전체화면
Tab3 설정화면 CCTV 설정 1. CCTV 등록
2. CCTV 수정(이름, URL)
3. CCTV 삭제
알림/동영상 설정 1. 알림 임계값 조회 및 수정
2. 저장되는 동영상 시간 조회 및 수정
개인정보 설정 1. 비밀번호 수정 (기존 비밀번호 확인 후 새 비밀번호 등록)
2. 매장명 수정

4. Backend

🔧 FastAPI Redis

4.1. DB(PostgreSQL) & ORM(SQLAlchemy)

  • DB Schema

image

4.2. API

  • a.b.c 형식으로 Versioning하여 API 명세서 관리
    • a : 배포
    • b : 백-프론트 합의
    • c : 백 또는 프론트에서 개별 업데이트
  • member, cctv, streaming, settings의 네 개 분류로, 총 20개의 API 이용

5. Pipeline

5.1. Streaming Pipeline

image

5.2. Inference Pipeline

image

팀 소개


박진영

선경은

강현서

김정택

이선우

최현우
Model Model Frontend Frontend Backend Backend