# Copyright 2024 Bytedance Ltd. and/or its affiliates
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import contextlib

try:
    from math_verify.metric import math_metric
    from math_verify.parser import ExprExtractionConfig, LatexExtractionConfig
except ImportError:
    print("To use Math-Verify, please install it first by running `pip install math-verify`.")


def compute_score(model_output: str, ground_truth: str) -> bool:
    def normalize_numeric_answer(answer: str) -> str:
        """Normalize numeric answers for better comparison"""
        answer = answer.strip()
        try:
            # Try to convert to float first, then back to string to normalize format
            if answer.replace('.', '').replace('-', '').replace('+', '').isdigit():
                return str(float(answer))
            # Handle scientific notation
            if 'e' in answer.lower() or 'E' in answer:
                return str(float(answer))
        except (ValueError, TypeError):
            pass
        return answer

    # Normalize both answers before verification
    ground_truth_normalized = normalize_numeric_answer(ground_truth)
    model_output_normalized = normalize_numeric_answer(model_output)
    
    # If both are numeric and equal after normalization, return True directly
    if (ground_truth_normalized != ground_truth or model_output_normalized != model_output):
        try:
            if float(ground_truth_normalized) == float(model_output_normalized):
                return 1.0
        except (ValueError, TypeError):
            pass

    verify_func = math_metric(
        gold_extraction_target=(LatexExtractionConfig(),),
        pred_extraction_target=(ExprExtractionConfig(), LatexExtractionConfig()),
    )
    ret_score = 0.0

    # Wrap the ground truth in \boxed{} format for verification
    ground_truth_boxed = "\\boxed{" + ground_truth + "}"
    with contextlib.suppress(Exception):
        ret_score, _ = verify_func([ground_truth_boxed], [model_output])

    return ret_score
