# MMDetection setting
conda create -n mmdet python=3.7 -y
conda install pytorch==1.7.1 torchvision==0.8.2 torchaudio==0.7.2 cudatoolkit=10.1 -c pytorch -y
pip install openmim
mim install mmdet
# YOLOv5 setting
conda create -n yolov5 python=3.8 -y
conda install pytorch==1.7.1 torchvision==0.8.2 torchaudio==0.7.2 cudatoolkit=10.1 -c pytorch -y
cd yolov5
pip install -r requirements.txt
python example.py --datasets COCO --img_path ../dataset/train/ --label ../dataset/train.json --convert_output_path ../dataset/ --img_type ".jpg" --manifest_path ./ --cls_list_file recycle.names
Install Requirements
pip install -r requirements.txt
cd yolov5-master
python train.py --img 1024 --batch 4 --multi-scale --data data/recycle.yaml --weights yolov5x6.pt
cd /mmdetection_PVT
# pip install -v -e . 실행
python tools/train.py configs/boostcamp_trash_PVTv2_b3_custom/final.py
cd /mmdetection
python tools/train.py configs/boostcamp/universenet101_gfl_fp16_4x4_mstrain_480_960_2x_coco.py
cd /mmdetection_Swin
# pip install -v -e . <- 실행
python tools/train.py configs/boostcamp/temp/cascade_rcnn_swin-s-p4-w7_fpn_ms-crop-3x_coco.py
python ensemble.py ensemble.json
서희수 |
황원상 |
조혜원 |
홍요한 |
박준혁 |
박범수 |
한건우 |
바야흐로 대량 생산, 대량 소비의 시대. 우리는 많은 물건이 대량으로 생산되고, 소비되는 시대를 살고 있습니다. 하지만 이러한 문화는 '쓰레기 대란', '매립지 부족'과 같은 여러 사회 문제를 낳고 있습니다.
분리수거는 이러한 환경 부담을 줄일 수 있는 방법 중 하나입니다. 잘 분리배출 된 쓰레기는 자원으로서 가치를 인정받아 재활용되지만, 잘못 분리배출 되면 그대로 폐기물로 분류되어 매립 또는 소각되기 때문입니다.
따라서 우리는 사진에서 쓰레기를 Detection 하는 모델을 만들어 이러한 문제점을 해결해보고자 합니다. 문제 해결을 위한 데이터셋으로는 일반 쓰레기, 플라스틱, 종이, 유리 등 10 종류의 쓰레기가 찍힌 사진 데이터셋이 제공됩니다.
여러분에 의해 만들어진 우수한 성능의 모델은 쓰레기장에 설치되어 정확한 분리수거를 돕거나, 어린아이들의 분리수거 교육 등에 사용될 수 있을 것입니다. 부디 지구를 위기로부터 구해주세요! 🌎
- Input : 쓰레기 객체가 담긴 이미지와 bbox 정보(좌표, 카테고리)가 모델의 인풋으로 사용됩니다. bbox annotation은 COCO format으로 제공됩니다. (COCO format에 대한 설명은 학습 데이터 개요를 참고해주세요.)
- Output : 모델은 bbox 좌표, 카테고리, score 값을 리턴합니다. 이를 submission 양식에 맞게 csv 파일을 만들어 제출합니다. (submission format에 대한 설명은 평가방법을 참고해주세요
Test set의 mAP50(Mean Average Precision)로 평가
-
Object Detection에서 사용하는 대표적인 성능 측정 방법
-
Ground Truth 박스와 Prediction 박스간 IoU(Intersection Over Union, Detector의 정확도를 평가하는 지표)가 50이 넘는 예측에 대해 True라고 판단합니다.
-
-
Orange
- TP = 1, FP = 1
- 총 2개의 Orange 박스 중 하단의 박스 1개는 객체를 잘 detection하였습니다. (TP) 상단의 박스 1개는 Blue category에 해당하는 객체를 Orange category로 예측하였기 때문에 잘못된 detection입니다. (FP)
-
Blue
- TP = 2, FP = 1
- 총 3개의 Blue 박스 중 두 개의 박스는 객체를 잘 detection하였습니다. (TP) 우측 하단의 박스는 객체 위치를 정확히 detection하지 못했습니다. (FP)
-
mAP
모든 이미지의 각 클래스별 AP 계산 후, 평균내어 최종 점수가 구해집니다.
-
- 시각화
위 이미지에서 보이는 바와 같이 Class별 bbox 수의 불균형이 심하고, 배터리의 경우 데이터 수가 159개(평균 2,314 개)뿐입니다.
① Class Dependency
- 전단지의 경우 일반 쓰레기와 종이 두 가지로 annotation되어 있음
- 유리와 투명 플라스틱이 매끈한 표면, 투명함 등 이미지상에서 유사한 특징을 보임
- 얇은 물체(노끈이나 줄 등)에 대한 background Error가 아주 높은 경향을 보임
② Class Imbalance
- Figure 1에서 처럼 Class별 bbox 수의 불균형이 심함
- 배터리의 경우, 데이터 수가 159개(평균 2,314 개)뿐
③ Various Dataset Environment
- Figure 2 와 같이 다양한 환경에서 촬영된 이미지
① Data Cleansing : Figure 3과 같은 train image의 잘못된 labeling이나 annotation을 수정해 성능 향상을 요함
② Data Augmentation : Class Imbalance 및 Image의 촬영 환경 보완을 위한 다양한 Augmentation 기법 시도
→ Randomfog, Blur, RandomBrightness, Cutmix, Mixup, Mosaic, Resize, normalization, MultiScale, RandomFlip
③ Model Selection : Inductive bias를 최소화하기 위해 다양한 backbone model을 사용하여 학습
④ Generalization : 여러 Augmentation과 Noise를 넣어 시도, TTA시도
⑤ Pseudo Labeling: 학습한 모델로 test 데이터를 inference한 후, 그 결과로 추가 학습
⑥ Ensemble : 1-stage model 과 2-stage model을 Ensemble 함으로서 Robust한 모델 개선 시도
⑦ Binary Classification : 각각의 single class를 binary classification 로 학습
Wandb를 활용한 실험 관리
Yolo-V5 augmentation test
UniverseNet101 augmentation test
- class별로 AP를 확인하면서 어떤 유형을 틀리고 있는지 파악
- Stratified validation과 Confusion Matrix를 통해 분류 모델 평가
Model | 개선 시도 | mAP |
UniverseNet101 | Mixup | 0.573 |
Mosaic / Adam / batch_size 16 / LR 0.0001 / Cutmix Dataset | 0.419 | |
Mosaic / Adam / batch_size 16 / LR 0.0001 | 0.451 | |
HueStauration / Adam / batch_size 16 / LR 0.0001 | 0.619 | |
RandomFog / batch_size 16 / LR 0.0001 | 0.623 | |
RandomBrightness / batch_size 16 / LR 0.002 | 0.624 | |
Blur, RandomFog, RandomBrightness, Mixup / Adam / batch_size 16 / LR 0.0001 /Data Cleaning | 0.613 | |
Data cleaning / RandomBrightness / batch_size 16 / LR 0.002 | 0.590 | |
Swin-T,S | Swin-T / Adam / batch_size 4 / LR 0.0001 | 0.523 |
Swin-T / MultiScale / Adam / batch_size 4 / LR 0.0001 | 0.550 | |
Swin-S / MultiScale / AdamW / batch_size 4 / LR 0.0001 | 0.561 | |
Swin-S / MultiScale, Mixup / AdamW / batch_size 4 / LR 0.0001 | 0.571 | |
Swin-S / Randomfog, RandomBrightnessContrast, ShiftScaleRotate, MultiScale, Mixup / AdamW / batch_size 4 / LR 0.0001 | 0.586 | |
Yolo-V5 | baseline (Yolo v5x6 default) / 300 epoch | 0.586 |
label smoothing (T=0.05) / 300 epoch | 0.583 | |
single class / 300 epoch | 0.008 | |
random fog / 50 epoch | 0.573 | |
pseudo labeling (conf_threshold=0.6) / train data(10epoch x 3), pseudo data(10epoch x 2) 번갈아가며 학습 / pseudo data 학습시 obj loss 제외 / 50 epoch | 0.559 | |
PVTv2-B3 | baseline epoch 30 / batch size 4 / scheduler step / LR 0.002 / fp16 | 0.541 |
batch size 3 / LR 0.0001 / Adam / score_thr = 0 | 0.573 | |
batch size 2 / LR 0.0001/ mixup, RandomFog, blur, randbright / Adam / Data cleaning | 0.526 |
더 자세한 기록은 더보기...
각 model별로 가장 LB score가 좋았던 버전 5개를 Ensemble하여 최종 모델을 생성- mmdetection 라이브러리를 활용하여 object detection의 전반적인 task를 수행해 볼 수 있었습니다.
- mAP, NMS, WBF등 object detection과 관련된 용어들에 대해 공부 할 수 있었습니다.
- object detection에 관련된 다른 대회들(Kaggle, Dacon)을 찾아보고 대회에서 활용된 기법들을 이번 대회에 적용시켜 봄으로써 성능 변화나 실제로 적용시켰을 때의 어려움 등을 경험해보고 이와 관련된 내용으로 팀원들과 소통하여 성장을 도모했습니다.
- mmdetection 외에 yolov5, Universenet과 같은 다른 라이브러리를 사용해 보는 등 다양한 시도를 하였습니다.
- mmdetection과 관련된 다양한 라이브러리를 처음 활용함에 어려움이 있어서 내가 원하던 모델을 구현하는데 시간이 오래 걸렸습니다. 새롭게 배워간다는 느낌보다 mmdetection 라이브러리를 통해 기계적으로 파라미터 튜닝을 하여 성능을 향상시킨다는 느낌이 강해서 아쉬웠습니다.
- object detection을 처음 입문함에 있어서 다양한 테스트를 해봐야 하는데 결과를 보기까지의 시간이 너무 오래 걸렸고, 이로 인해 다양한 실험을 기간 내에 해결하지 못했습니다.
- test dataset과 유사한 validation dataset을 찾기 어려워 연구가 진행될수록 model을 개선시키기 위한 뚜렷한 판단의 근거가 부족했습니다.
- LB mAP를 높이기 위해서는 bounding box를 많이 치는 것이 효과가 있었고 그러다 보니 도출된 결과를 확인했을때 이걸 detection했다고 할 수 있는지 의문이 들었고 mAP가 평가 지표로 적합한가 의문이 들었습니다.
mAP 0.672 |
mAP 0.482 |
- 한건우 : 외부 라이브러리를 사용할 때는 항상 검증하고 사용해야한다는 점을 다시 한번 느끼게 되었습니다.
- 박준혁 : 첫 object detection 대회를 경험함으로서 많은 어려움이 있었으나 팀원들과의 소통으로 잘 해결해나갔고, 앞으로도 이런 object detection task에 대한 감을 얻을 수 있어서 좋았습니다. 팀원 모두 대회를 열심히 진행해주고 같이 고민해주어서 감동이였어요~!
- 홍요한 : 라이브러리에 익숙해지는데 시간이 오래 걸려 더 많은 실험을 못했는데 다음 대회에는 더 많은 시도를 해보고 싶습니다!
- 황원상 : 이제 감을 잡아가는 것 같습니다. 다음 대회 때는 날아가봅시다.
- 박범수 : 두번째 competition이지만 아직도 부족한게 많다고 느끼는 대회였습니다. 앞으로는 조금 더 체계적으로 대회를 진행해야겠다는 걸 깨달았습니다.
- 서희수 : 협업을 중요하다고 생각해 왔는데 다양한 라이브러리로 실험을 진행해야 하는 상황에서는 우선시 하지 않을 필요도 있다고 깨닫게 되었고, 전반적인 detection task를 알아갈 수 있었다는 점에서 의미 있지만 라이브러리 튜닝만 하다 끝났다고 생각이 들기도 해서 아쉬운 마음이 남습니다. 모두 수고 많으셨어요!
- 조혜원 : Object detection 모델들을 직접 학습해볼 수 있어서 좋았으나, 모델 구조에 대해 깊이있게 파악하지 못한 등의 아쉬움도 많이 남는 대회였습니다. 팀원분들 모두 수고많으셨어요!
네이버 커넥트재단 - 재활용 쓰레기 데이터셋 / CC BY 2.0
https://stages.ai/competitions/76/overview/description