Spaces:
Sleeping
Sleeping
import streamlit as st | |
import os | |
import numpy as np | |
import pandas as pd | |
from glob import glob | |
import pickle | |
from sklearn.model_selection import train_test_split | |
from sklearn.ensemble import RandomForestRegressor | |
from sklearn.metrics import mean_squared_error, mean_absolute_error | |
from scipy.stats import pearsonr | |
import matplotlib.pyplot as plt | |
import seaborn as sns | |
import torch | |
import torchvision.transforms as transforms | |
from PIL import Image | |
from facenet_pytorch import MTCNN, InceptionResnetV1 | |
import warnings | |
warnings.filterwarnings("ignore") | |
device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu') | |
# If required, create a face detection pipeline using MTCNN: | |
mtcnn = MTCNN( | |
image_size=160, margin=40, min_face_size=20, | |
thresholds=[0.6, 0.7, 0.7], factor=0.709, post_process=True, | |
device=device | |
) | |
mtcnn2 = MTCNN( | |
image_size=160, margin=40, min_face_size=20, | |
thresholds=[0.6, 0.7, 0.7], factor=0.709, post_process=False, | |
device=device | |
) | |
# Create an inception resnet (in eval mode): | |
resnet = InceptionResnetV1(pretrained='vggface2').eval().to(device) | |
# Define the transformation to preprocess the images | |
preprocess = transforms.Compose([ | |
transforms.Resize((160, 160)), | |
transforms.ToTensor(), | |
transforms.Normalize(mean=[0.5, 0.5, 0.5], std=[0.5, 0.5, 0.5]) | |
]) | |
def extract_features(img): | |
img = img.convert('RGB') | |
face = mtcnn(img) | |
if face is None: | |
face = preprocess(img) | |
img = torch.stack([face]).to(device) | |
with torch.no_grad(): | |
features = resnet(img) | |
return features[0].cpu().numpy() | |
with open("/app/models/lr.p", "rb") as f: | |
lr = pickle.load(f) | |
img_file_buffer = st.camera_input("Take a picture") | |
if img_file_buffer is not None: | |
# To read image file buffer as a PIL Image: | |
img = Image.open(img_file_buffer) | |
detected_image = Image.fromarray(mtcnn2(img).numpy().transpose(1, 2, 0).astype(np.uint8)) | |
st.image(detected_image, caption="Detected Face") | |
embeddings = extract_features(img) | |
bmi = round(lr.predict([embeddings])[0], 2) | |
st.write(f"Your BMI is {bmi}") |