Spaces:
Runtime error
Runtime error
File size: 1,626 Bytes
c090e21 8baa190 3443a2f 8baa190 3443a2f c090e21 3443a2f 0bb8575 3443a2f 18dde07 3443a2f 18dde07 3443a2f 18dde07 3443a2f 18dde07 3443a2f c090e21 3443a2f 8baa190 3443a2f c090e21 3443a2f c090e21 3443a2f |
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 |
import gradio as gr
import torch
from torchvision import models, transforms
from PIL import Image
import json
# Cargar la configuración
#with open("reconocimiento_facial/config.json") as f:
with open("config.json") as f:
config = json.load(f)
# Definir las etiquetas de las clases
class_labels = ["Angry", "Disgust", "Fear", "Happy", "Sad", "Surprise", "Neutral"]
# Crear el modelo y ajustar la última capa
model = models.resnet50()
model.fc = torch.nn.Linear(model.fc.in_features, len(class_labels)) # len(class_labels) = 7
# Cargar los pesos del modelo
model.load_state_dict(torch.load("reconocimiento_facial/pytorch_model.bin"))
model.eval()
# Preprocesamiento de imágenes
transform = transforms.Compose([
transforms.Resize((config["image_size"], config["image_size"])),
transforms.ToTensor(),
transforms.Normalize(mean=config["transformations"]["Normalize"]["mean"], std=config["transformations"]["Normalize"]["std"])
])
def predict(image):
image = transform(image).unsqueeze(0)
with torch.no_grad():
output = model(image)
_, predicted = torch.max(output, 1)
predicted_class = class_labels[predicted.item()]
return predicted_class
# Crear la interfaz de Gradio
iface = gr.Interface(
fn=predict,
inputs=gr.Image(type="pil"),
outputs=gr.Textbox(label="Predicted Expression"),
title="Reconocimiento Facial de Expresiones",
description="Sube una imagen de una cara para clasificar la expresión facial en una de las siete categorías: Enfadado, Disgustado, Miedo, Feliz, Triste, Sorprendido y Neutral."
)
# Ejecutar la interfaz
iface.launch() |