colchones / app.py
rpovedav's picture
Create app.py
5feb066 verified
import gradio as gr
import numpy as np
import tensorflow as tf
from tensorflow.keras.models import load_model
from tensorflow.keras.optimizers import Adam
# Configurar TensorFlow en modo compatibilidad (para evitar algunos warnings)
tf.compat.v1.logging.set_verbosity(tf.compat.v1.logging.ERROR)
# Cargar el modelo entrenado
model = load_model('colchones/modelo_colchones.h5') # Aseg煤rate de tener el archivo del modelo correcto y la ruta adecuada
# Compilaci贸n del modelo
optimizer = Adam(learning_rate=0.001)
model.compile(optimizer=optimizer, loss='sparse_categorical_crossentropy', metrics=['accuracy'])
# Forzar la construcci贸n de m茅tricas
model.built = True
# Funci贸n para realizar la predicci贸n
def predict(firmeza, tama帽o, posici贸n, presupuesto):
# Convertir las opciones seleccionadas a n煤meros
firmeza_dict = {'Suave': 0, 'Media': 1, 'Firme': 2}
tama帽o_dict = {'Individual': 0, 'Matrimonial': 1, 'Queen': 2, 'King': 3}
posici贸n_dict = {'Lateral': 0, 'Espalda': 1, 'Est贸mago': 2}
presupuesto_dict = {'Bajo': 0, 'Medio': 1, 'Alto': 2}
colchon_data = [
firmeza_dict.get(firmeza, 0),
tama帽o_dict.get(tama帽o, 0),
posici贸n_dict.get(posici贸n, 0),
presupuesto_dict.get(presupuesto, 0),
firmeza_dict.get(firmeza, 0),
presupuesto_dict.get(presupuesto, 0)
]
# Realizar la predicci贸n
X_pred = np.array([colchon_data]) # Convertir a un arreglo numpy
prediction = model.predict(X_pred)
predicted_class = np.argmax(prediction)
tipos_colchones = ['Muelles Bic贸nicos', 'L谩tex', 'Muelles Ensacados', 'Espumaci贸n HR', 'H铆brido']
imagenes_colchones = {
0: 'colchones/static/images/muelles_biconicos.jpeg',
1: 'colchones/static/images/latex.jpg',
2: 'colchones/static/images/muelle_ensacado.jpg',
3: 'colchones/static/images/espumacion_hr.jpg',
4: 'colchones/static/images/hibrido.jpg'
}
return tipos_colchones[predicted_class], imagenes_colchones.get(predicted_class)
# Definir las opciones para cada caracter铆stica
firmeza_options = ['Suave', 'Media', 'Firme']
tama帽o_options = ['Individual', 'Matrimonial', 'Queen', 'King']
posici贸n_options = ['Lateral', 'Espalda', 'Est贸mago']
presupuesto_options = ['Bajo', 'Medio', 'Alto']
# Crear la interfaz de Gradio
with gr.Blocks() as demo:
gr.Markdown("# Predicci贸n de Tipo de Colch贸n")
firmeza = gr.Dropdown(choices=firmeza_options, label='Firmeza')
tama帽o = gr.Dropdown(choices=tama帽o_options, label='Tama帽o')
posici贸n = gr.Dropdown(choices=posici贸n_options, label='Posici贸n de dormir')
presupuesto = gr.Dropdown(choices=presupuesto_options, label='Presupuesto')
recomendacion = gr.Textbox(label='Tipo de Colch贸n Recomendado')
imagen = gr.Image(label='Imagen del Colch贸n', type='filepath', visible=False)
def make_prediction(firmeza, tama帽o, posici贸n, presupuesto):
tipo_colchon, img_colchon = predict(firmeza, tama帽o, posici贸n, presupuesto)
return tipo_colchon, gr.update(value=img_colchon, visible=True)
def clear_image(*args):
return '', gr.update(value=None, visible=False)
firmeza.change(clear_image, inputs=[firmeza, tama帽o, posici贸n, presupuesto], outputs=[recomendacion, imagen])
tama帽o.change(clear_image, inputs=[firmeza, tama帽o, posici贸n, presupuesto], outputs=[recomendacion, imagen])
posici贸n.change(clear_image, inputs=[firmeza, tama帽o, posici贸n, presupuesto], outputs=[recomendacion, imagen])
presupuesto.change(clear_image, inputs=[firmeza, tama帽o, posici贸n, presupuesto], outputs=[recomendacion, imagen])
btn = gr.Button("Recomendar")
btn.click(fn=make_prediction, inputs=[firmeza, tama帽o, posici贸n, presupuesto], outputs=[recomendacion, imagen])
# Ejecutar la aplicaci贸n
demo.launch()