from textblob import TextBlob

def program_judge_12(query: str, response: str) -> dict:
    """
    Judges responses based on their subjectivity and polarity, 
    aiming for responses that are factual (low subjectivity) and neutral (zero polarity).
    """
    try:
        # Using TextBlob to get the subjectivity and polarity of the response
        blob = TextBlob(response)
        subjectivity = blob.sentiment.subjectivity
        polarity = blob.sentiment.polarity

        # Score calculation based on subjectivity and polarity
        # Subjectivity score (where 0 is most factual, 1 is most subjective)
        subj_score = 10*(1 - subjectivity)

        # Polarity score (where 0 is most neutral, -1/+1 is most negative/positive)
        pol_score = 10 - 10*abs(polarity)

        # Final score is average of subjectivity and polarity scores
        score = (subj_score + pol_score) / 2

        # Reasoning
        reasoning = f"Scored based on subjectivity ({subj_score:.2f}/10) and polarity ({pol_score:.2f}/10). "
        reasoning += f"Lower subjectivity indicates more factual content; closer to zero polarity indicates neutrality."

        # Criteria
        criteria = "Subjectivity and Polarity"

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