from dataclasses import dataclass, field
from typing import Any, Dict

import torch

from distflow.workers.databuffer import DataProto


@dataclass
class ValidationResult:
    """A structured container for a single validation sample's results."""

    input_text: str
    output_text: str
    score: float
    data_source: str
    reward_tensor: torch.Tensor
    extra_rewards: Dict[str, Any] = field(default_factory=dict)


@dataclass
class ValidationPayload:
    """A lightweight, serializable container for validation metrics for efficient gathering."""

    input_text: str
    score: float
    data_source: str
    extra_rewards: Dict[str, Any] = field(default_factory=dict)


@dataclass
class NodeOutput:
    """A standardized return object for all node execution functions."""

    batch: DataProto
    metrics: Dict[str, Any] = field(default_factory=dict)
