import textstat
from textblob import TextBlob

def program_judge_33(query: str, response: str) -> dict:
    """
    Judges responses based on the Language Quality/Readability by using TextBlob for grammar check 
    and Textstat for readability score.
    """
    try:
        blob = TextBlob(response)
        criteria = "Language Quality/Readability"
        grammar_score = len(blob.correct().sentences) / len(blob.sentences)
        
        readability = textstat.flesch_reading_ease(response)
        if readability >= 90.0:
            readability_score = 10
        elif readability >= 80.0:
            readability_score = 9
        elif readability >= 70.0:
            readability_score = 8
        elif readability >= 60.0:
            readability_score = 7
        elif readability >= 50.0:
            readability_score = 6
        elif readability >= 40.0:
            readability_score = 5
        elif readability >= 30.0:
            readability_score = 4
        elif readability >= 20.0:
            readability_score = 3
        elif readability >= 10.0:
            readability_score = 2
        else:
            readability_score = 1

        score = (grammar_score * 5) + (readability_score * 0.5)      
        reasoning = "The score is based on both grammar and readability. The grammar score is calculated by the ratio of correct sentences to total sentences, and the readability score is calculated based on Flesch Reading Ease formula."

        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"
        }