rpovedav commited on
Commit
5feb066
1 Parent(s): 84413d4

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +85 -0
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()