from textblob import TextBlob

def program_judge_28(query: str, response: str) -> dict:
    """
    Judges responses based on the completeness and coverage of the answer, 
    using TextBlob's noun phrase extraction as a simple form of topic modeling.
    """
    try:
        query_blob = TextBlob(query)
        response_blob = TextBlob(response)

        query_topics = query_blob.noun_phrases
        response_topics = response_blob.noun_phrases

        # Score calculation based on the proportion of query topics covered in the response.
        if len(query_topics) == 0:
            score = 0.0
            reasoning = "The query does not contain any discernible topics."
        else:
            coverage = len(set(query_topics) & set(response_topics)) / len(set(query_topics))
            score = round(coverage * 10, 2)  # converting to 0-10 scale

            if score == 10:
                reasoning = "The response covers all the topics mentioned in the query."
            elif score > 0:
                reasoning = "The response covers some of the topics mentioned in the query."
            else:
                reasoning = "The response does not cover any of the topics mentioned in the query."

        return {
            'score': score,
            'reasoning': reasoning,
            'criteria': "Completeness/Coverage of Answer"
        }

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