import argparse
from llm.openai import init_openai, API_BASE, API_KEY
from llm.predict import run_single, run_batch

def main():
    parser = argparse.ArgumentParser(description="Run LLM predictions over features (OpenAI-compatible)")
    parser.add_argument("root_dir", nargs="?", default="data/full-trace-dataset")
    parser.add_argument("--model", default="gpt-5-nano-2025-08-07")
    parser.add_argument("--temperature", type=float, default=0.0)
    parser.add_argument("--max-tokens", type=int, default=16834)
    parser.add_argument("--recompute", action="store_false")
    parser.add_argument("--verbose", action="store_false")
    parser.add_argument("--single", default=None)

    parser.add_argument("--concurrent", action="store_false")
    parser.add_argument("--workers", type=int, default=8)
    args = parser.parse_args()

    print(f"[INFO] root_dir={args.root_dir}")
    print(f"[INFO] model={args.model}, temperature={args.temperature}, max_tokens={args.max_tokens}")
    print(f"[INFO] recompute={args.recompute}, verbose={args.verbose}")
    print(f"[INFO] concurrent={args.concurrent}, workers={args.workers}")
    print(f"[INFO] api_base={API_BASE}, api_key={API_KEY[:6]}***")

    init_openai()

    if args.single:
        run_single(
            args.single,
            model=args.model,
            temperature=args.temperature,
            max_tokens=args.max_tokens,
            verbose=args.verbose,
            save=True
        )
    else:
        wrote = run_batch(
            args.root_dir,
            model=args.model,
            temperature=args.temperature,
            max_tokens=args.max_tokens,
            recompute=args.recompute,
            verbose=args.verbose,
            concurrent=args.concurrent,
            workers=args.workers,
        )
        print(f"[INFO] wrote_preds={wrote}")

if __name__ == "__main__":
    main()
