"""Commercialized reasoning model implementation for creative reasoning."""

from typing import List, Tuple, Dict
from src.utils.llm_api_client import LLMAPIClient
from src.data_models.task_config import TaskConfig


class reasoning_model:
    """Commercialized reasoning model for creative reasoning tasks with dynamic LLM support."""
    
    def __init__(self, task_config: TaskConfig, backbone_llm_name: str, num_analogous_problems: int, num_solutions_per_problem: int, num_exploratory_ideas: int = 50, num_new_rule_sets: int = 3, num_final_solutions: int = 3, num_solutions_combinational: int = 10, num_thoughts_per_step: int = 5, search_depth: int = 3):
        """Initialize the reasoning model.
        
        Args:
            task_config: TaskConfig object containing task information
            backbone_llm_name: Name of the backbone LLM to use (e.g., "gpt-4o", "claude-3.5-sonnet", "deepseek-reasoner", "o1")
            num_analogous_problems: Number of analogous problems (ignored for commercialized_reasoning_model algorithm)
            num_solutions_per_problem: Number of solutions per problem (ignored for commercialized_reasoning_model algorithm)
            num_exploratory_ideas: Number of exploratory ideas (ignored for commercialized_reasoning_model algorithm)
            num_new_rule_sets: Number of new rule sets (ignored for commercialized_reasoning_model algorithm)
            num_final_solutions: Number of final solutions to generate
            num_solutions_combinational: Number of combinational solutions (ignored for commercialized_reasoning_model algorithm)
            num_thoughts_per_step: Number of thoughts per step (ignored for commercialized_reasoning_model algorithm)
            search_depth: Search depth (ignored for commercialized_reasoning_model algorithm)
        """
        # Validate inputs
        if not isinstance(task_config, TaskConfig):
            raise ValueError("task_config must be a TaskConfig object")
        
        if not isinstance(backbone_llm_name, str) or not backbone_llm_name.strip():
            raise ValueError("backbone_llm_name must be a non-empty string")
        
        # Store all parameters as instance attributes for consistency
        self.task_description_text = task_config.task_description
        self.backbone_llm_name = backbone_llm_name
        self.num_analogous_problems = num_analogous_problems
        self.num_solutions_per_problem = num_solutions_per_problem
        self.num_exploratory_ideas = num_exploratory_ideas
        self.num_new_rule_sets = num_new_rule_sets
        self.num_final_solutions = num_final_solutions
        self.num_solutions_combinational = num_solutions_combinational
        self.num_thoughts_per_step = num_thoughts_per_step
        self.search_depth = search_depth
        
        # Initialize LLM API client
        self.llm_client = LLMAPIClient()
        
        # Initialize intermediate logs collection with detailed format
        self.intermediate_logs: List[Tuple[str, List[Dict]]] = []
    
    def run(self) -> Tuple[str, List[Tuple[str, List[Dict]]]]:
        """Run the reasoning model to generate a solution.
        
        Returns:
            Tuple of (generated solution text, intermediate logs)
            
        Raises:
            RuntimeError: If the model fails to generate a solution
        """
        try:
            # Construct prompt with explicit request for multiple solutions
            prompt = f"{self.task_description_text}\n\nPlease provide {self.num_final_solutions} distinct creative solutions."
            
            # Use LLMAPIClient to call LLM API with specified model and temperature
            solution = self.llm_client.call_llm_model(
                prompt=prompt,
                model_name=self.backbone_llm_name,
                temperature=0.7  # Standard generative temperature
            )
            
            if not solution:
                raise RuntimeError("Failed to generate solution")
            
            # Collect intermediate log in detailed format
            llm_call_log = {
                "model_name": self.backbone_llm_name,
                "temperature": 0.7,
                "prompt": prompt,
                "response": solution,
                "timestamp": "2024-01-01T00:00:00Z"  # Placeholder timestamp
            }
            self.intermediate_logs.append(("LLM Call", [llm_call_log]))
                
            return solution, self.intermediate_logs
            
        except Exception as e:
            raise RuntimeError(f"Error during solution generation: {e}")
