my-python-space / app.py
NoahH7's picture
Update app.py
50963d3 verified
raw
history blame
3.93 kB
import streamlit as st
import requests
from transformers import DetrImageProcessor, DetrForObjectDetection
import torch
from PIL import Image, ImageDraw
# Fonction pour générer du texte avec Gemini
def generate_text_with_gemini(api_key, prompt):
url = "https://generativelanguage.googleapis.com/v1beta/models/gemini-1.5-flash-latest:generateContent"
headers = {
"Content-Type": "application/json",
}
params = {
"key": api_key
}
data = {
"contents": [
{
"parts": [
{"text": prompt}
]
}
]
}
response = requests.post(url, headers=headers, params=params, json=data)
# Debug: Print the raw response
print(f"Gemini response status code: {response.status_code}")
print(f"Gemini response content: {response.text}")
try:
response_json = response.json()
except ValueError:
response_json = {}
print("Failed to decode JSON response")
return response.status_code, response_json
# Fonction de traitement de l'image et d'encadrement des personnes détectées
def process_image(image):
processor = DetrImageProcessor.from_pretrained("facebook/detr-resnet-50", revision="no_timm")
model = DetrForObjectDetection.from_pretrained("facebook/detr-resnet-50", revision="no_timm")
# Préparer l'image pour le modèle
inputs = processor(images=image, return_tensors="pt")
outputs = model(**inputs)
# Post-traitement des résultats pour obtenir les boîtes englobantes et les labels
target_sizes = torch.tensor([image.size[::-1]])
results = processor.post_process_object_detection(outputs, target_sizes=target_sizes, threshold=0.9)[0]
# Convertir l'image pour dessiner
draw_image = image.copy()
draw = ImageDraw.Draw(draw_image)
# Compter le nombre de personnes détectées
persons = 0
for score, label, box in zip(results["scores"], results["labels"], results["boxes"]):
if model.config.id2label[label.item()] == 'person':
persons += 1
box = [round(i, 2) for i in box.tolist()]
# Dessiner le rectangle rouge autour de la personne détectée
draw.rectangle(box, outline="red", width=3)
expected_number_of_persons = 10 # Nombre attendu de personnes
absents = expected_number_of_persons - persons
# Assurez-vous que le nombre d'absents ne soit pas négatif
if absents < 0:
absents = 0
# Générer le contenu de l'email avec Gemini
prompt = f"Notifier de l'absence: Le nombre de personnes présentes est de {persons}. Le nombre d'absents est de {absents}."
gemini_api_key = "AIzaSyCJVUr-76I4TL42X98d9U0THbRD3MKlB38" # Votre clé API Gemini
status_code, response_json = generate_text_with_gemini(gemini_api_key, prompt)
email_content = response_json.get('candidates', [{}])[0].get('content', {}).get('parts', [{}])[0].get('text', 'Content generation failed.')
return draw_image, email_content
# Interface Streamlit
st.title("Analyse d'Images pour Détection de Personnes")
uploaded_files = st.file_uploader("Choisissez jusqu'à 3 images", type=["jpg", "jpeg", "png"], accept_multiple_files=True)
if uploaded_files:
for uploaded_file in uploaded_files:
# Lire l'image téléchargée
image = Image.open(uploaded_file)
st.image(image, caption=f'Image téléchargée : {uploaded_file.name}', use_column_width=True)
# Traitement de l'image
modified_image, email_content = process_image(image)
# Afficher l'image modifiée
st.image(modified_image, caption=f'Image avec personnes détectées : {uploaded_file.name}', use_column_width=True)
# Afficher le contenu généré
st.write(f"**Contenu généré pour {uploaded_file.name} :**")
st.markdown(email_content)