import numpy as np
import pdb

def _brier_score(action, gt):
    return 1-(action - gt) ** 2


def _accuracy(action, gt):
    return (action == gt).astype(int)


def _threshold_accuracy(action, gt):
    return ((action >= 0.5).astype(int) == gt).astype(int)

def _mse_score(action, gt):
    return -(action - gt) ** 2

def _log_loss(action, gt):
    return gt * np.log(action) + (1 - gt) * np.log(1 - action)

def _define_v_shaped_scoring_rule(kink):
    def _v_shaped_scoring_rule(action, state):
        result = np.zeros_like(action)
        mask = action <= kink
        result[mask] = 1/2 - 0.5 * (state[mask] - kink) / max(1 - kink, kink)
        result[~mask] = 1/2 + 0.5 * (state[~mask] - kink) / max(1 - kink, kink)
        return result
            # return 1/2 + 0.5 * (state - kink) / max(1 - kink, kink)
    return _v_shaped_scoring_rule