import numpy as np


def filter_top_errors(pred, true, percentile=99):
    pred = np.asarray(pred).reshape(-1)
    true = np.asarray(true).reshape(-1)

    valid = np.isfinite(pred) & np.isfinite(true)
    pred_v = pred[valid]
    true_v = true[valid]

    if pred_v.size == 0:
        return pred_v, true_v

    errors = np.abs(pred_v - true_v)
    k = int(np.ceil(pred_v.size * (100 - percentile) / 100.0))

    if k <= 0:
        return pred_v, true_v

    idx = np.argpartition(errors, -k)[-k:]
    mask = np.ones(pred_v.size, dtype=bool)
    mask[idx] = False
    return pred_v[mask], true_v[mask]


def RSE(pred, true):
    return np.sqrt(np.sum((true - pred) ** 2)) / np.sqrt(np.sum((true - true.mean()) ** 2))


def CORR(pred, true):
    u = ((true - true.mean(0)) * (pred - pred.mean(0))).sum(0)
    d = np.sqrt(((true - true.mean(0)) ** 2 * (pred - pred.mean(0)) ** 2).sum(0))
    return (u / d).mean(-1)


def MAE(pred, true):
    return np.mean(np.abs(pred - true))


def MSE(pred, true):
    return np.mean((pred - true) ** 2)


def RMSE(pred, true):
    return np.sqrt(MSE(pred, true))


def MAPE(pred, true):
    true = np.asarray(true)
    denom = np.maximum(np.abs(true), 1e-12)
    return np.mean(np.abs((pred - true) / denom))


def MSPE(pred, true):
    true = np.asarray(true)
    denom = np.maximum(np.abs(true), 1e-12)
    return np.mean(np.square((pred - true) / denom))


def metric(pred, true, filter_outliers=True, percentile=99):
    if filter_outliers:
        pred_filtered, true_filtered = filter_top_errors(pred, true, percentile)
    else:
        pred_filtered = np.asarray(pred).reshape(-1)
        true_filtered = np.asarray(true).reshape(-1)
        valid = np.isfinite(pred_filtered) & np.isfinite(true_filtered)
        pred_filtered = pred_filtered[valid]
        true_filtered = true_filtered[valid]

    mae = MAE(pred_filtered, true_filtered)
    mse = MSE(pred_filtered, true_filtered)
    rmse = RMSE(pred_filtered, true_filtered)
    mape = MAPE(pred_filtered, true_filtered)
    mspe = MSPE(pred_filtered, true_filtered)

    return mae, mse, rmse, mape, mspe
