Unsupervised Anomaly Detection by Airborne Sound of Industrial Machinery
A machine learning approach to machine anomaly detection on the MIMII dataset.
This study is the final "Capstone" project of ArneSch and HssDix for the 3 month data science bootcamp at neuefische in Hamburg. This project has been developed in 4 weeks of April and May 2020.
If you have any questions concerning this repository do not hesitate to contact us.
Also have a look at our presentation: link to the presentation
Explore the dataset in the showroom: link to the showroom
This repo is about a concept study on the MIMII dataset to detect anomalies of machines or machine parts like fans, slider, pump and valves by means of classic machine learning and deep learning methods.
In condition monitoring of machinery, it is common to use structure-borne sound and order tracking (RPM, etc.) to detect malfunctions. For various reasons like ease of retrofitting or the need for a mobile solution and size of the machine part or operational needs like zero downtime, airborne sound anomaly detection could be preferable. The proof of concept study conducted here, shows that by applying machine learning anomaly detection on acoustic sensing, a ML/AI sensor can be constructed that has good performance so that it can compete with a trained technician when detecting anomalies by listening to the machine, with the potential benefit of staying 24/7 at the machine part of interest. The development can be seen as groundwork for an embedded solution of a smart sensor as part of an IoT plant supervision system (like SCADA).
Anomaly detection with machine learning means mostly unsupervised learning as the base assumption is that abnormal operation is unknown. Abnormal operation could be potentially very diverse of nature, so even if the recordings of abnormal operation would exist training on them would lead to overfitting. Furthermore, the application of smart sensor would be less useful.
This means a smart sensor microphone system needs to be trained by being placed for a reasonable training time in front of a healthy machine part, to become an armed detector that learned what is normal under representative background noise. Herein lies also the limitations of the study as in a real-world scenario more machine parts are connected and the dataset specifically focuses on a single part. But a general abnormality detection also for an ensemble of machine parts could be applicable with the same technique.
To reach an optimal architecture various machine learning techniques are explored and eventually a divers ensemble connected. The following list summarizes the techniques explored:
- Stochastic model (a multi-dimensional normal distribution is found and outlier defined by significance)
- Random Isolation trees (a decision tree is taken assuming outlier need only a few decisions to be found as spatially separated in one or more features)
- Autoencoder (an underrepresented auto encoder reconstruction error is taken)
- Pseudo supervision (where normal observation is augmented/ distorted to train a binary classifier)
In the picture below an exemplary classification ensemble is sketched, this is an example to show the main parts that are:
- Feature extraction pre-filter like BSS blind source separation or denoising filter
- Feature extraction like welch spectra (PSDs) or MEL spectra
- Classifier like RFC random forest classifier
- Stochastic models for outlier detection like GMM gaussian mixture model, etc.
- Unsupervised outlier detection like neural network autoencoder
- Or outlier classification like IFC isolation forest classifier
- The time frame-based ensemble collects different classification over the time processed as some classifiers work on longer buffer parts than others. This may help to regulate the training of the algorithms and can improve training speeds.
In order to make any machine learning algorithm able to work with audio it is necessary to use various signal processing steps (feature extraction pre filter) that may be of classic nature or also take use of machine learning methods like clustering for preprocessing on the time buffer like activation detection. In application the reaction time of such an anomaly detection is around 10 sec at the current construction and training chain buildup. But some indication could be found to reduce this eventually.
The data have a general discretion through the ZENODO page where it is open for download
The related paper by the MIMII dataset creators - Harsh Purohit, Ryo Tanabe, Kenji Ichige, Takashi Endo,Yuki Nikaido, Kaori Suefusa, and Yohei Kawaguchi can be found here: https://arxiv.org/pdf/1909.09347.pdf
At this point we like to sincerely thank you for sharing the dataset, it serves a great challenge!
Some further interpretation from our end can be found in the sub chapter: about the dataset
Furthermore the MIMII creators also provided an autoencoder based baseline model on GitHub: https://github.com/MIMII-hitachi/mimii_baseline This repo was of great help to get into the topic and inspired us.
Maybe you like to tune in, listen and have a look to some spectra of a small selection from the MIMII dataset. Then visit the showroom:
link to the showroom
The repo has some folders that correspond to either setup or the main chapters of the study. Here you can find some overview information and links to the in depth chapters.
The feature extraction diagram is a chain of filters and feature extractions like the MEL spectrum as an output. Thereby the folder hosts the tuning and test of the components, finally used ones and explored ones. As well as the batch creation scripts for pre-processing the dataset. More in the sub chapter feature extraction diagrams
The modeling folder hosts all the explored machine learning variants sorted in sub folders like each with general description in the modeling.md
Hosts the unpacked dataset from the zenodo site. The structure expected is discribed in the subchapter: dataset folder structure. Additionaly it has folders for the extracted features after using the diagrams (see above).
Utility-function and classes stored in py-files rather than jupyter notebooks. In the folder utility/workshop some application and basic tests of the utilities can be found.
All subchapter and media material for documention.
References like papers, etc. see below.
Information about the Conda environment, Jupyter settings and GPU elements in tensorflow. Notice this work was done on windows 10 with anaconda and jupyter.
Miscellaneous material and interesting site experiments - partially unsorted.
A list of general potential for improvement and not fully or not at all explored techniques mostly due to time restrictions. Sub Chapter improvements
Notes for the application as a smart sensor. A small discussion on implication and follow-up-work for deployment. Sub chapter: application notes
Some reflection on workflow chosen and setup. Sub chapter workflow improvements
The results generated with the main notebook are shown below. If you want to read more details about the modeling process and the construction of the ensembles, check this file: modeling.md
The results have been calculated for test-sets with 50% normal and 50% abnormal recordings. The number of instances of the testset is shown.
6dB | -6dB | |||||
---|---|---|---|---|---|---|
ID | N | baseline | ours | baseline | ours | |
Valve | 04 | 240 | 64.0% | 99.9% | 50.0% | 91.7% |
06 | 240 | 70.0% | 82.3% | 53.0% | 66.0% | |
Avg. | 67.0% | 91.1% | 51.5% | 78.9% | ||
Pump | 04 | 200 | 99.0% | 100.0% | 93.0% | 97.4% |
06 | 208 | 94.0% | 99.4% | 61.0% | 78.6% | |
Avg. | 96.5% | 99.7% | 77.0% | 88.0% | ||
Fan | 04 | 694 | 92.0% | 98.5% | 57.0% | 67.9% |
06 | 722 | 99.0% | 99.7% | 83.0% | 91.8% | |
Avg. | 95.5% | 99.1% | 70.0% | 79.9% | ||
Slide rail | 04 | 356 | 88.0% | 99.8% | 61.0% | 90.1% |
06 | 178 | 71.0% | 97.6% | 52.0% | 75.4% | |
Avg. | 79.5% | 98.7% | 56.5% | 82.7% | ||
over all | Avg. | 84.6% | 97.2% | 63.8% | 82.4% |
To the creators of the MIMII dataset
To the creators of the gigantic audio processing library librosa
To the creators of the library pyroomacustics
To all the developers of python, scipy, numpy, scikit learn and tensorflow ... and all the great python stuff that we can build on.
To Mike X Cohen for his great Python DSP Udemy courses
To all the founders and minds of machine learning you created an awesome universe to explore.
To the team at neuefische GmbH, that made this project possible by training us in the data science bootcamp.
To so many more form the web like towardsdatascience.com, stackoverflow ...
Find all references: papers, source code and other web sources in the following sub chapters: