Compararación de tres filamentos distintos
Este experimento dura 20min por que a simple vista se ve que no aporta ninguna mejora, de hecho, añade más inestabilidad al sitema. Se opta por añadir más reglas al sistema, e intentar hacer que la velocidad de tracción no llegue a los límites.
In [1]:
%pylab inline
#Importamos las librerías utilizadas
import numpy as np
import pandas as pd
import seaborn as sns
In [2]:
#Mostramos las versiones usadas de cada librerías
print ("Numpy v{}".format(np.__version__))
print ("Pandas v{}".format(pd.__version__))
print ("Seaborn v{}".format(sns.__version__))
In [14]:
#Abrimos los ficheros con los datos
bq = pd.read_csv('./BQ/BQ.CSV')
formfutura = pd.read_csv('./FORMFUTURA/formfutura.CSV')
filastruder = pd.read_csv('./FILAEXTRUDER/ensayo4.CSV')
In [15]:
#Almacenamos en una lista las columnas del fichero con las que vamos a trabajar
columns = ['Diametro X']
In [17]:
#Mostramos un resumen de los datos obtenidoss
bq[columns].describe()
formfutura[columns].describe()
filastruder[columns].describe()
Out[17]:
Representamos ambos diámetro y la velocidad de la tractora en la misma gráfica
In [25]:
datos.ix[:, "Diametro X":"Diametro Y"].plot(figsize=(16,10),ylim=(0.5,3)).hlines([1.85,1.65],0,3500,colors='r')
#datos['RPM TRAC'].plot(secondary_y='RPM TRAC')
Out[25]:
In [26]:
datos.ix[:, "Diametro X":"Diametro Y"].boxplot(return_type='axes')
Out[26]:
Aumentando la velocidad se ha conseguido que disminuya el valor máxima, sin embargo ha disminuido el valor mínimo. Para la siguiente iteracción, se va a volver a las velocidades de 1.5- 3.4 y se van a añadir más reglas con unos incrementos de velocidades menores, para evitar saturar la velocidad de traccción tanto a nivel alto como nivel bajo.
Comparativa de Diametro X frente a Diametro Y para ver el ratio del filamento
In [27]:
plt.scatter(x=datos['Diametro X'], y=datos['Diametro Y'], marker='.')
Out[27]:
In [28]:
datos_filtrados = datos[(datos['Diametro X'] >= 0.9) & (datos['Diametro Y'] >= 0.9)]
In [29]:
#datos_filtrados.ix[:, "Diametro X":"Diametro Y"].boxplot(return_type='axes')
In [30]:
plt.scatter(x=datos_filtrados['Diametro X'], y=datos_filtrados['Diametro Y'], marker='.')
Out[30]:
In [31]:
ratio = datos_filtrados['Diametro X']/datos_filtrados['Diametro Y']
ratio.describe()
Out[31]:
In [32]:
rolling_mean = pd.rolling_mean(ratio, 50)
rolling_std = pd.rolling_std(ratio, 50)
rolling_mean.plot(figsize=(12,6))
# plt.fill_between(ratio, y1=rolling_mean+rolling_std, y2=rolling_mean-rolling_std, alpha=0.5)
ratio.plot(figsize=(12,6), alpha=0.6, ylim=(0.5,1.5))
Out[32]:
Calculamos el número de veces que traspasamos unos límites de calidad. $Th^+ = 1.85$ and $Th^- = 1.65$
In [33]:
Th_u = 1.85
Th_d = 1.65
In [34]:
data_violations = datos[(datos['Diametro X'] > Th_u) | (datos['Diametro X'] < Th_d) |
(datos['Diametro Y'] > Th_u) | (datos['Diametro Y'] < Th_d)]
In [35]:
data_violations.describe()
Out[35]:
In [36]:
data_violations.plot(subplots=True, figsize=(12,12))
Out[36]:
In [ ]: