Spaces:
Build error
Build error
File size: 5,649 Bytes
5c0c96a 538b4a9 548dad1 30e029e 548dad1 322fc19 548dad1 538b4a9 548dad1 30e029e 538b4a9 548dad1 dcf8576 548dad1 58996b4 548dad1 30e029e f5322c1 548dad1 30e029e 548dad1 30e029e f5322c1 30e029e 548dad1 58996b4 548dad1 30e029e 392b7ca 30e029e 538b4a9 30e029e 548dad1 30e029e 6fdacd7 30e029e 392b7ca 30e029e 548dad1 5c0c96a 548dad1 30e029e 548dad1 97ab7f8 30e029e 548dad1 30e029e 548dad1 97ab7f8 5c0c96a 30e029e 548dad1 dcf8576 548dad1 dcf8576 30e029e dcf8576 548dad1 97ab7f8 548dad1 6fdacd7 548dad1 dcf8576 30e029e dcf8576 30e029e 322fc19 548dad1 6fdacd7 5c0c96a 30e029e |
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 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 |
import gradio as gr
import torch
from transformers import AutoProcessor, AutoModelForCausalLM
import pandas as pd
import numpy as np
from PIL import Image
def get_model():
"""Inicializa o modelo uma única vez"""
device = "cuda" if torch.cuda.is_available() else "cpu"
model_name = "microsoft/git-base-coco"
processor = AutoProcessor.from_pretrained(model_name)
model = AutoModelForCausalLM.from_pretrained(model_name)
model = model.to(device)
return processor, model, device
# Base de dados nutricional simplificada
NUTRITION_DB = {
"arroz": {"calorias": 130, "proteinas": 2.7, "carboidratos": 28, "gorduras": 0.3},
"feijão": {"calorias": 77, "proteinas": 5.2, "carboidratos": 13.6, "gorduras": 0.5},
"frango": {"calorias": 165, "proteinas": 31, "carboidratos": 0, "gorduras": 3.6},
"salada": {"calorias": 15, "proteinas": 1.4, "carboidratos": 2.9, "gorduras": 0.2},
}
def process_image(image, progress=gr.Progress()):
"""Processa a imagem e retorna a descrição"""
try:
progress(0.3, desc="Carregando modelo...")
processor, model, device = get_model()
progress(0.5, desc="Processando imagem...")
if isinstance(image, np.ndarray):
image = Image.fromarray(image)
# Processa a imagem
inputs = processor(images=image, return_tensors="pt").to(device)
progress(0.7, desc="Gerando descrição...")
# Gera a descrição
outputs = model.generate(
**inputs,
max_new_tokens=50,
num_beams=1,
temperature=1.0,
)
# Decodifica a saída
description = processor.decode(outputs[0], skip_special_tokens=True)
progress(1.0, desc="Concluído!")
return description.strip()
except Exception as e:
raise gr.Error(f"Erro no processamento da imagem: {str(e)}")
def analyze_foods(description):
"""Analisa a descrição e retorna informações nutricionais"""
try:
# Identifica alimentos da base de dados na descrição
found_foods = []
for food in NUTRITION_DB.keys():
if food in description.lower():
found_foods.append(food)
if not found_foods:
return "Nenhum alimento conhecido identificado.", None, None
# Calcula nutrientes
total_nutrients = {
"calorias": 0,
"proteinas": 0,
"carboidratos": 0,
"gorduras": 0
}
for food in found_foods:
for nutrient, value in NUTRITION_DB[food].items():
total_nutrients[nutrient] += value
# Prepara dados para visualização
table_data = [
["Calorias", f"{total_nutrients['calorias']:.1f} kcal"],
["Proteínas", f"{total_nutrients['proteinas']:.1f}g"],
["Carboidratos", f"{total_nutrients['carboidratos']:.1f}g"],
["Gorduras", f"{total_nutrients['gorduras']:.1f}g"]
]
# Dados para o gráfico
plot_data = pd.DataFrame({
'Nutriente': ['Proteínas', 'Carboidratos', 'Gorduras'],
'Quantidade': [
total_nutrients['proteinas'],
total_nutrients['carboidratos'],
total_nutrients['gorduras']
]
})
analysis = f"""### Alimentos Identificados:
• {', '.join(found_foods)}
### Descrição do Modelo:
{description}
### Análise Nutricional:
• Calorias Totais: {total_nutrients['calorias']:.1f} kcal
• Proteínas: {total_nutrients['proteinas']:.1f}g
• Carboidratos: {total_nutrients['carboidratos']:.1f}g
• Gorduras: {total_nutrients['gorduras']:.1f}g
"""
return analysis, table_data, plot_data
except Exception as e:
raise gr.Error(f"Erro na análise: {str(e)}")
def analyze_image(image):
"""Função principal que coordena o processo de análise"""
try:
# Processa a imagem
description = process_image(image)
# Analisa os alimentos
analysis, table_data, plot_data = analyze_foods(description)
return analysis, table_data, plot_data
except Exception as e:
return str(e), None, None
# Interface Gradio
with gr.Blocks(theme=gr.themes.Soft()) as iface:
gr.Markdown("""
# 🍽️ Análise Nutricional com IA
Faça upload de uma foto do seu prato para análise nutricional.
""")
with gr.Row():
# Coluna de Input
with gr.Column():
image_input = gr.Image(
type="pil",
label="Foto do Prato",
sources=["upload", "webcam"]
)
analyze_btn = gr.Button("📊 Analisar", variant="primary")
# Coluna de Output
with gr.Column():
# Análise textual
output_text = gr.Markdown(label="Análise")
# Tabela nutricional
output_table = gr.Dataframe(
headers=["Nutriente", "Quantidade"],
label="Informação Nutricional"
)
# Gráfico
output_plot = gr.BarPlot(
x="Nutriente",
y="Quantidade",
title="Macronutrientes (g)",
height=300
)
# Eventos
analyze_btn.click(
fn=analyze_image,
inputs=[image_input],
outputs=[output_text, output_table, output_plot]
)
if __name__ == "__main__":
iface.launch() |