from sentence_transformers import SentenceTransformer, util

def program_judge_9(query: str, response: str) -> dict:
    """Judges responses based on semantic similarity to the query."""
    try:
        # Initialize the sentence transformer model for semantic similarity
        model = SentenceTransformer('all-MiniLM-L6-v2')
        
        # Compute the embeddings for the query and response
        query_embedding = model.encode(query, convert_to_tensor=True)
        response_embedding = model.encode(response, convert_to_tensor=True)
        
        # Compute the cosine similarity between the query and response embeddings
        similarity_score = util.pytorch_cos_sim(query_embedding, response_embedding)
        
        # Scale the similarity score to 0-10
        score = float(similarity_score * 10)
        
        reasoning = f"The semantic similarity between the query and response is {similarity_score}, scaled to a 0-10 scale is {score}."
        criteria = "Relevance to Query (Semantic Similarity)"
        
        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"
        }