ThinkBell project, which is made from 2021 Woongjin Thinkbig Industry-Academic Cooperation Project Team.
-
클라이언트별로 python 클라이언트를 구동해야 합니다. flask 폴더로 진입하여 python server.py 커맨드를 입력해 주세요.
-
만약 서버를 오픈해야 한다면, webrtc 폴더로 진입하여 npm이 설치되어있지 않다면 먼저 npm install 커맨드를 입력 후에 npm start를 입력합니다. 이렇게 함으로써 서버가 오픈되게 됩니다.
-
서버를 열고 나서, 혹은 누군가가 서버를 열었다면 해당 ngrok 주소를 브라우저에 입력하여 브라우저 상에서 화상 회의 통신이 이루어집니다. 만약 로컬에서만 테스트하고 싶다면, https://localhost:3012 를 입력하세요. 크롬 브라우저를 권장합니다.
-
접속이 되었다면, python 클라이언트에서 통신이 잘 되고 있는지 로그를 확인해 주세요.
시스템은 webrtc 통신을 중심으로 구동되며, js webrtc 모듈은 python 영상 처리 클라이언트에게 처리할 이미지를 Frame 단위로, js 상에서 구동되는 AI Agent 모듈에게 Stream 리소스를 제공합니다. 영상 처리 클라이언트가 분석을 마치고 결과값을 js AI Agent에 리턴하면, AI Agent가 Front-End와 통신하며 결과값을 시각적으로 표현합니다.
현재 리포지토리에 담겨 있는 코드는 python 클라이언트를 담당하는 flask 폴더와, js 클라이언트와 서버를 담당하는 webrtc 폴더 크게 두 가지 파트로 구분되어 있습니다.
flask 폴더는 다음과 같이 구성되어 있습니다.
- MediaPipeProcess.py: Google MediaPipe 모듈을 이용하는 모든 영상 처리 모듈이 이곳에서 이루어집니다.
- VoiceActivityDetection.py: VAD 알고리즘을 활용해 발화 인식이 이곳에서 이루어집니다.
- daiseecnn.py: DAiSEE 데이터셋을 활용해 Engagement를 측정합니다.
- object_detection_api.py: 앞에서 나왔던 처리 결과값들을 모두 한데 모아 Threshold와 각종 몰입도 측정 알고리즘을 이용하여, flask 서버에 json 형식으로 최종 몰입도 결과값을 리턴하는 핵심 python 파일입니다.
- server.py: flask 서버를 오픈합니다. 이 flask 서버는 로컬 전용으로 webrtc 모듈과 통신하기 위해서만 존재하며, 외부 클라이언트와 통신하지 않습니다.
webrtc 폴더는 다음과 같이 구성되어 있습니다.
- ssl 폴더: 인증을 위한 키 파일이 들어 있습니다.
- src 폴더: WebRTC 통신을 구동하는 폴더입니다.
- public 폴더: Front-End와 Flask 폴더와의 통신부, AI Agent가 들어 있는 핵심 폴더입니다.
webrtc/public 폴더는 다음과 같이 구성되어 있습니다.
- index.html: Front-End가 보여지는 파일입니다.
- img, neuralNets, pacman: 팩맨 게임 Agent를 위해 구성된 파일들입니다.
- js: Flask 폴더와 통신하고, index.html과 상호작용하는 AI Agent가 들어 있는 핵심 폴더입니다.
webrtc/public/js 폴더는 다음과 같이 구성되어 있습니다.
- HeadControls.js: 팩맨 게임 에이전트에서 고개 각도 측정을 위해 사용됩니다.
- back.js: 보상 기반 AI Agent를 관장하는 코드입니다.
- broadcast.js: 다른 외부 클라이언트들과 status 통신을 위해 사용됩니다.
- client.js: AR Image Rendering을 위해 사용됩니다.
- jeelizFaceFilter.js: Face Filter 이용 API입니다.
- temp.js: Front-End에 직접 표시되어 있는 기능들을 관할합니다.
- main.js: WebRTC통신을 관장하는 코드입니다.
- objDetect.js: python flask 서버가 5000번 포트를 이용하여 전송한 처리 결과값을 받아서 AI Agent에 리턴하는 역할을 수행합니다.
- pacman.js, pacmanMain.js: 팩맨 게임 에이전트 전체를 관할합니다.
- 2021 SW 인재페스티벌 대상 - 과학기술정보통신부 장관상
- 2021 성균관대학교 산학협력프로젝트 하계 발표회 아이디어 주제상, 우수 발표상
- 2021 성균관대학교 산학협력프로젝트 최종 발표회 AI 트랙 우수상