import torch

def get_output(data_loader, model, device):
    """
    Run model over data_loader and collect all predicted outputs (for embeddings or soft outputs).
    """
    model.eval()
    all_outputs = []
    with torch.no_grad():
        for X, _ in data_loader:
            X = torch.tensor(X, dtype=torch.float32).to(device)
            outputs = model(X)
            all_outputs.append(outputs.cpu())
    return torch.cat(all_outputs, dim=0)
