import spacy
from spacy import displacy
from collections import Counter
import en_core_web_sm
nlp = en_core_web_sm.load()

def program_judge_3(query: str, response: str) -> dict:
    """
    Judges responses based on Logical Coherence. It checks if the important entities (such as proper nouns, dates) 
    mentioned in the query are also mentioned in the response. If they are, the response is likely to be logically 
    coherent with the query.
    """
    try:
        # Parse the query and response
        query_doc = nlp(query)
        response_doc = nlp(response)

        # Extract the entities
        query_entities = [str(ent) for ent in query_doc.ents]
        response_entities = [str(ent) for ent in response_doc.ents]

        # Check the logical coherence by checking if the entities in query are also present in response
        matched_entities = [entity for entity in query_entities if entity in response_entities]

        # Calculate score based on the ratio of matched entities to total entities in the query
        if len(query_entities) > 0:
            score = len(matched_entities) / len(query_entities) * 10
        else:
            score = 10.0  # If there are no entities in the query, we assume the response is logically coherent

        reasoning = f"The response contained {len(matched_entities)} out of {len(query_entities)} important entities from the query."

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