import numpy as np

class TwoStageLinear:
    def __init__(self):
        self.alpha_N = None
        self.C_N = None
        self.a = None
        self.b = None

    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

        B = np.vstack([np.ones_like(y), y]).T
        a, b = np.linalg.lstsq(B, acc, rcond=None)[0]

        self.alpha_N, self.C_N, self.a, self.b = float(alpha_N), float(C_N), float(a), float(b)
        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.a + self.b * nll_hat
    