Git Product home page Git Product logo

landmark-service's Introduction

Seoul Mate

Project Member

이름 역할
박지수 프론트엔드
조원일 프론트엔드
선혜주 인공지능/중간 발표
임동현 인공지능
홍지운 백엔드
이상원 백엔드/팀장/최종 발표

기술 스택

Position Languages & Tools README
Frontend ReactJS FrontEnd
Backend NestJS
MySQL
BackEnd
Artificial intelligence Python
Tensorflow
Ai
Deploy docker

협업 도구

  • Gitlab: 프로젝트 코드 저장소, webhook을 이용해 Merge Request 발생 시 discord 푸시 사용
  • Discord: 팀 공지사항, 아이디어 회의, Merge Request 발생 확인
  • Figma: 디자인 회의, 아이디어 회의, 스크럼에 활용

애자일 방법론: scrum

  • 화 ~ 토 오전 10시 scrum 진행
  • 각자 개발하고 있는 부분의 진행도를 공유

기획 의도

서비스 목표

코로나 19의 완화로 국외 여행길이 열리면서 외국인 관광객이 증가할 것으로 예상됩니다. 단순히 여행객들이 랜드마크에서 사진만 찍고 끝나는 것이 아닌 랜드마크의 정보를 제공하고, 랜드마크 방문 시 스탬프를 찍어 여행을 게임처럼 재밌게 느낄 수 있는 경험을 제공합니다.

Seoul Mate는 한국의 랜드마크를 방문, 스탬프를 얻어 여행 레벨을 높일 수 있습니다. 게임의 퀘스트를 진행하는 느낌을 주며, 다양한 랜드마크에 방문할 수 있는 기회를 제공합니다.

[연합뉴스] "다시 한국으로"...끊어진 외국인 관광객 유치 총력전

서비스의 콘텐츠

랜드마크 예측: 메인 기능

Seoul Mate에서는 랜드마크의 사진을 찍어 업로드 하게 되면 어떤 랜드마크인지 알려줍니다. 랜드마크에 대한 주소, 카테고리, 설명을 얻을 수 있습니다.

스탬프와 경험치: 서브 기능

Seoule Mate에서는 랜드마크를 방문 후 사진을 찍어 기록할 수 있습니다. 사용자는 사진을 찍어 어떤 랜드마크인지 알 수 있으며, 방문한 랜드마크가 기록됩니다. 사용자는 사진을 찍은 후 게시글에 공유할 수 있습니다.

게시글을 작성하면 경험치가 오르고 경험치에 따른 등급이 주어지게 됩니다.

서울에 어떤 랜드마크가 있을까?: 서브 기능

Seoul Mate의 메인 페이지에서는 방문자가 많은 랜드마크를 보여주며, 서비스에서 제공하는 랜드마크의 위치가 지도로 제공됩니다.

사용된 데이터와 인공지능 모델

시용한 데이터

  • AI 허브 랜드마크 이미지

    인공지능 기반의 컴퓨터 비전 기술 및 서비스 개발에 활용하기 위해 국내 특성(지리 공간적, 기능적)이 반영된 국내 도심 민간건물, 공공기관, 관광명소, 편의시설 등 국내 도시별 주요 랜드마크 이미지 데이터 구축(출처: AI허브)

  • 데이터셋 Training 폴더 구조

├─[원천]서울특별시_001
│  ├─3.1독립선언기념탑
│  ├─4.19학생혁명기념탑
│  ├─경복궁
│  └─ ...
├─[원천]서울특별시_002
│  ├─동십자각
│  ├─망원정지
│  ├─명동성당
│  └─ ...
│ ...
├─[라벨]서울특별시
│  └─서울특별시
│      ├─150년수령느티나무
│      ├─3.1독립선언기념탑
│      ├─4.19학생혁명기념탑
│      └─ ...

  • annotation 파일
{
    "info": {
        "description": "2020 landmark Dataset",
        "url": "https://aihub.or.kr/aidata/8009",
        "version": "1.0",
        "year": 2020
    },
    "licenses": [
        {
            "possession": "PCN컨소시엄",
            "id": 1
        }
    ],
    "images": [
        {
            "license": 1,
            "file_name": "3.1독립선언기념탑_039_41544868.jpg",
            "width": 4032,
            "height": 2268,
            "image_id": 41544868
        }
    ],
    "annotations": [
        {
            "type": "Bounding box",
            "category_id": 15919,
            "bbox": [
                1115.06,
                768.19,
                3113.64,
                1877.7
            ],
            "image_id": 41544868,
            "id": "41544868_1",
            "truncated": "0",
            "hidden": "0",
            "light_reflex": "0",
            "na": "1"
        }
    ],
    "categories": [
        {
            "id": 15919,
            "name": "3.1독립선언기념탑",
            "supercategory": "지역상징성",
            "metainfo": {
                "location1": "서울특별시",
                "location2": "서대문구",
                "Type1": "지역상징성",
                "Type2": "기념비",
                "name_kr": "3.1독립선언기념탑",
                "add": "서울특별시 서대문구 현저동 101"
            }
        }
    ]
}

데이터 전처리

데이터 선별

