# utils/timer_profiler.py
"""
Simple timing / profiling helper. Measures per-image latency and reports statistics.
"""
import time
import numpy as np

class TimerProfiler:
    def __init__(self):
        self.samples = []

    def time_fn(self, fn, *args, **kwargs):
        t0 = time.time()
        res = fn(*args, **kwargs)
        t1 = time.time()
        self.samples.append(t1 - t0)
        return res

    def summary(self):
        arr = np.array(self.samples)
        return {"count": len(arr), "mean_s": float(arr.mean() if len(arr)>0 else 0.0),
                "median_s": float(np.median(arr) if len(arr)>0 else 0.0),
                "p95_s": float(np.percentile(arr, 95) if len(arr)>0 else 0.0)}
