- Author: Umberto Griffo
- Twitter: @UmbertoGriffo
You can try the code directly on Colab. Save a copy in your drive and enjoy It!
- Python 3.6
- numpy 1.13.3
- scipy 0.19.1
- matplotlib 2.0.2
- spyder 3.2.3
- scikit-learn 0.19.0
- h5py 2.7.0
- Pillow 4.2.1
- pandas 0.20.3
- Anaconda 3
- TensorFlow 1.3.0
- Keras 2.1.1
* 2 Intel Xeon E5-2630 v4 2.2GHz, 25M Cache, 8.0 GT/s QPI, Turbo, HT, 10C/20T (85W) Max Mem 2133MHz
* 128 GB Ram
* 1 TB Disk
In this example I build an LSTM network in order to predict remaining useful life (or time to failure) of aircraft engines [3] based on scenario described at [1] and [2]. The network uses simulated aircraft sensor values to predict when an aircraft engine will fail in the future so that maintenance can be planned in advance. The question to ask is "Given these aircraft engine operation and failure events history, can we predict when an in-service engine will fail?" We re-formulate this question into two closely relevant questions and answer them using two different types of machine learning models:
* Regression models: How many more cycles an in-service engine will last before it fails?
* Binary classification: Is this engine going to fail within w1 cycles?
In the Dataset directory there are the training, test and ground truth datasets. The training data consists of multiple multivariate time series with "cycle" as the time unit, together with 21 sensor readings for each cycle. Each time series can be assumed as being generated from a different engine of the same type. The testing data has the same data schema as the training data. The only difference is that the data does not indicate when the failure occurs. Finally, the ground truth data provides the number of remaining working cycles for the engines in the testing data. The following picture shows a sample of the data:
You can find more details about the data at [1] and [2].Mean Absolute Error | Coefficient of Determination (R^2) |
---|---|
12 | 0.7965 |
The following pictures shows the trend of loss Function, Mean Absolute Error, R^2 and actual data compared to predicted data:
Accuracy | Precision | Recall | F-Score |
---|---|---|---|
0.97 | 0.92 | 1.0 | 0.96 |
The following pictures shows trend of loss Function, Accuracy and actual data compared to predicted data:
- [1] Deep Learning for Predictive Maintenance https://github.com/Azure/lstms_for_predictive_maintenance/blob/master/Deep%20Learning%20Basics%20for%20Predictive%20Maintenance.ipynb
- [2] Predictive Maintenance: Step 2A of 3, train and evaluate regression models https://gallery.cortanaintelligence.com/Experiment/Predictive-Maintenance-Step-2A-of-3-train-and-evaluate-regression-models-2
- [3] A. Saxena and K. Goebel (2008). "Turbofan Engine Degradation Simulation Data Set", NASA Ames Prognostics Data Repository (https://ti.arc.nasa.gov/tech/dash/groups/pcoe/prognostic-data-repository/#turbofan), NASA Ames Research Center, Moffett Field, CA
- [4] Understanding LSTM Networks http://colah.github.io/posts/2015-08-Understanding-LSTMs/