import nltk
from nltk.corpus import stopwords
from nltk.tokenize import word_tokenize

def program_judge_16(query: str, response: str) -> dict:
    """
    Judges responses based on clarity and conciseness. It assigns a high score for concise, clear responses
    and a low score for verbose or unclear responses.
    """
    try:
        # Tokenize the response
        response_tokens = word_tokenize(response)
        # Remove punctuation and convert to lower case
        response_tokens = [word.lower() for word in response_tokens if word.isalpha()]
        # Remove stopwords
        response_tokens = [word for word in response_tokens if word not in stopwords.words('english')]

        # Calculate the clarity score: high if the response contains all words in the query, low otherwise
        query_words = word_tokenize(query)
        clarity_score = sum([1 for word in query_words if word in response_tokens]) / len(query_words)

        # Calculate the conciseness score: high if the response is short, low otherwise
        conciseness_score = 1 / len(response_tokens)

        # Combine the two scores
        score = (clarity_score + conciseness_score) / 2 * 10

        # Generate reasoning
        reasoning = f"The response was judged based on its clarity and conciseness. " \
                    f"It received a clarity score of {clarity_score * 10:.2f} and a conciseness score of {conciseness_score * 10:.2f}."

        criteria = "Clarity and Conciseness"

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