from sklearn.feature_extraction.text import CountVectorizer

def program_judge_30(query: str, response: str) -> dict:
    """
    Judges responses based on the completeness/coverage of the answer. 
    It uses the CountVectorizer to convert the query and response into a matrix of token counts. 
    Then it calculates the score by comparing the counts of the tokens in the query and the response.
    """
    try:
        vectorizer = CountVectorizer().fit_transform([query, response])
        vectors = vectorizer.toarray()

        query_vector = vectors[0]
        response_vector = vectors[1]

        score = 0
        for i in range(len(query_vector)):
            if query_vector[i] != 0 and response_vector[i] != 0:
                score += 1
        
        score = (score / len(query_vector)) * 10
        reasoning = "The score is based on the number of tokens from the query that are also present in the response."
        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"
        }