from sklearn.feature_extraction.text import TfidfVectorizer
from sklearn.metrics.pairwise import cosine_similarity

def program_judge_34(query: str, response: str) -> dict:
    """
    Judges responses based on their completeness and coverage of the query.
    The function uses TF-IDF vectorization and cosine similarity to determine how well the response covers the query.
    """
    try:
        # Initialize the TF-IDF vectorizer
        vectorizer = TfidfVectorizer()

        # Fit and transform the vectorizer on the query and response
        tfidf_matrix = vectorizer.fit_transform([query, response])

        # Compute the cosine similarity between the query and response
        similarity_score = cosine_similarity(tfidf_matrix[0:1], tfidf_matrix[1:2])[0][0]

        # Scale the similarity score to a 0-10 scale
        score = similarity_score * 10

        # Provide reasoning
        reasoning = f"The response covers {(similarity_score*100):.2f}% of the query."

        # Define the criteria
        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"
        }