Create app.py
Browse files
app.py
ADDED
@@ -0,0 +1,85 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import gradio as gr
|
2 |
+
import numpy as np
|
3 |
+
import tensorflow as tf
|
4 |
+
from tensorflow.keras.models import load_model
|
5 |
+
from tensorflow.keras.optimizers import Adam
|
6 |
+
|
7 |
+
# Configurar TensorFlow en modo compatibilidad (para evitar algunos warnings)
|
8 |
+
tf.compat.v1.logging.set_verbosity(tf.compat.v1.logging.ERROR)
|
9 |
+
|
10 |
+
# Cargar el modelo entrenado
|
11 |
+
model = load_model('colchones/modelo_colchones.h5') # Asegúrate de tener el archivo del modelo correcto y la ruta adecuada
|
12 |
+
|
13 |
+
# Compilación del modelo
|
14 |
+
optimizer = Adam(learning_rate=0.001)
|
15 |
+
model.compile(optimizer=optimizer, loss='sparse_categorical_crossentropy', metrics=['accuracy'])
|
16 |
+
|
17 |
+
# Forzar la construcción de métricas
|
18 |
+
model.built = True
|
19 |
+
|
20 |
+
# Función para realizar la predicción
|
21 |
+
def predict(firmeza, tamaño, posición, presupuesto):
|
22 |
+
# Convertir las opciones seleccionadas a números
|
23 |
+
firmeza_dict = {'Suave': 0, 'Media': 1, 'Firme': 2}
|
24 |
+
tamaño_dict = {'Individual': 0, 'Matrimonial': 1, 'Queen': 2, 'King': 3}
|
25 |
+
posición_dict = {'Lateral': 0, 'Espalda': 1, 'Estómago': 2}
|
26 |
+
presupuesto_dict = {'Bajo': 0, 'Medio': 1, 'Alto': 2}
|
27 |
+
|
28 |
+
colchon_data = [
|
29 |
+
firmeza_dict.get(firmeza, 0),
|
30 |
+
tamaño_dict.get(tamaño, 0),
|
31 |
+
posición_dict.get(posición, 0),
|
32 |
+
presupuesto_dict.get(presupuesto, 0),
|
33 |
+
firmeza_dict.get(firmeza, 0),
|
34 |
+
presupuesto_dict.get(presupuesto, 0)
|
35 |
+
]
|
36 |
+
|
37 |
+
# Realizar la predicción
|
38 |
+
X_pred = np.array([colchon_data]) # Convertir a un arreglo numpy
|
39 |
+
prediction = model.predict(X_pred)
|
40 |
+
predicted_class = np.argmax(prediction)
|
41 |
+
|
42 |
+
tipos_colchones = ['Muelles Bicónicos', 'Látex', 'Muelles Ensacados', 'Espumación HR', 'Híbrido']
|
43 |
+
imagenes_colchones = {
|
44 |
+
0: 'colchones/static/images/muelles_biconicos.jpeg',
|
45 |
+
1: 'colchones/static/images/latex.jpg',
|
46 |
+
2: 'colchones/static/images/muelle_ensacado.jpg',
|
47 |
+
3: 'colchones/static/images/espumacion_hr.jpg',
|
48 |
+
4: 'colchones/static/images/hibrido.jpg'
|
49 |
+
}
|
50 |
+
|
51 |
+
return tipos_colchones[predicted_class], imagenes_colchones.get(predicted_class)
|
52 |
+
|
53 |
+
# Definir las opciones para cada característica
|
54 |
+
firmeza_options = ['Suave', 'Media', 'Firme']
|
55 |
+
tamaño_options = ['Individual', 'Matrimonial', 'Queen', 'King']
|
56 |
+
posición_options = ['Lateral', 'Espalda', 'Estómago']
|
57 |
+
presupuesto_options = ['Bajo', 'Medio', 'Alto']
|
58 |
+
|
59 |
+
# Crear la interfaz de Gradio
|
60 |
+
with gr.Blocks() as demo:
|
61 |
+
gr.Markdown("# Predicción de Tipo de Colchón")
|
62 |
+
firmeza = gr.Dropdown(choices=firmeza_options, label='Firmeza')
|
63 |
+
tamaño = gr.Dropdown(choices=tamaño_options, label='Tamaño')
|
64 |
+
posición = gr.Dropdown(choices=posición_options, label='Posición de dormir')
|
65 |
+
presupuesto = gr.Dropdown(choices=presupuesto_options, label='Presupuesto')
|
66 |
+
recomendacion = gr.Textbox(label='Tipo de Colchón Recomendado')
|
67 |
+
imagen = gr.Image(label='Imagen del Colchón', type='filepath', visible=False)
|
68 |
+
|
69 |
+
def make_prediction(firmeza, tamaño, posición, presupuesto):
|
70 |
+
tipo_colchon, img_colchon = predict(firmeza, tamaño, posición, presupuesto)
|
71 |
+
return tipo_colchon, gr.update(value=img_colchon, visible=True)
|
72 |
+
|
73 |
+
def clear_image(*args):
|
74 |
+
return '', gr.update(value=None, visible=False)
|
75 |
+
|
76 |
+
firmeza.change(clear_image, inputs=[firmeza, tamaño, posición, presupuesto], outputs=[recomendacion, imagen])
|
77 |
+
tamaño.change(clear_image, inputs=[firmeza, tamaño, posición, presupuesto], outputs=[recomendacion, imagen])
|
78 |
+
posición.change(clear_image, inputs=[firmeza, tamaño, posición, presupuesto], outputs=[recomendacion, imagen])
|
79 |
+
presupuesto.change(clear_image, inputs=[firmeza, tamaño, posición, presupuesto], outputs=[recomendacion, imagen])
|
80 |
+
|
81 |
+
btn = gr.Button("Recomendar")
|
82 |
+
btn.click(fn=make_prediction, inputs=[firmeza, tamaño, posición, presupuesto], outputs=[recomendacion, imagen])
|
83 |
+
|
84 |
+
# Ejecutar la aplicación
|
85 |
+
demo.launch()
|