"""Tests some of the utility-style functions within the package."""


import iisignature

from helpers import helpers as h
from helpers import validation as v


tests = ['lyndon_words', 'lyndon_brackets', 'signature_channels', 'logsignature_channels']
depends = []
signatory = v.validate_tests(tests, depends)


def test_lyndon_amount():
    """Tests that the lyndon_words and lyndon_brackets functions gives the same number of elements"""
    for channels in range(1, 10):
        for depth in range(1, 6):
            len_words = len(signatory.lyndon_words(channels, depth))
            len_brackets = len(signatory.lyndon_brackets(channels, depth))
            print('channels=' + str(channels))
            print('depth=' + str(depth))
            assert len_words == len_brackets


def _iisignature_convert(ii_elem):
    outstr = ''
    for character in ii_elem:
        if character == '1':
            outstr += '0'
        elif character == '2':
            outstr += '1'
        elif character == '3':
            outstr += '2'
        elif character == '4':
            outstr += '3'
        elif character == '5':
            outstr += '4'
        elif character == '6':
            outstr += '5'
        elif character == '7':
            outstr += '6'
        elif character == '8':
            outstr += '7'
        elif character == '9':
            outstr += '8'
        elif character == '?':
            outstr += '9'
        else:
            outstr += character
    return outstr


def test_lyndon_brackets():
    """Tests the lyndon_brackets function"""
    for channels in range(2, 11):  # iisignature supports channels with unique symbols in the range 2 to 10 inclusive
        for depth in range(1, 6):
            iisignature_brackets = iisignature.basis(h.iisignature_prepare(channels, depth))
            signatory_brackets = signatory.lyndon_brackets(channels, depth)
            for ii_elem, sig_elem in zip(iisignature_brackets, signatory_brackets):
                print('channels=' + str(channels))
                print('depth=' + str(depth))
                assert sig_elem == eval(_iisignature_convert(ii_elem))


# This is actually quite an important test, because we use lyndon_words as part of our logsignature testing elsewhere,
# so we have to know that this function is correct.
def test_lyndon_words():
    """Tests the lyndon_words function"""
    for channels in range(2, 11):  # iisignature supports channels with unique symbols in the range 2 to 10 inclusive
        for depth in range(1, 6):
            iisignature_brackets = iisignature.basis(h.iisignature_prepare(channels, depth))
            signatory_words = signatory.lyndon_words(channels, depth)
            for ii_elem, sig_elem in zip(iisignature_brackets, signatory_words):
                ii_elem_new = ii_elem.replace('[', '').replace(']', '').replace(',', '')
                ii_elem_new = _iisignature_convert(ii_elem_new)
                sig_elem_new = ''.join(str(i) for i in sig_elem)
                print('channels=' + str(channels))
                print('depth=' + str(depth))
                print('ii_elem' + str(ii_elem))
                print('sig_elem' + str(sig_elem))
                assert sig_elem_new == ii_elem_new


def test_signature_channels():
    """Tests the signature_channels function"""
    for channels in range(1, 16):
        for depth in range(1, 15):
            for scalar_term in (True, False):
                result = signatory.signature_channels(channels, depth, scalar_term)
                sum_over = sum(channels ** i for i in range(1, depth + 1))
                if scalar_term:
                    sum_over += 1
                print('channels=' + str(channels))
                print('depth=' + str(depth))
                assert result == sum_over


def test_logsignature_channels():
    """Tests the logsignature_channels function"""
    for channels in range(1, 10):
        for depth in range(1, 6):
            result = signatory.logsignature_channels(channels, depth)
            from_words = len(signatory.lyndon_words(channels, depth))
            print('channels=' + str(channels))
            print('depth=' + str(depth))
            assert result == from_words
