import unittest
from parameterized import parameterized

from rkhs_weightings import RKHSWeightingClassifier
from test_common import LEARNERS, ANALYTICAL_INSTANTIATIONS, LOSSES
from test_common import N_ITER, RNG
from test_common import make_scaled_classification

class TestLearners(unittest.TestCase):
    @parameterized.expand([[L, I, loss] for L in LEARNERS for I in ANALYTICAL_INSTANTIATIONS for loss in LOSSES])
    def test_rademacher_complexity(self, L, I, loss):
        X, y = make_scaled_classification()
        model = I(data_x=X, rng=RNG)
        learner = L(n_iter=N_ITER, rng=RNG, loss=loss())
        clf = RKHSWeightingClassifier(learner, model).fit(X, y)
        clf.learner.rademacher_complexity()

    @parameterized.expand([[L, I, loss] for L in LEARNERS for I in ANALYTICAL_INSTANTIATIONS for loss in LOSSES])
    def test_rademacher_bound(self, L, I, loss):
        X, y = make_scaled_classification()
        model = I(data_x=X, rng=RNG)
        learner = L(n_iter=N_ITER, rng=RNG, loss=loss())
        clf = RKHSWeightingClassifier(learner, model).fit(X, y)
        clf.learner.rademacher_bound()

if __name__ == '__main__':
    unittest.main()