import numpy as np


def get_min(arr):
    masked_arr = arr[arr != 0]
    if len(masked_arr) == 0:
        return 0
    return np.min(masked_arr)


def get_avg(arr):
    masked_arr = arr[arr != 0]
    if len(masked_arr) == 0:
        return 0
    return np.mean(masked_arr)


def softmax(x):
    # Subtract the max value for numerical stability
    e_x = np.exp(x - np.max(x))
    return e_x / e_x.sum(axis=0)


def masked_softmax(x):
    mask = x != 0
    masked_x = x[mask]
    softmax_value = softmax(masked_x)
    ret = np.zeros_like(x, dtype=x.dtype)
    ret[mask] = softmax_value
    return ret


def get_input_dim(opt):
    input_size = 1  # round number
    input_size += opt.players * 2 if opt.history else opt.players
    input_size += 1 if opt.encode_id else 0
    return input_size


def extract_critical_settings(all_combs, players):
    all_localone = []
    all_localzero = []
    for i, comb in enumerate(all_combs):
        if comb.get_init() == 0:
            all_localzero.append(i)
        elif comb.get_init() == (2**players - 1):
            all_localone.append(i)

    return all_localzero, all_localone
