import numpy as np

### TEST F_HAT ###
from comab.reward_estimator.full_empirical_cdf import F_hat

z = 0.8
t= np.array([[0,0,2,3]])
# P = 1
# N = 2
array = [
    [
        [0, 0, 0, 0, 0, 0, 0], # X_t^(0)
        [0, 0, 0, 0, 0, 0, 0], # X_t^(1)
        [0.9, 0, 0, 0, 0.3, 0, 0],  # X_t^(2)
        [0, 0.5, 0, 0.6, 0, 0.64, 0]   # X_t^(3)
    ]
]

X = np.array(array) #K=1, N+P+1=4, T=7
_F_hat_test= F_hat(z, X, t)
assert np.allclose(_F_hat_test, np.array([[np.nan, np.nan, 0.5, 1.]]), equal_nan=True), "Arrays must be equal up to numerical precision."