from __future__ import annotations

import argparse, datetime, json, subprocess, sys

from pathlib import Path

def to_csv(x):
    if isinstance(x, (list, tuple)):
        return ",".join(str(v) for v in x)
    return str(x)




def newest_dir(root: Path, contains: str) -> Path:

    cands = [p for p in root.iterdir() if p.is_dir() and contains in p.name]

    if not cands:

        cands = [p for p in root.iterdir() if p.is_dir()]

    cands.sort(key=lambda p: p.stat().st_mtime, reverse=True)

    return cands[0]



def stage_artifacts(run_dir: Path, out_art: Path) -> None:

    out_art.mkdir(parents=True, exist_ok=True)

    pa = run_dir / "paper_artifacts"

    if pa.is_dir():

        for f in pa.iterdir():

            if f.is_file():

                (out_art / f.name).write_bytes(f.read_bytes())

    for ext in (".png",".csv",".tex",".json"):

        for f in run_dir.glob(f"*{ext}"):

            if f.is_file():

                (out_art / f.name).write_bytes(f.read_bytes())



def main() -> None:

    ap = argparse.ArgumentParser()

    ap.add_argument("--device", default="cpu")

    ap.add_argument("--config", default="paper_configs/covdrift.json")

    args = ap.parse_args()



    repo = Path(__file__).resolve().parent

    cfg = json.loads((repo / args.config).read_text())



    for tag, c in cfg["datasets"].items():

        out_root = repo / "results" / "paper_runs" / f"{tag}_downstream_covdrift_mr_fixed"

        stamp = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")

        raw_root = out_root / "raw_runs" / f"paper_{stamp}"

        raw_root.mkdir(parents=True, exist_ok=True)



        cmd = [

            sys.executable, "-u", "runners/run_covdrift_mr_fixed_icml.py",

            "--dataset", c["dataset"],

            "--out", str(raw_root),

            "--seeds", to_csv(c["seeds"]),

            "--device", args.device,

            "--dtype", str(c.get("dtype","float64")),

            "--rank", str(c["rank"]),

            "--drift-rank", str(c["drift_rank"]),

            "--drift-smax", str(c["drift_smax"]),

            "--drift-seed", str(c["drift_seed"]),

            "--drift-subspace", str(c["drift_subspace"]),

            "--Ks", to_csv(c["Ks"]),

            "--train-frac", str(c["train_frac"]),

            "--unlab-frac", str(c["unlab_frac"]),

            "--test-frac", str(c["test_frac"]),

            "--shrinkage", str(c["shrinkage"]),

            "--lam-floor-mult", str(c["lam_floor_mult"]),

            "--methods", to_csv(c["methods"]),

        ]

        subprocess.run(cmd, cwd=str(repo), check=True)



        run_dir = newest_dir(raw_root, "covdrift_mr_fixed")



        subprocess.run([sys.executable, "-u", "runners/icml_finalize_covdrift_mr_fixed_paper.py",

                        "--run-dir", str(run_dir),

                        "--title", tag], cwd=str(repo), check=True)



        stage_artifacts(run_dir, out_root / "paper_artifacts")

        (out_root / "last_run_dir.txt").write_text(str(run_dir) + "\n")



if __name__ == "__main__":

    main()
