Skip to content

Latest commit

 

History

History
143 lines (78 loc) · 7.1 KB

README.md

File metadata and controls

143 lines (78 loc) · 7.1 KB

BBQ_Madhacks2018

The bounding box quality checking web service for Madhacks 2018

Introduction

This is the code repository for Madhacks 2018. Madhacks is the University of Wisconsin's twice-annual hackathon, bringing together participants from all over the US and Canada for 24 hours of hacking.

BBQ standing bounding box qualifier which is a web service that examines the matching between ground truth bounding boxes and the predicted bounding boxes and produces a prediction quality report and debugging tools for object detection algorithm.

A lot of work of object detection methods are focusing on how to generate bounding box annotations like Crowdsourcing Annotations for Visual Object Detection,Quanti.us: a tool for rapid, flexible, crowd-based annotation of images and exploer why the object detection algorithm fails like HOGgles: Visualizing Object Detection Features. However, few have talked about how to debug or check where the object detection model fails. This hackathon project is a tool that can help people actually see where the object detection algorithm fails.

Problem Define

Input

Basic

Run BBQ

To run BBQ you need to type this two commands in your terminal,

export FLASK_APP=BBQDemo.py

Then you will this hints below

 * Serving Flask app "BBQDemo"
 * Running on http://127.0.0.1:5000/  

you can try

flask run

Submission Summary

Inspiration

In the object detection task using bounding boxes, people want to know both the location and category of object. So typically two types of error involved here. However, although there are many annotation tools, there are few tools that can help people track where their object detection algorithm fails. Is it because of the poor performance of location regressor or it is due to the failure of the classifier.

Things become worse when you have to prepare labels for domain science dataset instead of using high-quality dataset like MS COCO or ImageNet. For example, we are working on an AI project that uses object detection program for STEM() images of metallic material. We want to study the number of different kinds of defects which are important for the performance of the material. However, Faster R-CNN algorithm achieves poor performance and it is very hard to understand why and identify the bugs never to say improve the performance. A typical pair of ground truth image and the predicted image is shown below.

ground truth labeling and predicting image

What it does

workflow image

So we plan to create a web service that can developer debug their object detection models especially when the ground truth labeling contains error.

Step by step usage

Step 1 : upload files

the user inputs the image for detection and the ground truth bounding box txt file and the prediction bounding box txt file. The bounding box should follow the following format

[label, x1, y1, x2, y2]

Where label is the label of object contained in the bounding box and (x1,y1) is the top left conner of the bounding box and (x2,y2) is the right bottom conner of the bounding box.

Check the following figure for more information

step1

step2

After all files are selected, you can click the Submit to submit all 3 files

step3

Step 2 : check overall results

Then the website will show all the mismatched predicted bounding boxes and for different types of error, it will display them differently:

step4

  1. location error
  2. classification error

In the above summary figure, the website only plots the wrong predictions and all color bounding box on the web page can be clicked which will bring you to a more detailed information web page.

Step 3 : Check location error

Say if we want to check the location as pointed in the following figure, you can directly click it.

step4loc

which will bring you to another web page as shown below,

step5loc

location error means that the object detection model predicts the wrong location of an object. The model thinks there is an object but according to ground truth label, it is background. So we have to check why the model thinks a background area is an object. And because the ground truth data set may contain error, so it can also be that ground truth labeling misses a potential object.

With the given information, you can easily identify which type of reason of the error and modify correspondingly.

Step 4 : Check classification error

Classification error means the model detects the region of interest but the classifier fails to classify the region of interest into the correct category which means you may need a stronger classifier.

Say we want to check the classification error that is pointed by the red arrow in the following figure,

step4cls

You can click either red for prediction bounding box or blue ground truth bounding box.

Then the website will bring you to the more detailed information page as shown below,

step5cls

How we built it

We use Python 3 with Flask as our backend engine to build the website and Bootstrap as our frontend framework for UI.

Challenges we ran into

We don't have much experience in web development. First we find it difficult to use css to customize our web page. Then we run into some trouble when trying to make the image map interactive.

Accomplishments that we're proud of

We build a tool that is very easy to use and can make the complicated debugging process much easier.

What we learned

Mostly web development, including html, css, javascript, flask(python), etc. As we mentioned, both team members don't know how to do web develop before. This project gave us some experience in both front-end and back-end.

What's next for BBQ

BBQ acts as a online tool for object detection debugging. For future work, we plan to add a model deployment module to BBQ, where users can upload their model to the web service and the other users can use them to detect image online.

Submitted to MadHack 2018

Successful Submission