from textblob import TextBlob
from sklearn.feature_extraction.text import CountVectorizer
import pandas as pd

def program_judge_24(query: str, response: str) -> dict:
    """
    Judges responses based on the completeness/coverage of the answer.
    The score is determined by computing the proportion of query terms 
    that are present in the response. Higher scores represent more
    complete coverage of the query in the response.
    """
    try:
        # Compute a binary vector representation of the query and response
        vectorizer = CountVectorizer(binary=True)
        term_matrix = vectorizer.fit_transform([query, response])
        
        # Create a DataFrame for easier comparison
        term_df = pd.DataFrame(term_matrix.toarray(), columns=vectorizer.get_feature_names_out())
        
        # Determine the total number of query terms
        total_query_terms = term_df.loc[0].sum()
        
        # Determine the number of query terms that are present in the response
        query_terms_in_response = (term_df.loc[0] & term_df.loc[1]).sum()
        
        # Compute the completeness score as the proportion of query terms present in the response
        score = (query_terms_in_response / total_query_terms) * 10
        
        reasoning = "The response covers {:.2f}% of the terms in the query.".format(score * 10)
        criteria = "Completeness/Coverage of Answer"

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