from nltk.tokenize import word_tokenize
from collections import Counter

def program_judge_26(query: str, response: str) -> dict:
    """
    Judges responses based on verbosity and redundancy. 
    More verbose and less redundant responses receive higher scores.
    """
    try:
        # Tokenize the response
        tokens = word_tokenize(response)
        
        # Calculate the repetition ratio
        word_counts = Counter(tokens)
        repetition_ratio = sum([count for word, count in word_counts.items() if count > 1]) / len(tokens)
        
        # Calculate the verbosity ratio
        verbosity_ratio = len(tokens) / len(word_tokenize(query))
        
        # Calculate the final score (verbosity_ratio / repetition_ratio * 10)
        # If repetition_ratio is zero, assign maximum score
        if repetition_ratio == 0:
            score = 10.0
        else:
            score = min(10, verbosity_ratio / repetition_ratio * 10)
        
        # Explain the reasoning
        reasoning = "The response was evaluated based on verbosity and redundancy. "
        reasoning += "More verbose and less redundant responses receive higher scores. "
        reasoning += "The verbosity ratio was {}, and the repetition ratio was {}, resulting in a score of {}.".format(
            verbosity_ratio, repetition_ratio, score)

        # Define the criteria
        criteria = "Response Verbosity/Redundancy"
        
        return {
            'score': score,
            'reasoning': reasoning,
            'criteria': criteria
        }
    except Exception as e:
        return {
            'score': 0.0,
            'reasoning': f"Error in evaluation: {str(e)}",
            'criteria': "Error occurred"
        }