import textstat

def program_judge_6(query: str, response: str) -> dict:
    """
    Judges responses based on language quality/readability, using the Flesch Reading Ease score as a metric.
    """
    try:
        # Use Flesch Reading Ease score to evaluate readability. Higher scores indicate easier readability.
        score = textstat.flesch_reading_ease(response)

        # Normalize the score to a 0-10 scale (original scale is 0-100)
        normalized_score = score / 10

        # Reasoning includes the original FRE score for transparency
        reasoning = f"The response received a Flesch Reading Ease score of {score}, " \
                    f"indicating its readability. Higher scores mean the text is easier to read."

        # The criterion for this judgement
        criteria = "Language Quality/Readability"

        return {
            'score': normalized_score,
            'reasoning': reasoning,
            'criteria': criteria
        }

    except Exception as e:
        return {
            'score': 0.0,
            'reasoning': f"Error in evaluation: {str(e)}",
            'criteria': "Error occurred"
        }