from readability import Readability
import spacy

def program_judge_1(query: str, response: str) -> dict:
    """
    Judges responses based on clarity and conciseness. Clarity is measured by 
    the readability index (Flesch-Kincaid grade level) and conciseness is measured 
    by the ratio of the number of sentences in the response to the number of sentences 
    in the query.
    """
    try:
        # Load English tokenizer, tagger, parser, NER and word vectors
        nlp = spacy.load("en_core_web_sm")

        # Process whole documents
        query_doc = nlp(query)
        response_doc = nlp(response)

        # Analyze syntax
        query_sents = list(query_doc.sents)
        response_sents = list(response_doc.sents)

        # Calculate conciseness
        conciseness = max(0, min(5, (len(query_sents) / len(response_sents)) * 5))

        # Calculate clarity
        r = Readability(response)
        fkg_score = int(r.flesch_kincaid().grade_level)
        clarity = max(0, min(5, fkg_score / 2))

        # Calculate final score
        score = clarity + conciseness

        # Ensure score is within bounds
        if score < 0:
            score = 0.0
        if score > 10:
            score = 10.0

        reasoning = f"Conciseness: {conciseness*5}, Clarity (Flesch-Kincaid grade level): {fkg_score}"

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