import argparse
from PIL import Image
import json
from dotenv import load_dotenv
from state_estimation import PredicateGrounder
from tp_lodge.utils.pddl_utils import get_predicate_evaluation
from tqdm import tqdm
from tp_lodge.task_planning.models.pddl.pddl_domain import PDDLDomain
from demos.furniturebench.scripts.fb_variable_parser import FBVariableParser
from tp_lodge.utils.pddl_domain_syntax import parse_formula
from pathlib import Path

from llm_utils import TextGenApi


def main(args):
    root_dir = Path(__file__).parent.parent.parent
    domain = "fb-lamp"
    vlm_llm = "gpt4.1-mini"
    data_llm = "gpt4.1-mini"

    textgen_api = TextGenApi.default(vlm_llm)

    data_dir = root_dir / "data" / domain
    connection = TextGenApi.default(data_llm).connections.connections[0].model_dir
    lodge_results_dir = root_dir / "results" / domain / connection / "hi-tamp/planning-with-pred-learning"

    out_dir = (
        root_dir
        / "results"
        / domain
        / "predicate-learning-eval"
        / textgen_api.connections.connections[0].model_dir
        / ("lodge-grounder" if args.use_lodge else "grounder")
    )

    domain_knowledge = (data_dir / "domain_knowledge.txt").read_text()

    for lodge_result_dir in lodge_results_dir.glob("sample-*"):
        lodge_domain = PDDLDomain.loads((lodge_result_dir / "domain.json").read_text())
        reply_buffer = json.loads((lodge_result_dir / "reply_buffer/states.json").read_text())

        sample_out_dir = out_dir / lodge_result_dir.name
        sample_out_dir.mkdir(parents=True, exist_ok=True)
        grounder = PredicateGrounder(
            code_api_file=root_dir / "scripts/llm_code_interface.py",
            domain_knowledge=domain_knowledge,
            textgen_api=textgen_api,
            out_dir=(lodge_result_dir / "grounding_code" if args.use_lodge else sample_out_dir / "functions"),
        )
        grounder.set_namespace_annotation(
            [FBVariableParser().from_dict(v) for v in list(reply_buffer["states"].values())[0]["variables"]]
        )

        # Save predictions to output directory
        out_predictions_file = sample_out_dir / "predictions.json"
        if out_predictions_file.exists():
            predictions = {
                k: {parse_formula(k2, only_variables=False): v2 for k2, v2 in v.items()}
                for k, v in json.load(open(out_predictions_file)).items()
            }
        else:
            predictions = {}

        for state_hash, state in tqdm(reply_buffer["states"].items()):
            if state_hash in predictions:
                continue

            pred_predicates = grounder.ground_state(
                variables=[FBVariableParser().from_dict(v) for v in state["variables"]],
                predicates=lodge_domain.predicates,
                verify=False,
            )

            predictions[state_hash] = get_predicate_evaluation(pred_predicates)

            # Save predictions to output directory
            out_predictions_file.write_text(
                json.dumps({k: {str(k2): v2 for k2, v2 in v.items()} for k, v in predictions.items()}, indent=4)
            )


if __name__ == "__main__":
    argparser = argparse.ArgumentParser()
    argparser.add_argument("--use-lodge", action="store_true")

    load_dotenv()
    main(argparser.parse_args())
