✔ Unitiy 가상공간 속에서 KoGPT2 모델 기반의 챗봇을 카프카와 연동시켜 구현하였다.
✔ KoGPT2 모델이란, 주어진 단어를 통해 다음 단어를 예측하는 학습모델이다. 이는 문장 생성에 최적화되어 있다.
✔ 프로젝트 기간: 22/03/14 ~ 22/04/01
✔ 최종 PPT 링크: https://drive.google.com/file/d/1zLnQs3izegjii2x778iMkhbLdDm77Y7-/view?usp=sharing
1️⃣ Unity 가상공간에서 다양한 캐릭터를 기반한 메타버스를 구현하였다. 캐릭터를 이동하며 마치 게임을 하는 듯한 시각적인 효과를 즐길 수있다. 한, 포털을 통해 웹사이트로 이동하는 기능도 구현하였다.
2️⃣ 가상공간 속에서 머신러닝으로 학습된 챗봇과 일상, 감정대화를 나눌 수 있다.
3️⃣ 클라이언트와 챗봇과의 대화는 Kafka를 통해 주고 받는다.
4️⃣ 일정주기를 반복하여 대화한 내용을 Spark와 Hadoop에 저장한다. 저장한 데이터를 바탕으로 챗봇을 재학습시킨다.
🔹 김세진: 딥러닝 코드를 Spark로 재학습 (sparkML), Hadoop 클러스터에 대용량 DB저장
🔹 김예빈: 인공지능 NLP AI 설계 및 학습, 채팅 내역으로 재학습 코드 구현, Kafka 데이터 송수신, PPT
🔹 장규호: Hadoop 클러스터에 대용량 DB저장, 학습 데이터셋 선정 및 추출 가공
🔹 장서현: Unity 환경 개발, Kafka 데이터 송수신, Photon 서버 클라이언트 환경 추가, ELK로 시각화
시스템 | CPU | 메모리 | HDD | 프로그램 버전 | 비고 |
---|---|---|---|---|---|
Kafka broker | 1 | 2.0GB | 20GB | 2.13 | Vmware |
Kafka Producer 1 | 2 | 16.0GB | 100GB | 2.13 | Vmware |
Kafka Consumer 1 | 1 | 4.0GB | 20GB | 2.13 | Vmware |
Kafka Producer 2 | 1 | 1GB | 20GB | 2.13 | Vmware |
Kafka Consumer 2 | 1 | 1.0GB | 20GB | 2.13 | Vmware |
Spark master | 4 | 16.0GB | 422GB | 3.1.3 | 컴퓨터 |
Spark worker1 | 2 | 8.0GB | 50GB | 3.1.3 | Vmware |
Spark worker2 | 2 | 8.0GB | 50GB | 3.1.3 | Vmware |
Hadoop master | 4 | 16.0GB | 421.0GB | 3.2.2 | 컴퓨터 |
Hadoop worker1 | 2 | 8.0GB | 50.0GB | 3.2.2 | Vmware |
Hadoop worker2 | 2 | 8.0GB | 50.0GB | 3.2.2 | Vmware |
Unity | 2 | 16.0GB | 100GB | 2020.3.30f1 | 노트북 |
Photon | 2 | 16.0GB | 100GB | photon unity networking2 | 노트북 |
Logstash | 4 | 8.0GB | 100GB | 7.17.1 | 노트북 |
Elasticsearch | 2 | 4.0GB | 20GB | 7.17.1 | Vmware |
Kibana | 2 | 4.0GB | 20GB | 7.17.1 | Vmware |
🔹 Producer 1과 Consumer 1은 질문을 받을 때, Producer 2와 Consumer 2는 답변을 보낼 때 사용
Topic | Producer | Consumer | Context | 비고 |
---|---|---|---|---|
bot_question | Unity Server | Machine learning test | 클라이언트 질문 | Question |
ChatbotA | Machine learning test | Unity Server | 챗봇 답변 | Answer |
ChatbotB | Machine learning test | Unity Server | 챗봇 답변 | Answer |
ChatbotC | Machine learning test | Unity Server | 챗봇 답변 | Answer |
스파크 폴더 내에 chatbot.py 파일 참조