├── Estimation of RUL using CNN.ipynb ├── LICENSE ├── PHM08.csv └── README.md /Estimation of RUL using CNN.ipynb: -------------------------------------------------------------------------------- 1 | { 2 | "cells": [ 3 | { 4 | "cell_type": "code", 5 | "execution_count": null, 6 | "metadata": { 7 | "collapsed": true 8 | }, 9 | "outputs": [], 10 | "source": [ 11 | "import pandas as pd\n", 12 | "import numpy as np\n", 13 | "import tensorflow as tf\n", 14 | "from sklearn.preprocessing import scale" 15 | ] 16 | }, 17 | { 18 | "cell_type": "code", 19 | "execution_count": null, 20 | "metadata": { 21 | "collapsed": false, 22 | "scrolled": true 23 | }, 24 | "outputs": [], 25 | "source": [ 26 | "def windows(nrows, size):\n", 27 | " start,step = 0, 2\n", 28 | " while start < nrows:\n", 29 | " yield start, start + size\n", 30 | " start += step\n", 31 | "\n", 32 | "def segment_signal(features,labels,window_size = 15):\n", 33 | " segments = np.empty((0,window_size))\n", 34 | " segment_labels = np.empty((0))\n", 35 | " nrows = len(features)\n", 36 | " for (start, end) in windows(nrows,window_size):\n", 37 | " if(len(data.iloc[start:end]) == window_size):\n", 38 | " segment = features[start:end].T #Transpose to get segment of size 24 x 15 \n", 39 | " label = labels[(end-1)]\n", 40 | " segments = np.vstack([segments,segment]) \n", 41 | " segment_labels = np.append(segment_labels,label)\n", 42 | " segments = segments.reshape(-1,24,window_size,1) # number of features = 24 \n", 43 | " segment_labels = segment_labels.reshape(-1,1)\n", 44 | " return segments,segment_labels" 45 | ] 46 | }, 47 | { 48 | "cell_type": "code", 49 | "execution_count": null, 50 | "metadata": { 51 | "collapsed": false, 52 | "scrolled": true 53 | }, 54 | "outputs": [], 55 | "source": [ 56 | "data = pd.read_csv(\"PHM08.csv\")\n", 57 | "features = scale(data.iloc[:,2:26]) # select required columns and scale them\n", 58 | "labels = data.iloc[:,26] # select RUL " 59 | ] 60 | }, 61 | { 62 | "cell_type": "code", 63 | "execution_count": null, 64 | "metadata": { 65 | "collapsed": false, 66 | "scrolled": false 67 | }, 68 | "outputs": [], 69 | "source": [ 70 | "segments, labels = segment_signal(features,labels)" 71 | ] 72 | }, 73 | { 74 | "cell_type": "code", 75 | "execution_count": null, 76 | "metadata": { 77 | "collapsed": true 78 | }, 79 | "outputs": [], 80 | "source": [ 81 | "train_test_split = np.random.rand(len(segments)) < 0.70\n", 82 | "train_x = segments[train_test_split]\n", 83 | "train_y = labels[train_test_split]\n", 84 | "test_x = segments[~train_test_split]\n", 85 | "test_y = labels[~train_test_split]" 86 | ] 87 | }, 88 | { 89 | "cell_type": "markdown", 90 | "metadata": {}, 91 | "source": [ 92 | "--------------------------------------------------------------------------------------------------------------------------------" 93 | ] 94 | }, 95 | { 96 | "cell_type": "code", 97 | "execution_count": null, 98 | "metadata": { 99 | "collapsed": false 100 | }, 101 | "outputs": [], 102 | "source": [ 103 | "def weight_variable(shape):\n", 104 | " initial = tf.truncated_normal(shape, stddev = 0.1)\n", 105 | " return tf.Variable(initial)\n", 106 | "\n", 107 | "def bias_variable(shape):\n", 108 | " initial = tf.constant(1.0, shape = shape)\n", 109 | " return tf.Variable(initial)\n", 110 | "\n", 111 | "def apply_conv(x,kernel_height,kernel_width,num_channels,depth):\n", 112 | " weights = weight_variable([kernel_height, kernel_width, num_channels, depth])\n", 113 | " biases = bias_variable([depth])\n", 114 | " return tf.nn.relu(tf.add(tf.nn.conv2d(x, weights,[1,1,1,1],padding=\"VALID\"),biases))\n", 115 | " \n", 116 | "def apply_max_pool(x,kernel_height,kernel_width,stride_size):\n", 117 | " return tf.nn.max_pool(x, ksize=[1, kernel_height, kernel_width, 1], strides=[1, 1, stride_size, 1], padding = \"VALID\")" 118 | ] 119 | }, 120 | { 121 | "cell_type": "code", 122 | "execution_count": null, 123 | "metadata": { 124 | "collapsed": true 125 | }, 126 | "outputs": [], 127 | "source": [ 128 | "num_labels = 1\n", 129 | "batch_size = 10\n", 130 | "num_hidden = 800\n", 131 | "learning_rate = 0.0001\n", 132 | "training_epochs = 30\n", 133 | "input_height = 24\n", 134 | "input_width = 15\n", 135 | "num_channels = 1\n", 136 | "total_batches = train_x.shape[0] // batch_size" 137 | ] 138 | }, 139 | { 140 | "cell_type": "code", 141 | "execution_count": null, 142 | "metadata": { 143 | "collapsed": true 144 | }, 145 | "outputs": [], 146 | "source": [ 147 | "X = tf.placeholder(tf.float32, shape=[None,input_height,input_width,num_channels])\n", 148 | "Y = tf.placeholder(tf.float32, shape=[None,num_labels])\n", 149 | "\n", 150 | "c = apply_conv(X, kernel_height = 24, kernel_width = 4, num_channels = 1, depth = 8) \n", 151 | "p = apply_max_pool(c,kernel_height = 1, kernel_width = 2, stride_size = 2) \n", 152 | "c = apply_conv(p, kernel_height = 1, kernel_width = 3, num_channels = 8, depth = 14) \n", 153 | "p = apply_max_pool(c,kernel_height = 1, kernel_width = 2, stride_size = 2) \n", 154 | "\n", 155 | "shape = p.get_shape().as_list()\n", 156 | "flat = tf.reshape(p, [-1, shape[1] * shape[2] * shape[3]])\n", 157 | "\n", 158 | "f_weights = weight_variable([shape[1] * shape[2] * shape[3], num_hidden])\n", 159 | "f_biases = bias_variable([num_hidden])\n", 160 | "f = tf.nn.tanh(tf.add(tf.matmul(flat, f_weights),f_biases))\n", 161 | "\n", 162 | "out_weights = weight_variable([num_hidden, num_labels])\n", 163 | "out_biases = bias_variable([num_labels])\n", 164 | "y_ = tf.add(tf.matmul(f, out_weights),out_biases)" 165 | ] 166 | }, 167 | { 168 | "cell_type": "code", 169 | "execution_count": null, 170 | "metadata": { 171 | "collapsed": true 172 | }, 173 | "outputs": [], 174 | "source": [ 175 | "cost_function = tf.reduce_mean(tf.square(y_- Y))\n", 176 | "optimizer = tf.train.AdamOptimizer(learning_rate).minimize(cost_function)" 177 | ] 178 | }, 179 | { 180 | "cell_type": "code", 181 | "execution_count": 75, 182 | "metadata": { 183 | "collapsed": false 184 | }, 185 | "outputs": [ 186 | { 187 | "name": "stdout", 188 | "output_type": "stream", 189 | "text": [ 190 | "Training set MSE\n", 191 | "4752.72697916\n", 192 | "4677.79731598\n", 193 | "4675.55796569\n", 194 | "4668.99871858\n", 195 | "4646.43073364\n", 196 | "4606.30021167\n", 197 | "4544.63535847\n", 198 | "4453.55062054\n", 199 | "4320.07571005\n", 200 | "4142.02065626\n", 201 | "3939.75333712\n", 202 | "3732.80059479\n", 203 | "3540.9024371\n", 204 | "3373.17483584\n", 205 | "3231.20530547\n", 206 | "3112.15695777\n", 207 | "3011.5041224\n", 208 | "2925.24642685\n", 209 | "2851.78353692\n", 210 | "2789.1534664\n", 211 | "2736.44654112\n", 212 | "2687.96121346\n", 213 | "2644.67107264\n", 214 | "2605.52678315\n", 215 | "2568.49537431\n", 216 | "2533.52371995\n", 217 | "2503.20061828\n", 218 | "2473.34282306\n", 219 | "2445.49239087\n", 220 | "2419.93309399\n", 221 | "Test set MSE: 2607.9456\n" 222 | ] 223 | } 224 | ], 225 | "source": [ 226 | "with tf.Session() as session:\n", 227 | " tf.global_variables_initializer().run()\n", 228 | " print(\"Training set MSE\")\n", 229 | " for epoch in range(training_epochs):\n", 230 | " for b in range(total_batches): \n", 231 | " offset = (b * batch_size) % (train_x.shape[0] - batch_size)\n", 232 | " batch_x = train_x[offset:(offset + batch_size), :, :, :]\n", 233 | " batch_y = train_y[offset:(offset + batch_size),:]\n", 234 | " _, c = session.run([optimizer, cost_function],feed_dict={X: batch_x, Y : batch_y})\n", 235 | " \n", 236 | " p_tr = session.run(y_, feed_dict={X: train_x})\n", 237 | " tr_mse = tf.reduce_mean(tf.square(p_tr - train_y))\n", 238 | " print(session.run(tr_mse))\n", 239 | "\n", 240 | " p_ts = session.run(y_, feed_dict={X: test_x})\n", 241 | " ts_mse = tf.reduce_mean(tf.square(p_ts - test_y))\n", 242 | " print(\"Test set MSE: %.4f\" % session.run(ts_mse)) " 243 | ] 244 | }, 245 | { 246 | "cell_type": "code", 247 | "execution_count": null, 248 | "metadata": { 249 | "collapsed": true 250 | }, 251 | "outputs": [], 252 | "source": [] 253 | } 254 | ], 255 | "metadata": { 256 | "anaconda-cloud": {}, 257 | "kernelspec": { 258 | "display_name": "Python [conda root]", 259 | "language": "python", 260 | "name": "conda-root-py" 261 | }, 262 | "language_info": { 263 | "codemirror_mode": { 264 | "name": "ipython", 265 | "version": 3 266 | }, 267 | "file_extension": ".py", 268 | "mimetype": "text/x-python", 269 | "name": "python", 270 | "nbconvert_exporter": "python", 271 | "pygments_lexer": "ipython3", 272 | "version": "3.5.2" 273 | } 274 | }, 275 | "nbformat": 4, 276 | "nbformat_minor": 1 277 | } 278 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Apache License 2 | Version 2.0, January 2004 3 | http://www.apache.org/licenses/ 4 | 5 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 6 | 7 | 1. Definitions. 8 | 9 | "License" shall mean the terms and conditions for use, reproduction, 10 | and distribution as defined by Sections 1 through 9 of this document. 11 | 12 | "Licensor" shall mean the copyright owner or entity authorized by 13 | the copyright owner that is granting the License. 14 | 15 | "Legal Entity" shall mean the union of the acting entity and all 16 | other entities that control, are controlled by, or are under common 17 | control with that entity. For the purposes of this definition, 18 | "control" means (i) the power, direct or indirect, to cause the 19 | direction or management of such entity, whether by contract or 20 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 21 | outstanding shares, or (iii) beneficial ownership of such entity. 22 | 23 | "You" (or "Your") shall mean an individual or Legal Entity 24 | exercising permissions granted by this License. 25 | 26 | "Source" form shall mean the preferred form for making modifications, 27 | including but not limited to software source code, documentation 28 | source, and configuration files. 29 | 30 | "Object" form shall mean any form resulting from mechanical 31 | transformation or translation of a Source form, including but 32 | not limited to compiled object code, generated documentation, 33 | and conversions to other media types. 34 | 35 | "Work" shall mean the work of authorship, whether in Source or 36 | Object form, made available under the License, as indicated by a 37 | copyright notice that is included in or attached to the work 38 | (an example is provided in the Appendix below). 39 | 40 | "Derivative Works" shall mean any work, whether in Source or Object 41 | form, that is based on (or derived from) the Work and for which the 42 | editorial revisions, annotations, elaborations, or other modifications 43 | represent, as a whole, an original work of authorship. For the purposes 44 | of this License, Derivative Works shall not include works that remain 45 | separable from, or merely link (or bind by name) to the interfaces of, 46 | the Work and Derivative Works thereof. 47 | 48 | "Contribution" shall mean any work of authorship, including 49 | the original version of the Work and any modifications or additions 50 | to that Work or Derivative Works thereof, that is intentionally 51 | submitted to Licensor for inclusion in the Work by the copyright owner 52 | or by an individual or Legal Entity authorized to submit on behalf of 53 | the copyright owner. For the purposes of this definition, "submitted" 54 | means any form of electronic, verbal, or written communication sent 55 | to the Licensor or its representatives, including but not limited to 56 | communication on electronic mailing lists, source code control systems, 57 | and issue tracking systems that are managed by, or on behalf of, the 58 | Licensor for the purpose of discussing and improving the Work, but 59 | excluding communication that is conspicuously marked or otherwise 60 | designated in writing by the copyright owner as "Not a Contribution." 61 | 62 | "Contributor" shall mean Licensor and any individual or Legal Entity 63 | on behalf of whom a Contribution has been received by Licensor and 64 | subsequently incorporated within the Work. 65 | 66 | 2. Grant of Copyright License. Subject to the terms and conditions of 67 | this License, each Contributor hereby grants to You a perpetual, 68 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 69 | copyright license to reproduce, prepare Derivative Works of, 70 | publicly display, publicly perform, sublicense, and distribute the 71 | Work and such Derivative Works in Source or Object form. 72 | 73 | 3. Grant of Patent License. Subject to the terms and conditions of 74 | this License, each Contributor hereby grants to You a perpetual, 75 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 76 | (except as stated in this section) patent license to make, have made, 77 | use, offer to sell, sell, import, and otherwise transfer the Work, 78 | where such license applies only to those patent claims licensable 79 | by such Contributor that are necessarily infringed by their 80 | Contribution(s) alone or by combination of their Contribution(s) 81 | with the Work to which such Contribution(s) was submitted. If You 82 | institute patent litigation against any entity (including a 83 | cross-claim or counterclaim in a lawsuit) alleging that the Work 84 | or a Contribution incorporated within the Work constitutes direct 85 | or contributory patent infringement, then any patent licenses 86 | granted to You under this License for that Work shall terminate 87 | as of the date such litigation is filed. 88 | 89 | 4. Redistribution. You may reproduce and distribute copies of the 90 | Work or Derivative Works thereof in any medium, with or without 91 | modifications, and in Source or Object form, provided that You 92 | meet the following conditions: 93 | 94 | (a) You must give any other recipients of the Work or 95 | Derivative Works a copy of this License; and 96 | 97 | (b) You must cause any modified files to carry prominent notices 98 | stating that You changed the files; and 99 | 100 | (c) You must retain, in the Source form of any Derivative Works 101 | that You distribute, all copyright, patent, trademark, and 102 | attribution notices from the Source form of the Work, 103 | excluding those notices that do not pertain to any part of 104 | the Derivative Works; and 105 | 106 | (d) If the Work includes a "NOTICE" text file as part of its 107 | distribution, then any Derivative Works that You distribute must 108 | include a readable copy of the attribution notices contained 109 | within such NOTICE file, excluding those notices that do not 110 | pertain to any part of the Derivative Works, in at least one 111 | of the following places: within a NOTICE text file distributed 112 | as part of the Derivative Works; within the Source form or 113 | documentation, if provided along with the Derivative Works; or, 114 | within a display generated by the Derivative Works, if and 115 | wherever such third-party notices normally appear. The contents 116 | of the NOTICE file are for informational purposes only and 117 | do not modify the License. You may add Your own attribution 118 | notices within Derivative Works that You distribute, alongside 119 | or as an addendum to the NOTICE text from the Work, provided 120 | that such additional attribution notices cannot be construed 121 | as modifying the License. 122 | 123 | You may add Your own copyright statement to Your modifications and 124 | may provide additional or different license terms and conditions 125 | for use, reproduction, or distribution of Your modifications, or 126 | for any such Derivative Works as a whole, provided Your use, 127 | reproduction, and distribution of the Work otherwise complies with 128 | the conditions stated in this License. 129 | 130 | 5. Submission of Contributions. Unless You explicitly state otherwise, 131 | any Contribution intentionally submitted for inclusion in the Work 132 | by You to the Licensor shall be under the terms and conditions of 133 | this License, without any additional terms or conditions. 134 | Notwithstanding the above, nothing herein shall supersede or modify 135 | the terms of any separate license agreement you may have executed 136 | with Licensor regarding such Contributions. 137 | 138 | 6. Trademarks. This License does not grant permission to use the trade 139 | names, trademarks, service marks, or product names of the Licensor, 140 | except as required for reasonable and customary use in describing the 141 | origin of the Work and reproducing the content of the NOTICE file. 142 | 143 | 7. Disclaimer of Warranty. Unless required by applicable law or 144 | agreed to in writing, Licensor provides the Work (and each 145 | Contributor provides its Contributions) on an "AS IS" BASIS, 146 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 147 | implied, including, without limitation, any warranties or conditions 148 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 149 | PARTICULAR PURPOSE. You are solely responsible for determining the 150 | appropriateness of using or redistributing the Work and assume any 151 | risks associated with Your exercise of permissions under this License. 152 | 153 | 8. Limitation of Liability. In no event and under no legal theory, 154 | whether in tort (including negligence), contract, or otherwise, 155 | unless required by applicable law (such as deliberate and grossly 156 | negligent acts) or agreed to in writing, shall any Contributor be 157 | liable to You for damages, including any direct, indirect, special, 158 | incidental, or consequential damages of any character arising as a 159 | result of this License or out of the use or inability to use the 160 | Work (including but not limited to damages for loss of goodwill, 161 | work stoppage, computer failure or malfunction, or any and all 162 | other commercial damages or losses), even if such Contributor 163 | has been advised of the possibility of such damages. 164 | 165 | 9. Accepting Warranty or Additional Liability. While redistributing 166 | the Work or Derivative Works thereof, You may choose to offer, 167 | and charge a fee for, acceptance of support, warranty, indemnity, 168 | or other liability obligations and/or rights consistent with this 169 | License. However, in accepting such obligations, You may act only 170 | on Your own behalf and on Your sole responsibility, not on behalf 171 | of any other Contributor, and only if You agree to indemnify, 172 | defend, and hold each Contributor harmless for any liability 173 | incurred by, or claims asserted against, such Contributor by reason 174 | of your accepting any such warranty or additional liability. 175 | 176 | END OF TERMS AND CONDITIONS 177 | 178 | APPENDIX: How to apply the Apache License to your work. 179 | 180 | To apply the Apache License to your work, attach the following 181 | boilerplate notice, with the fields enclosed by brackets "{}" 182 | replaced with your own identifying information. (Don't include 183 | the brackets!) The text should be enclosed in the appropriate 184 | comment syntax for the file format. We also recommend that a 185 | file or class name and description of purpose be included on the 186 | same "printed page" as the copyright notice for easier 187 | identification within third-party archives. 188 | 189 | Copyright {yyyy} {name of copyright owner} 190 | 191 | Licensed under the Apache License, Version 2.0 (the "License"); 192 | you may not use this file except in compliance with the License. 193 | You may obtain a copy of the License at 194 | 195 | http://www.apache.org/licenses/LICENSE-2.0 196 | 197 | Unless required by applicable law or agreed to in writing, software 198 | distributed under the License is distributed on an "AS IS" BASIS, 199 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 200 | See the License for the specific language governing permissions and 201 | limitations under the License. 202 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ### Estimation of Remaining Useful Life using CNN 2 | 3 | #### Related Papers 4 |