import time
from pam.prefix_dag import build_demo_prefix_dag
from pam.mtau import MTau
from pam.pam_search import PaMEngine
from config import CFG

def s_prefix(v): return 1.0 - 0.05*(0 if v=="root" else int(v.split("_")[1]))
def d_rem_factory(g):
    def f(v):
        md=max(n.depth for n in g.nodes.values()); return max(0, md - (g.nodes[v].depth if v in g.nodes else 0))
    return f

if __name__=="__main__":
    g = build_demo_prefix_dag(D=3,B=3,seed=CFG.SEED)
    mt = MTau(CFG.CS_MAX, d_rem_factory(g), s_prefix)
    for mode in ["Exact","Surrogate","Fallback"]:
        print(f"\n=== Running {mode} ===")
        t0=time.time(); out = PaMEngine(g, mt, mode=mode, rng_seed=CFG.SEED).run(cap_k=None)
        print(f"Incumbent={out['incumbent']:.4f}  Expanded={out['expanded']}  Ledger={out['ledger']}")
