"""
Monte Carlo Tree Search implementation for document QA
"""

from dataclasses import dataclass, field
from typing import Any, List, Optional

@dataclass
class MCTSNode:
    """Monte Carlo Tree Search Node for decision making."""
    state: Any
    parent: Optional['MCTSNode'] = None
    children: List['MCTSNode'] = field(default_factory=list)
    visits: int = 0
    value: float = 0.0
    
    def add_child(self, child_state: Any) -> 'MCTSNode':
        """Add a child node to this node."""
        child = MCTSNode(state=child_state, parent=self)
        self.children.append(child)
        return child
    
    def update(self, reward: float):
        """Update node statistics with a new reward."""
        self.visits += 1
        self.value += (reward - self.value) / self.visits 