-
-
Notifications
You must be signed in to change notification settings - Fork 3.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
args to reproduce tiny-yolo metrics on img_size=320 #1111
Comments
@akshaychawla to test pretrained weights:
To train from scratch see https://github.com/ultralytics/yolov3#reproduce-our-results
Reduce --batch size if you get cuda out of memory errors. |
Thanks @glenn-jocher , I'll test out these arguments and post the results here. |
FYI the training is multi-scale 320-640, which produces better results at 320 (actually at all resolutions) than simply training at 320. |
NOTE: The results shown in this comment are misleading, please look at the latest comments below which contain correct information. Update on training:
(this will be updated when the training finishes) In comparison to #696 , the differences are:
Other things: |
@akshaychawla yes there's been a lot of updates since #696, which train to higher mAPs. Your command looks fine, but your results do not look right. This is the most recent training of the two models we have. |
@akshaychawla if you have two GPUs at your disposal I would simply install apex on your system, and train one model on each. I think you'll find that yolov3-spp works much better and is still extremely fast. About your discrepancy, there must be some difference in your code. I would cancel your training, git clone a new copy and start from scratch. I've attached the results.txt files, you should be seeing similar results. |
Sure, I'll pull a fresh copy of the repository and train yolov3-tiny from scratch with mixed precision. However, we're a little bit inflexible on the architecture right now because the code is being modified to support distillation from model A (yolov3) to model B (yolov3-tiny). Will post an update as soon as training finishes. Also, just to confirm, we're training coco2017 right? the one from get_coco2017.sh ? Thanks! |
@akshaychawla 2014 and 2017 use the same images, just a different breakdown between trian/val. The above plots are for 2014 (to compare to original yolov3 paper results), but you will see identical results when training 2017. Just make sure later on you test with the same dataset that you trained on. So train with 2017, then if you want to use test.py later on, specify |
Dev box: 1x Tesla V100, Ubuntu 18.04 Training & testing on COCO2017 (from data/get_coco2017.sh)
Last epoch's [email protected]: 0.339 Link to results and weights: https://drive.google.com/drive/folders/1Q_lUdBiLnh7VNWm8heXf3BJuBFIcAIRM?usp=sharing |
@akshaychawla ah, great! Yes this all looks correct. When you test this model directly with test.py, pycocotools will give the official coco mAP, which tends to be a bit higher than our locally produced mAP. i.e.:
|
Thanks Glenn! We were hoping to test get the official coco mAP at the end of training but it seems that the version of pycocotools installed in our environment has an issue (cocodataset/cocoapi#356) with the installed version of numpy. I'll be sure to post the cocotools metrics later with the corrected environment, for now we're moving on to test knowledge distillation. Again, thank you so much for your work! |
@akshaychawla ah yes. You likely need to enforce numpy == 1.17 I believe in order for pycocotools to function properly. pycocotools mAP is typically about 1% higher than ours (for unknown reasons), so your result is just about in line with the readme. The only other 'catch' is that [email protected] is highest at --conf 0.5, while [email protected]:0.95 is highest at --conf 0.7, so the training results show you mAP at the middle ground --conf 0.6. If you really want to maximize one or the other (as in the readme table), you should set your --conf accordingly (but we are talking about fractions of a percent here, so not a big difference). |
This issue is stale because it has been open 30 days with no activity. Remove Stale label or comment or this will be closed in 5 days. |
Hello,
I'm trying to reproduce the following tiny-yolo mAP metric:
data:image/s3,"s3://crabby-images/0259d/0259d2472dfa3937ef531fdc868c7931a693d21c" alt="Screen Shot 2020-04-28 at 12 56 19 PM"
Are the following arguments correct?
note that the img-size is set to 320, instead of 416, since I will test it only on imgs of size=320x320.
The text was updated successfully, but these errors were encountered: