import os, glob, re
import pandas as pd
import matplotlib.pyplot as plt

# point this to your per-c CSV root
ROOT = "/scratch/user/aaryabookseller/Research/archive/csv/imperfect_signal/c_rel"

def _slug_to_float(dirname: str) -> float:
    # dirname looks like "c=10" or "c=0p01"
    val_str = dirname.split("=")[1]
    return float(val_str.replace("p", "."))

all_dfs = []
for dirpath in glob.glob(os.path.join(ROOT, "c=*")):
    c_val = _slug_to_float(os.path.basename(dirpath))
    trace_csvs = glob.glob(os.path.join(dirpath, "trace*.csv"))
    if not trace_csvs:
        continue
    latest = max(trace_csvs, key=os.path.getmtime)
    df = pd.read_csv(latest)
    df["c"] = c_val
    all_dfs.append(df)

if not all_dfs:
    raise RuntimeError("No per-c CSVs found")

df_all = pd.concat(all_dfs, ignore_index=True)

# === Plot u1 relative gap across c values ===
plt.figure(figsize=(7,5))
for c_val, dfc in df_all.groupby("c"):
    if "u1" in dfc.columns and "u1_star" in dfc.columns:
        iters = dfc["step"].values
        gap = abs(dfc["u1"] - dfc["u1_star"]) / (dfc["u1_star"].abs() + 1e-12)
        plt.plot(iters, gap, label=f"c={c_val:g}")

plt.xscale("log"); plt.yscale("log")
plt.xlabel("Iteration"); plt.ylabel(r"$u_1$ relative gap")
plt.legend()
plt.tight_layout()
plt.savefig("combined_u1_gap_c_rel.pdf")
plt.show()