"""Problem adapter interface for multi-problem PSRO support."""

from __future__ import annotations

from abc import ABC, abstractmethod
from typing import List, Dict, Any, Callable, Tuple, Optional

import numpy as np


class ProblemAdapter(ABC):
    """
    Problem adapter interface for extending PSRO to different problems.
    
    Each problem domain (TSP, Graph Coloring, etc.) implements this interface
    to provide problem-specific functionality while keeping core PSRO framework
    problem-agnostic.
    """
    
    @abstractmethod
    def initialize(self, controller) -> None:
        """
        Initialize the problem-specific strategy pools.
        
        This should create initial solver and generator strategies.
        Called by controller during initialization.
        
        Args:
            controller: HeuPSROController instance
        """
        pass
    
    @abstractmethod
    def evaluate_solver(
        self,
        code: str,
        instances: List[Any],
        **kwargs
    ) -> float:
        """
        Evaluate a solver heuristic on given instances.
        
        Args:
            code: Solver code string
            instances: List of problem instances
            **kwargs: Additional problem-specific parameters
            
        Returns:
            Performance metric (lower is better for minimization)
        """
        pass
    
    @abstractmethod
    def evaluate_generator(
        self,
        config: Dict,
        heuristics: List[str],
        sigma_h: np.ndarray,
        **kwargs
    ) -> float:
        """
        Evaluate a generator on mixed solver strategies.
        
        Args:
            config: Generator configuration
            heuristics: List of solver heuristic codes
            sigma_h: Solver mixture weights
            **kwargs: Additional problem-specific parameters
            
        Returns:
            Performance metric (higher is better for generator)
        """
        pass
    
    @abstractmethod
    def create_eoh_bridge(self, config, solver_eoh_dir: str, generator_eoh_dir: str) -> Any:
        """
        Create problem-specific EoH bridge.
        
        Args:
            config: Problem configuration
            solver_eoh_dir: Directory for solver EoH results
            generator_eoh_dir: Directory for generator EoH results
            
        Returns:
            EoH bridge instance for the problem
        """
        pass
    
    # Legacy abstract methods removed: prepare_precomputed_tasks, compute_baseline_metrics, compute_generator_difficulty
    
    def create_sampler(self, pools, config) -> Any:
        """
        Create problem-specific instance sampler.
        
        This is optional - if not implemented, controller may use a default sampler.
        
        Args:
            pools: StrategyPools instance
            config: Problem configuration
            
        Returns:
            Problem-specific sampler instance
        """
        # Default: not implemented, controller will handle
        return None

