"""
Test wrappers for MMD methods: mmd_median, mmd_split, mmd_fuse
"""
import numpy as np

from mmd_median import mmd_median
from mmd_split import mmd_split
from mmdfuse import mmdfuse


def test_MMD_median(X, Y, seed, kernel="gaussian"):
    """MMD_median test"""
    try:
        np.random.seed(seed)
        result = mmd_median(X, Y, seed, alpha=0.05, kernel=kernel, B1=500)
        return int(result)
    except:
        return 'na'


def test_mmd_fuse(X, Y, seed):
    """mmd_fuse test"""
    try:
        np.random.seed(seed)
        # Always use both gaussian and laplace kernels
        result = mmdfuse(X, Y, seed, alpha=0.05, kernels=("gaussian"),
                         number_bandwidths=10, number_permutations=500)
        return int(result)
    except:
        return 'na'


def test_mmd_split(X, Y, seed, kernel="gaussian"):
    """mmd_split test"""
    try:
        np.random.seed(seed)
        result = mmd_split(X, Y, seed, alpha=0.05, kernel=kernel, 
                          number_bandwidths=10, number_permutations=500)
        return int(result)
    except:
        return 'na'
