forked from bnsreenu/python_for_microscopists
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path088-autoencoder_anomaly_V0.1.py
98 lines (69 loc) · 2.92 KB
/
088-autoencoder_anomaly_V0.1.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#!/usr/bin/env python
__author__ = "Sreenivas Bhattiprolu"
__license__ = "Feel free to copy, I appreciate if you acknowledge Python for Microscopists"
# https://www.youtube.com/watch?v=u1vLJBwOFC8
"""
Artificial dataset created in Excel (anomaly.csv).
First column is Date
Second column is supposed to be Power reading: Good between 90 and 100
Third column: Detector reading: Good between 8-12
Last coumn is QUality which is either Good or Bad.
"""
import pandas as pd
df = pd.read_csv('anomaly.csv')
#print(df.columns)
#print(df.head())
#df['Power'].plot(kind='hist', title='Power Reading', bins=30, figsize=(12,10))
#Most values between 90 and 100 with some outliers / anomalies
#df['Detector'].plot(kind='hist', title='Detector Reading', bins=30, figsize=(12,10))
#Most values between 8 and 12 with some outliers / anomalies
#To see how the data is spread betwen Good and Bad
print(df.groupby('Quality')['Quality'].count())
df.drop(['Date'], axis=1, inplace=True)
#print(df.head())
#If there are missing entries, drop them.
df.dropna(inplace=True,axis=1)
#COnvert non-numeric to numeric
df.Quality[df.Quality == 'Good'] = 1
df.Quality[df.Quality == 'Bad'] = 2
good_mask = df['Quality']== 1 #All good to be True for good data points
bad_mask = df['Quality']== 2 #All values False for good data points
#print(good_mask.head())
df.drop('Quality',axis=1,inplace=True)
df_good = df[good_mask]
df_bad = df[bad_mask]
print(f"Good count: {len(df_good)}")
print(f"Bad count: {len(df_bad)}")
# This is the feature vector that goes to the neural net
x_good = df_good.values
x_bad = df_bad.values
from sklearn.model_selection import train_test_split
x_good_train, x_good_test = train_test_split(
x_good, test_size=0.25, random_state=42)
print(f"Good train count: {len(x_good_train)}")
print(f"Good test count: {len(x_good_test)}")
#########
#Define the autoencoder model
#Since we're dealing with numeric values we can use only Dense layers.
from sklearn import metrics
import numpy as np
import pandas as pd
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Dense
model = Sequential()
model.add(Dense(10, input_dim=x_good.shape[1], activation='relu'))
model.add(Dense(3, activation='relu'))
model.add(Dense(10, activation='relu'))
model.add(Dense(x_good.shape[1]))
model.compile(loss='mean_squared_error', optimizer='adam')
model.summary()
model.fit(x_good_train,x_good_train,verbose=1,epochs=100)
pred = model.predict(x_good_test)
score1 = np.sqrt(metrics.mean_squared_error(pred,x_good_test))
pred = model.predict(x_good)
score2 = np.sqrt(metrics.mean_squared_error(pred,x_good))
pred = model.predict(x_bad)
score3 = np.sqrt(metrics.mean_squared_error(pred,x_bad))
print(f"Insample Good Score (RMSE): {score1}".format(score1))
print(f"Out of Sample Good Score (RMSE): {score2}")
print(f"Bad sample Score (RMSE): {score3}")