Spaces:
Running
Running
import gradio as gr | |
from transformers import TimeSeriesTransformerForPrediction, TimeSeriesTransformerConfig | |
import torch | |
import pandas as pd | |
import numpy as np | |
# Carregar configuração | |
config = TimeSeriesTransformerConfig.from_pretrained("google/timesfm-2.0-500m-pytorch") | |
config.prediction_length = 3 | |
config.context_length = 12 | |
# Carregar modelo | |
model = TimeSeriesTransformerForPrediction.from_pretrained( | |
"google/timesfm-2.0-500m-pytorch", | |
config=config, | |
torch_dtype="auto" | |
) | |
def prever_vendas(historico): | |
# Converter entrada em tensor | |
historico = [float(x) for x in historico.split(",") if x.strip()] # Ignorar valores vazios | |
if len(historico) != config.context_length: | |
raise ValueError(f"O histórico deve ter exatamente {config.context_length} valores numéricos.") | |
# Formatar dados como tensor (batch, sequence_length) | |
inputs = torch.tensor(historico).unsqueeze(0) | |
# Gerar previsão | |
with torch.no_grad(): | |
outputs = model(inputs) # Método correto é __call__, não predict | |
forecast = outputs.mean.squeeze().tolist() | |
return np.round(forecast, 2) | |
# Interface Gradio | |
iface = gr.Interface( | |
fn=prever_vendas, | |
inputs=gr.Textbox(label=f"Histórico de Vendas ({config.context_length} meses, separados por vírgulas)"), | |
outputs=gr.Textbox(label=f"Previsão para os Próximos {config.prediction_length} Meses"), | |
examples=[ | |
["140,155,160,145,150,165,170,160,175,160,155,170"], # 12 meses | |
] | |
) | |
iface.launch() |