import spacy
from collections import Counter

def program_judge_31(query: str, response: str) -> dict:
    """
    Judges responses based on verbosity and redundancy. More verbose and less redundant responses are scored higher.
    """
    try:
        nlp = spacy.load('en_core_web_sm')
        doc = nlp(response)
        total_words = len([token.text for token in doc if not token.is_stop])
        
        unique_words = len(Counter([token.lemma_ for token in doc if not token.is_stop]))
        redundancy_ratio = unique_words / total_words if total_words > 0 else 0
        
        # Adjusting verbosity score to be between 0 and 10
        verbosity_score = min(total_words / 10, 10)
        
        # Adjusting redundancy score to be between 0 and 10
        redundancy_score = (1 - redundancy_ratio) * 10
        
        score = (verbosity_score + redundancy_score) / 2
        reasoning = f"Response has a verbosity score of {verbosity_score} and a redundancy score of {redundancy_score}."
        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"
        }