File size: 1,543 Bytes
84efb83 07403e8 84efb83 07403e8 84efb83 07403e8 84efb83 07403e8 84efb83 07403e8 84efb83 07403e8 |
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 49 50 51 52 53 |
from pathlib import Path
import torch
import gradio as gr
from torch import nn
import cv2
LABELS = Path("class_names.txt").read_text().splitlines()
model = nn.Sequential(
nn.Conv2d(1, 32, 3, padding="same"),
nn.ReLU(),
nn.MaxPool2d(2),
nn.Conv2d(32, 64, 3, padding="same"),
nn.ReLU(),
nn.MaxPool2d(2),
nn.Conv2d(64, 128, 3, padding="same"),
nn.ReLU(),
nn.MaxPool2d(2),
nn.Flatten(),
nn.Linear(1152, 256),
nn.ReLU(),
nn.Linear(256, len(LABELS)),
)
state_dict = torch.load("pytorch_model.bin", map_location="cpu")
model.load_state_dict(state_dict, strict=False)
model.eval()
def predict(im):
if(im is not None):
# print(im.size)
im = cv2.resize(im, dsize=(28, 28), interpolation=cv2.INTER_CUBIC)
x = torch.tensor(im, dtype=torch.float32).unsqueeze(0).unsqueeze(0) / 255.0
# print(type(im), im.size)
with torch.no_grad():
out = model(x)
probabilities = torch.nn.functional.softmax(out[0], dim=0)
values, indices = torch.topk(probabilities, 5)
return {LABELS[i]: v.item() for i, v in zip(indices, values)}
sp = gr.Sketchpad(shape=(56,56),brush_radius =1)
interface = gr.Interface(
predict,
inputs=sp,
outputs="label",
theme="huggingface",
title="Reconocimiento de garabtosss",
description="Querés jugar al Picdictonary con una AI? Dibujá un objeto cotidiano y mirá los resultados!",
article="<p style='text-align: center'>Reconocimiento de Garabatos | Demo Model</p>",
live=True,
)
interface.launch() |