from pathlib import Path
from natsort import natsorted
from pddl.core import And
from tp_lodge.utils.pddl_utils import get_valid_predicates
from pddl.parser.problem import ProblemParser


gt_dir = Path(__file__).parent.parent / "furniturebench/data/fb-lamp/problems"
gen_dirs = Path(__file__).parent.parent / "furniturebench/results/fb-lamp/gpt-4.1-mini-2025-04-14/sadegh/no-docstrings"

for gt_problem_file in natsorted(gt_dir.glob("p*.pddl")):
    gt_problem = ProblemParser()(gt_problem_file.read_text())
    print(gt_problem_file.name)


    goals = {}
    inits = {}
    for gen_dir in natsorted(gen_dirs.glob("seed_*")):
        gen_problem = ProblemParser()((gen_dir / "problem" / gt_problem_file.name).read_text())
        goals[gen_dir.stem] = str(gen_problem.goal)
        inits[gen_dir.stem] = str(And(*get_valid_predicates(gen_problem.init)))

    # print("- GT:       %s\n%s" % (str(gt_problem.goal), "\n".join(["- %s: %s" % (k, v) for k, v in goals.items() ])))
    print("- GT:       %s\n%s" % (str(And(*get_valid_predicates(gt_problem.init))), "\n".join(["- %s: %s" % (k, v) for k, v in inits.items() ])))

    input("confirm")