데이터 셋에 아파트나 상가 건물과 같은 주요 랜드마크로 볼 수 없는 것들은 제외하고 관광지 위주의 랜드마크를 선정했습니다.

ex) 제거한 데이터셋

  • 라온

  • 메트로팜

  • 카이스트 서울캠퍼스

노이즈 제거

ex) 돌담 위주의 이미지로 구성된 서울 한양 도성 클래스에서 간판 이미지는 노이즈라 판단하여 제거했습니다.

  • 정상 이미지


  • 노이즈

EDA

  • 클래스 개수: 112개

  • 클래스 별 이미지 개수

    Min: 69, Max: 263, Mean: 147

  • 장소 별 클래스 개수

  • subcategory 별 클래스 개수

  • supercategory 별 클래스 개수

인공지능 모델

YOLO: object detection

랜드마크를 예측하는 인공지능 모델은 YOLO모델을 사용합니다. 모델의 inference 속도를 고려해 one stage detector로 실험을 진행합니다. 랜드마크를 object detection을 사용하여 boundary box를 예측, 하나의 랜드마크 객체를 탐지합니다.

프로젝트 구조

데이터베이스 구조도

스크린샷 2022-07-02 오전 10 52 32

와이어 프레임

Figma url

어려웠던 점 및 해결 방법

FrontEnd

조원일

  1. 1차 프로젝트 때 썼던 axios 통신 관련 api 스켈레톤 코드를 썼습니다 백엔드에서 데이터를 받는 양식에 따라 프론트에서 데이터를 보내주는 방식이 달라져서 기존 스켈레톤 코드로는 제대로 작동이 안되는 것들이 많아 axios 통신 양식에 대해 깊이 있게 공부하게 되었습니다

  2. 하나의 핸들러에서 여러개의 api통신을 연달아 수행 할 때 데이터를 받아 다음 api통신 req 데이터에 넘겨줘야 하는 코드를 짜고 있었는데 자바스크립트의 비동기 처리 방식 및 백에서 데이터를 처리하는 속도 등 여러가지 고려사항들이 많았습니다. asyc/await로 동기 처리를 하는 방법을 확실히 알 수 있게 되었고, setTimeout으로 특정 과정에 딜레이를 줘서 데이터를 처리하는 등 다양한 방법에 대해 알 수 있었습니다.

  3. recoil로 전역 관리를 하는 데이터가 있었는데, defalut값을 설정 안해줘서 작동이 제대로 안되었었습니다. 에러메세지가 딱히 뜨지 않아 코드를 하나하나 세세하게 살펴보다가 꼭 defalut 값을 설정해줘야 된다는 사실을 알게되었습니다.

  4. 전체 댓글 데이터를 불러와서 하나씩 맵핑하여 뿌려주는 코드를 작성 중 댓글 수정 시 원하는 댓글 데이터만 상태값을 변경해야하는 상황이 있었습니다. 맵핑 시 idx값을 지정해주고, 각 댓글 데이터에 editable이라는 새로운 KEY값을 넣어주어 각 댓글 데이터 별로 상태관리를 할 수 있었습니다

박지수

  1. 카카오맵 API를 사용해 유저정보를 불러오던중 user정보가 제대로 불러와 지지 않았다. 아직까지 user api를 제대로 이해하지 못해 user정보를 불러오기 위해 api로 직접 호출하는 대신 recoil을 사용하여 유저정보를 호출하였습니다

  2. 프로필 수정시 랜더링이 일어나지 않고 새로 고침을 해야 랜더링이 일어났습니다. 이 부분은 아직까지 userEffect부분을 활용하는데 문제가 있었습니다. 프론트엔드 오피스아워 시간을 활용해서 userEffect와 비동기 처리를 제대로 이해하고 적용해서 새로고침을 하지 않아도 비동기적으로 수정할 수 있었습니다.

BackEnd

이상원

  1. Node js에서 사용했던 로그인 검증 미들웨어를 Nest js의 auth guard로 변경하는 과정에서 학습이 필요했습니다. 공식 문서를 보고 오피스아워 시간을 활용해 정확히 이해하고 로그인 검증 기능을 구현할 수 있었습니다.
  2. 데이터베이스로 MYSQL을 사용했습니다. 테이블 간의 관계성을 이용한 설계에 어려움이 있었습니다. 설계 이후에도 typeorm에서 외래키 설정과 cascade 옵션을 주는 부분에서 공식 문서를 활용해 여러번 테스트를 하여 해결했습니다.

Artificial Intelligence

선혜주

  1. 데이터를 정제하는 작업과 불균형 문제를 다루는게 시간이 많이 걸려서 어려움이 있었습니다. 인공지능 파트 팀원과 분배하여 작업하였고, 불균형 문제는 focal loss 사용하여 해결했습니다.

임동현

  1. 많이 해보지 않은 분야라서 하나부터 열까지 다 어려웠습니다. 오피스 아워 질문이나 열심히 구글링을 통해 하나하나 배워가면서 많은 오류를 해결 하였습니다.

landmark-service's People

Contributors

donghyeonlim avatar hongloans avatar hyejuseon avatar knowbaesu avatar monglong0214 avatar nowgnas avatar sunghyunkwon avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.