forked from cwhite98/SmartBuilding
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfrio_2_cop.py
90 lines (83 loc) · 4.21 KB
/
frio_2_cop.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
import json
import joblib
import boto3
import pandas as pd
from sklearn.cluster import KMeans
from sklearn.neighbors import KNeighborsRegressor
import s3fs
import os
key = os.environ['aws_key']
secret_key = os.environ['aws_secret_key']
s3 = boto3.client('s3',
aws_access_key_id=key,
aws_secret_access_key=secret_key,
region_name='us-east-2')
BUCKET_NAME = 'smart-building-integrador'
url = 'https://smart-building-integrador.s3.us-east-2.amazonaws.com/HVAC.csv'
dataFrio2_cop = pd.read_csv(url)
def predict_frio_2_cop(kmeans, clusters):
centroids = kmeans.cluster_centers_
diagnostico = ''
diagnosticos = []
minPotenciaFrio2 = 0
maxPotenciaFrio2 = 27
minPotenciaTermicaFrio2 = 0
maxPotenciaTermicaFrio2 = 97
minTempExterior = 10
maxTempExterior = 27
for cluster in clusters:
if not ((centroids[cluster][0] > minPotenciaFrio2) and (centroids[cluster][0] <= maxPotenciaFrio2)):
diagnosticos.append('Revisar la anomalia derivada al valor de la POTENCIA GRUPO FRÍO 2.')
if not ((centroids[cluster][1] > minPotenciaTermicaFrio2) and (centroids[cluster][1] <= maxPotenciaTermicaFrio2)):
diagnosticos.append('Revisar la anomalia derivada al valor de la POTENCIA TERMICA GRUPO FRIO 2.')
if not ((centroids[cluster][2] > minTempExterior) and (centroids[cluster][2] <= maxTempExterior)):
diagnosticos.append('La TEMPERATURA EXTERIOR esta generando una anomalia en el climatizador.')
if (len(diagnosticos) == 0):
diagnostico = 'Máquina GRUPO FRÍO 2 apagada o iniciando.'
else:
for i in range(len(diagnosticos) - 1):
if (len(diagnosticos) == 1):
diagnostico = diagnosticos[0]
else:
diagnostico += diagnosticos[i] + ' | '
diagnostico += diagnosticos[-1]
return diagnostico
def lambda_handler(event, context):
diccionario = []
urlContadores = 'https://smart-building-integrador.s3.us-east-2.amazonaws.com/indices/indexFrio2_COP.csv'
data = pd.read_csv(urlContadores, sep='\s*,\s*', header=0, encoding='ascii', engine='python')
valorDataFrio2_cop = data['grupo_frio2_cop']
#Cargar modelos
s3.download_file(BUCKET_NAME, 'models/neigh_frio_2.pkl', '/tmp/neigh_frio_2.pkl')
neigh = joblib.load('/tmp/neigh_frio_2.pkl')
s3.download_file(BUCKET_NAME, 'models/kmeans_frio_2_cop.pkl', '/tmp/kmeans_frio_2_cop.pkl')
kmeans = joblib.load('/tmp/kmeans_frio_2_cop.pkl')
for i in range(int(valorDataFrio2_cop), int(valorDataFrio2_cop)+10):
df = dataFrio2_cop.iloc[i]
# get data to be predicted
X = [[float(df['POTENCIA GRUPO FRÍO 2']), float(df['POTENCIA TERMICA GRUPO FRIO 2']),
float(df['TEMPERATURA EXTERIOR'])]]
prediction_ = neigh.predict(X)
prediction = float(prediction_[0])
valorReal = float(df['C_O_P MÁQUINA GRUPO FRÍO 2'])
# COP malo --> diagnostico (clustering)
kmeans_prediction = ' '
if (((valorReal <= 3.5) or (valorReal >= 4.5)) and ((prediction <= 3.5) or (prediction >= 4.5))
or (valorReal <= prediction - 0.5) or (valorReal >= prediction + 0.5)):
clusters = kmeans.predict(X)
kmeans_prediction = predict_frio_2_cop(kmeans, clusters)
# Diccionario con todas las variables de un registro que se va retornar
df.loc['C_O_P MÁQUINA GRUPO FRÍO 2 PREDICHO'] = prediction
df.loc['Diagnostico'] = kmeans_prediction
df2 = df.drop(labels=['Diagnostico', 'Fecha- hora de lectura'])
df2 = df2.apply(lambda x: round(float(x), 3))
dfAux = df[['Diagnostico', 'Fecha- hora de lectura']]
dfR = pd.concat([df2, dfAux], axis=0, sort=False)
registro_dict = dfR.to_dict()
diccionario.append(registro_dict)
data['grupo_frio2_cop'] = valorDataFrio2_cop + 10
bytes_to_write = data.to_csv(None, index=False).encode()
fs = s3fs.S3FileSystem(key=key, secret=secret_key)
with fs.open('s3://smart-building-integrador/indices/indexFrio2_COP.csv', 'wb') as f:
f.write(bytes_to_write)
return(diccionario)