import numpy as np

class TwoStageLogistic:
    def __init__(self):
        self.alpha_N = None
        self.C_N = None
        self.a = None
        self.b = None
        self.k = None
        self.l0 = None

    @staticmethod
    def _logistic(z, a, b, k, l0):
        return a / (1.0 + np.exp(-k * (z - l0))) + b

    def fit(self, flops, nll, acc):
        flops = np.asarray(flops, dtype=float).ravel()
        nll = np.asarray(nll, dtype=float).ravel()
        acc = np.asarray(acc, dtype=float).ravel()

        eps = 1e-12
        x = np.clip(flops, eps, None)
        y = np.clip(nll,   eps, None)

        A = np.vstack([np.log(x), np.ones_like(x)]).T
        alpha_N, log_C_coeff = np.linalg.lstsq(A, np.log(y), rcond=None)[0]
        C_coeff = np.exp(log_C_coeff)
        C_N = (1.0 / C_coeff) ** (1.0 / alpha_N) if alpha_N != 0 else 1.0

        p0 = [float(np.max(acc)), float(np.min(acc)), 1.0, float(np.median(y))]
        a, b, k, l0 = curve_fit(self._logistic, y, acc, p0=p0, maxfev=10000)[0]

        self.alpha_N, self.C_N = float(alpha_N), float(C_N)
        self.a, self.b, self.k, self.l0 = float(a), float(b), float(k), float(l0)
        return self

    def predict(self, flops):
        x = np.asarray(flops, dtype=float).ravel()
        nll_hat = (np.clip(x, 1e-12, None) / self.C_N) ** self.alpha_N
        return self._logistic(nll_hat, self.a, self.b, self.k, self.l0)
    