idk_test / app.py
dhhd255's picture
Update app.py
7f11cbb
raw
history blame
1.84 kB
import streamlit as st
import torch
from torchvision import transforms
from huggingface_hub import HfFileSystem
from PIL import Image
# Authenticate and download the custom model from Hugging Face Spaces
fs = HfFileSystem()
model_path = 'dhhd255/efficient_net_parkinsons/best_model.pth'
with fs.open(model_path, 'rb') as f:
model_content = f.read()
# Save the model file to disk
with open('best_model.pth', 'wb') as f:
f.write(model_content)
# Load your custom model onto the CPU
model = torch.hub.load('ultralytics/yolov5', 'custom', path='best_model.pth')
model.eval()
# Define a function that takes an image as input and uses the model for inference
def image_classifier(image):
# Preprocess the input image
data_transform = transforms.Compose([
transforms.Lambda(lambda x: x.convert('RGB')),
transforms.Resize((224, 224)),
transforms.ToTensor()
])
image = Image.fromarray(image)
image = data_transform(image)
image = image.unsqueeze(0)
# Use your custom model for inference
with torch.no_grad():
outputs = model(image)
_, predicted = torch.max(outputs.data, 1)
# Map the index to a class label
labels = ['Healthy', 'Parkinson']
predicted_label = labels[predicted.item()]
# Return the result
return outputs[0].numpy(), predicted_label
# Create a Streamlit app with an image upload input
uploaded_file = st.file_uploader('Upload an image')
if uploaded_file is not None:
# Convert the UploadedFile object to a NumPy array
image = Image.open(uploaded_file)
image = np.array(image)
# Use the image for inference
predictions, predicted_label = image_classifier(image)
# Display the result
st.write(f'Predictions: {predictions}')
st.write(f'Predicted label: {predicted_label}')