import os
import re
import json

from olym_gen.utils.utils import get_logger

logger = get_logger()

def main(load_path: str) -> None:
    count = 0
    correct = 0
    for file in os.listdir(load_path):
        if not re.match(r"problem_(\d+)_proof_(\d+)_generate_(\d+).json", file):
            continue
        count += 1
        logger.debug(f"Processing file: {file}")
        with open(os.path.join(load_path, file), 'r', encoding='UTF-8') as f:
            data = json.load(f)
            if not data['pass_check']:
                continue
            if isinstance(data["check_result"], str):
                continue
            if data["check_result"]["proof_correct"]:
                correct += 1
    logger.info(f"Total files processed: {count}, Correct proofs: {correct}, Accuracy: {correct / count if count > 0 else 0:.2f}")
    
if __name__ == "__main__":
    import argparse
    parser = argparse.ArgumentParser(description="Evaluate proof correctness.")
    parser.add_argument("load_path", type=str, help="Path to the directory containing generated proof files.")
    args = parser.parse_args()
    
    main(args.load_path)
    logger.info("Evaluation completed.")