"""Utility functions for loading and preparing models for evaluation."""
from typing import Dict, Tuple, Optional
from transformers import PreTrainedModel, PreTrainedTokenizer
from src.model_loading.common.models import ModelIdentifier
from src.model_loading.common.config import ModelConfig
from src.model_loading.manager import ModelManager

def load_model_for_evaluation(
    model_identifier: ModelIdentifier,
    device: str = "cuda",
    max_memory: Optional[Dict[str, str]] = None,
    apply_compile: bool = True,
) -> Tuple[PreTrainedModel, PreTrainedTokenizer]:
    """Load and prepare a model and tokenizer for reliability evaluation."""
    config = ModelConfig(
        identifier=model_identifier,
        device=device,
        max_memory=max_memory,
        apply_compile=apply_compile,
    )
    manager = ModelManager()
    model, tokenizer = manager.load_model(config)
    
    # Configure tokenizer for generation
    tokenizer.pad_token_id = tokenizer.eos_token_id
    model.eval()
    
    return model, tokenizer
