Skip to content

Commit

Permalink
Add standalone visual object detection notebook. (#3586)
Browse files Browse the repository at this point in the history
* Add standalone visual object detection notebook.

* Debug the upload issue

- previously the CI test failed at uplaading .rec to s3.
- use absolute path instead

* Debug code change

* Debug

* Use aws s3 cp to upload data to s3

* Use aws s3 cp to upload data to s3

* Test will small number of training epochs.

* Try to fix the opencv issue by using python3.8

* Try to fix the opencv issue

- remove the 'opencv-python-headless<4.3' restriction

* Downgrade opencv try to resolve the opencv issue.

- ref: https://stackoverflow.com/a/72812857

* Update opencv version trying to resolve the AttributeError issue.

* opendv-python 4.6.0.66 not working, change to 4.5.5.64

* Change to pytorch 1.8 python 3.6 kernel

* Address all comments from the reviewer

- move all behind-the-scene package installation to the beginning of the
  notebook
- polish the README file and address all concerns from the reviewer

* Change to pytorch 1.8 and python 3.6 kernel

* Remove most outputs in the notebook.

Co-authored-by: Tao Sun <[email protected]>
  • Loading branch information
tao2020 and Tao Sun authored Sep 16, 2022
1 parent c2987ea commit c88f7f1
Show file tree
Hide file tree
Showing 9 changed files with 3,026 additions and 0 deletions.
1 change: 1 addition & 0 deletions introduction_to_applying_machine_learning/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,4 @@ These examples provide a gentle introduction to machine learning concepts as the
- [Population Segmentation of US Census Data using PCA and Kmeans](US-census_population_segmentation_PCA_Kmeans) analyzes US census data and reduces dimensionality using PCA then clusters US counties using KMeans to identify segments of similar counties.
- [Document Embedding using Object2Vec](object2vec_document_embedding) is an example to embed a large collection of documents in a common low-dimensional space, so that the semantic distances between these documents are preserved.
- [Traffic violations forecasting using DeepAR](deepar_chicago_traffic_violations) is an example to use daily traffic violation data to predict pattern and seasonality to use Amazon DeepAR alogorithm.
- [Visual Inspection Automation with Pre-trained Amazon SageMaker Models](visual_object_detection) is an example for fine-tuning pre-trained Amazon Sagemaker models on a target dataset.
Original file line number Diff line number Diff line change
@@ -0,0 +1,145 @@
# Visual Inspection Automation with Pre-trained Amazon SageMaker Models

This solution detects product defects with an end-to-end Deep Learning workflow for quality control in manufacturing process. The solution takes input of product images and identifies defect regions with bounding boxes. In particular, this solution uses a pre-trained Sagemaker object detection model and fine-tune on the target dataset.

This solution will demonstrate the immense advantage of fine-tuning a high-quality pre-trained model on the target dataset, both visually and numerically.

### Contents
1. [Overview](#overview)
1. [What Does the Input Data Look Like?](#input)
2. [How to Prepare Your Data to Feed into the Model?](#preparedata)
3. [What are the Outputs?](#output)
4. [What is the Estimated Cost?](#cost)
5. [What Algorithms & Models are Used?](#algorithms)
6. [What Does the Data Flow Look Like?](#dataflow)
2. [Solution Details](#solution)
1. [Background](#background)
2. [What is Visual Inspection?](#inspection)
3. [What are the Problems?](#problems)
4. [What Does this Solution Offer?](#offer)
3. [Architecture Overview](#architecture)
4. [Cleaning up](#cleaning-up)
5. [Customization](#customization)


## 1. Overview <a name="overview"></a>

### 1.1. What Does the Input Data Look Like? <a name="input"></a>

Input is an image of a defective / non-defective product. The training data should have relatively balanced classes, with annotations for ground truth defects (locations and defect types) per image. Here are examples of annotations used in the demo, they show some "inclusion" defects on the surface:

!["sample2"](https://sagemaker-solutions-prod-us-east-2.s3.us-east-2.amazonaws.com/sagemaker-defect-detection/docs/sample2.png)

The NEU surface defect database (see [references](#references)) is a *balanced* dataset which contains

> Six kinds of typical surface defects of the hot-rolled steel strip are collected, i.e., rolled-in scale (RS), patches (Pa), crazing (Cr), pitted surface (PS), inclusion (In) and scratches (Sc). The database includes 1,800 grayscale images: 300 samples each of six different kinds of typical surface defects
Here is a sample image of the six classes

!["data sample"](https://sagemaker-solutions-prod-us-east-2.s3.us-east-2.amazonaws.com/sagemaker-defect-detection/docs/data.png)

### 1.2. How to Prepare Your Data to Feed into the Model? <a name="preparedata"></a>

There are data preparation and preprocessing steps and should be followed in the notebooks. It's critical to prepare your image annotations beforehand.
For finetuning pretrained Sagemaker models, you need to prepare either a single `annotation.json` for all data, or a `RecordIO` file for both all images and all annotations. Check the notebook for details.

### 1.3. What are the Outputs? <a name="output"></a>

* For each image, the trained model will produce bounding boxes of detected visual defects (if any), the predicted defect type, and prediction confidence score (0~1).
* If you have a labeled test dataset, you could obtain the mean Average Precision (mAP) score for each model and compare among all the models.
* For example, the mAP scores on a test set of the NEU dataset

| | Type1 | Type1+HPO | Type2 | Type2+HPO|
| --- | --- | --- | --- | ---|
| mAP | 0.067 | 0.226 | 0.371 | 0.375|


### 1.4. What is the Estimated Cost? <a name="cost"></a>

* Running the notebook costs around $130~140 USD, assuming using p3.2xlarge EC2 instance in the notebook, and $3.06 on-demand hourly rate in US East. This notebook provides advanced materials, including finetuning two types of pretrained Sagemaker models **till convergence**, with and without hyperparameter optimization (HPO), and result in four models for inference. You could choose to train either one model, or all four models according to your budget and requirements. The cost and runtime for training each model are:

| Model | Cost (USD) | Runtime (Hours) | Billable time (Hours)|
|:----------:|:---------------:|:----:|:-----:|
|Type 1| 1.5 | 0.5 | 0.5|
|Type 1 with HPO (20 jobs)| 30.6 | 1* | 10|
|Type 2| 4.6 | 1.5 | 1.5|
|Type 2 with HPO (20 jobs)| 92 | 3* | 30|
(*) HPO tasks in this solution consider 20 jobs in total and 10 jobs in parallel. So 1 actual runtime hour amounts to 10 billable cost hours.
* Please make sure you have read the cleaning up part in [Section 4](#cleaning-up) after training to avoid incurred cost from deployed models.



### 1.5. What Algorithms & Models are Used? <a name="algorithms"></a>

* The pretrained Sagemaker models include SSD models and FasterRCNN model, using either VGG, ResNet, or MobileNet as backbone, pretrained on either ImageNet, COCO, VOC, or FPN dataset.

### 1.6. How Does the Data Flow Look Like? <a name="dataflow"></a>

![Data flow](https://sagemaker-solutions-prod-us-east-2.s3.us-east-2.amazonaws.com/sagemaker-defect-detection/docs/data_flow.png)

## 2. Solution Details <a name="solution"></a>

### 2.1. Background <a name="background"></a>

According to the [Gartner study on the top 10 strategic tech trends for 2020](https://www.gartner.com/smarterwithgartner/gartner-top-10-strategic-technology-trends-for-2020/), hyper-automation is the number one trend in 2020 and will continue advancing in future. When it comes to manufacturing, one of the main barriers to hyper-automation is in areas where Human involvements is still struggling to be reduced and intelligent systems have hard times to become on-par with Human visual recognition abilities and become mainstream, despite great advancement of Deep Learning in Computer Vision. This is mainly due to lack of enough annotated data (or when data is sparse) in areas such as _Quality Control_ sections where trained Human eyes still dominates.


### 2.2. What is Visual Inspection? <a name="inspection"></a>

The **analysis of products on the production line for the purpose of Quality Control**. According to [Everything you need to know about Visual Inspection with AI](https://nanonets.com/blog/ai-visual-inspection/), visual inspection can also be used for internal and external assessment of the various equipment in a production facility such as storage tanks, pressure vessels, piping, and other equipment which expands to many industries from Electronics, Medical, Food and Raw Materials.

### 2.3. What are the Problems? <a name="problems"></a>

* *Human visual inspection error* is a major factor in this area. According to the report [The Role of Visual Inspection in the 21st Century](https://www.osti.gov/servlets/purl/1476816)

> Most inspection tasks are much more complex and typically exhibit error rates of 20% to 30% (Drury & Fox, 1975)
which directly translates to *cost*.
* Cost: according to [glassdoor estimate](https://www.glassdoor.co.in/Salaries/us-quality-control-inspector-salary-SRCH_IL.0,2_IN1_KO3,28.htm), a trained quality inspector salary varies between 29K (US) - 64K per year.

### 2.4. What Does this Solution Offer? <a name="offer"></a>

This solution offers a complete solution using high-quality pretrained Sagemaker models to finetune on the target dataset with and without hyperparameter optimization (HPO).

The **most important** information this solution delivers, is that training a deep learning model from scratch on a small dataset can be both time-consuming and less effective, whereas finetuning a high-quality pretrained model, which was trained on large-scale dataset, could be both cost- and runtime-efficient and highly performant. Here are the sample detection results

<img src="patches_116.jpeg" alt="drawing" width="1200"/>

## 3. Architecture Overview <a name="architecture"></a>

The following illustration is the architecture for the end-to-end training and deployment process

!["Solution Architecture"](https://sagemaker-solutions-prod-us-east-2.s3.us-east-2.amazonaws.com/sagemaker-defect-detection/docs/train_arch.png)

1. The input data located in an [Amazon S3](https://aws.amazon.com/s3/) bucket
2. The provided [SageMaker notebook](source/deep_demand_forecast.ipynb) that gets the input data and launches the later stages below
3. **Training Classifier and Detector models** and evaluating its results using Amazon SageMaker. If desired, one can deploy the trained models and create SageMaker endpoints
4. **SageMaker endpoint** created from the previous step is an [HTTPS endpoint](https://docs.aws.amazon.com/sagemaker/latest/dg/how-it-works-hosting.html) and is capable of producing predictions
5. Monitoring the training and deployed model via [Amazon CloudWatch](https://aws.amazon.com/cloudwatch/)

## 4. Cleaning up <a name="cleaning-up"></a>

If you run the notebook end-to-end, the Cleaning up section in the notebook will delete all the checkpoints and models automatically for you. If you choose to only train some of the four models in the notebook, please make sure to run corresponding code in the Cleaning up section to delete all the artifacts.

**Caution:** You need to manually delete any extra resources that you may have created in this notebook. For examples extra Amazon S3 bucketis.

## 5. Customization <a name="customization"></a>

For using your own data, make sure it is labeled and is a *relatively* balanced dataset. Also make sure the image annotations follow the required format.



### Useful Links <a name="links"></a>

* [Amazon SageMaker Getting Started](https://aws.amazon.com/sagemaker/getting-started/)
* [Amazon SageMaker Developer Guide](https://docs.aws.amazon.com/sagemaker/latest/dg/whatis.html)
* [Amazon SageMaker Python SDK Documentation](https://sagemaker.readthedocs.io/en/stable/)
* [AWS CloudFormation User Guide](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/Welcome.html)

### References

* K. Song and Y. Yan, “A noise robust method based on completed local binary patterns for hot-rolled steel strip surface defects,” Applied Surface Science, vol. 285, pp. 858-864, Nov. 2013.

* Yu He, Kechen Song, Qinggang Meng, Yunhui Yan, “An End-to-end Steel Surface Defect Detection Approach via Fusing Multiple Hierarchical Features,” IEEE Transactions on Instrumentation and Measuremente, 2020,69(4),1493-1504.

* Hongwen Dong, Kechen Song, Yu He, Jing Xu, Yunhui Yan, Qinggang Meng, “PGA-Net: Pyramid Feature Fusion and Global Context Attention Network for Automated Surface Defect Detection,” IEEE Transactions on Industrial Informatics, 2020.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit c88f7f1

Please sign in to comment.