Skip to content

Commit

Permalink
Update system tests
Browse files Browse the repository at this point in the history
  • Loading branch information
pwollstadt committed Nov 11, 2018
1 parent 7f8a1da commit 847a5fa
Show file tree
Hide file tree
Showing 27 changed files with 77 additions and 52 deletions.
2 changes: 1 addition & 1 deletion idtxl/network_inference.py
Original file line number Diff line number Diff line change
Expand Up @@ -332,7 +332,7 @@ def _initialise(self, settings, data, sources, target):
'(''max_lag_sources'') needs to be specified.')
if 'min_lag_sources' not in self.settings:
raise RuntimeError('The minimum lag for source embedding '
'(''max_lag_sources'') needs to be specified.')
'(''min_lag_sources'') needs to be specified.')
self.settings.setdefault('max_lag_target', settings['max_lag_sources'])

if (type(self.settings['min_lag_sources']) is not int or
Expand Down
Binary file modified test/data/continuous_results_bmi_JidtGaussianCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_bmi_JidtKraskovCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_bte_JidtGaussianCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_bte_JidtKraskovCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_mmi_JidtGaussianCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_mmi_JidtKraskovCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_mte_JidtGaussianCMI.p
Binary file not shown.
Binary file modified test/data/continuous_results_mte_JidtKraskovCMI.p
Binary file not shown.
Binary file modified test/data/discrete_results_bmi_JidtDiscreteCMI.p
Binary file not shown.
Binary file modified test/data/discrete_results_bte_JidtDiscreteCMI.p
Binary file not shown.
Binary file modified test/data/discrete_results_mmi_JidtDiscreteCMI.p
Binary file not shown.
Binary file modified test/data/discrete_results_mte_JidtDiscreteCMI.p
Binary file not shown.
Binary file modified test/data/mute_results_0.p
Binary file not shown.
Binary file modified test/data/mute_results_1.p
Binary file not shown.
Binary file modified test/data/mute_results_2.p
Binary file not shown.
Binary file modified test/data/mute_results_3.p
Binary file not shown.
Binary file modified test/data/mute_results_4.p
Binary file not shown.
Binary file modified test/data/mute_results_full.p
Binary file not shown.
2 changes: 1 addition & 1 deletion test/generate_test_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ def _print_result(res):


if __name__ == '__main__':
analyse_mute_te_data()
analyse_discrete_data()
analyse_mute_te_data()
analyse_continuous_data()
assert_results()
8 changes: 5 additions & 3 deletions test/systemtest_multivariate_te.py
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ def test_multivariate_te_lagged_copies():
results = random_analysis.analyse_single_target(settings, data, t)
assert len(results.get_single_target(t, fdr=False).selected_vars_full) == 1, (
'Conditional contains more/less than 1 variables.')
assert not results.get_single_target(t, fdr=False).selected_vars_sources.size, (
assert not results.get_single_target(t, fdr=False).selected_vars_sources, (
'Conditional sources is not empty.')
assert len(results.get_single_target(t, fdr=False).selected_vars_target) == 1, (
'Conditional target contains more/less than 1 variable.')
Expand Down Expand Up @@ -136,6 +136,7 @@ def test_multivariate_te_random():
settings = {
'cmi_estimator': 'JidtKraskovCMI',
'max_lag_sources': 5,
'min_lag_sources': 1,
'n_perm_max_stat': 200,
'n_perm_min_stat': 200,
'n_perm_omnibus': 500,
Expand All @@ -149,7 +150,7 @@ def test_multivariate_te_random():
results = random_analysis.analyse_single_target(settings, data, t)
assert len(results.get_single_target(t, fdr=False).selected_vars_full) == 1, (
'Conditional contains more/less than 1 variables.')
assert not results.get_single_target(t, fdr=False).selected_vars_sources.size, (
assert not results.get_single_target(t, fdr=False).selected_vars_sources, (
'Conditional sources is not empty.')
assert len(results.get_single_target(t, fdr=False).selected_vars_target) == 1, (
'Conditional target contains more/less than 1 variable.')
Expand Down Expand Up @@ -208,7 +209,7 @@ def test_multivariate_te_lorenz_2():
# Just analyse the direction of coupling
results = lorenz_analysis.analyse_single_target(settings, data, target=1)
print(results._single_target)
print(results.get_adjacency_matrix('binary'))
print(results.get_adjacency_matrix('binary', fdr=False))


def test_multivariate_te_mute():
Expand Down Expand Up @@ -272,6 +273,7 @@ def test_multivariate_te_multiple_runs():
test_multivariate_te_mute()
test_multivariate_te_lorenz_2()
test_multivariate_te_random()
test_multivariate_te_lagged_copies()
test_multivariate_te_multiple_runs()
test_multivariate_te_corr_gaussian()
test_multivariate_te_corr_gaussian('OpenCLKraskovCMI')
40 changes: 27 additions & 13 deletions test/systemtest_multivariate_te_discrete.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
from idtxl.idtxl_utils import calculate_mi


def test_multivariate_te_corr_gaussian():
def test_multivariate_te_corr_gaussian(estimator=None):
"""Test multivariate TE estimation on correlated Gaussians.
Run the multivariate TE algorithm on two sets of random Gaussian data with
Expand All @@ -25,6 +25,9 @@ def test_multivariate_te_corr_gaussian():
This test runs considerably faster than other system tests.
This produces strange small values for non-coupled sources. TODO
"""
if estimator is None:
estimator = 'JidtKraskovCMI'

cov = 0.4
expected_mi, source1, source2, target = _get_gauss_data(covariance=cov)
# n = 1000
Expand All @@ -39,7 +42,7 @@ def test_multivariate_te_corr_gaussian():
data = Data(normalise=True)
data.set_data(np.vstack((source1[1:].T, target[:-1].T)), 'ps')
settings = {
'cmi_estimator': 'JidtDiscreteCMI',
'cmi_estimator': estimator,
'discretise_method': 'max_ent',
'max_lag_sources': 5,
'min_lag_sources': 1,
Expand Down Expand Up @@ -120,7 +123,7 @@ def test_multivariate_te_lagged_copies():
results = random_analysis.analyse_single_target(settings, data, t)
assert len(results.get_single_target(t, fdr=False).selected_vars_full) == 1, (
'Conditional contains more/less than 1 variables.')
assert not results.get_single_target(t, fdr=False).selected_vars_sources.size, (
assert not results.get_single_target(t, fdr=False).selected_vars_sources, (
'Conditional sources is not empty.')
assert len(results.get_single_target(t, fdr=False).selected_vars_target) == 1, (
'Conditional target contains more/less than 1 variable.')
Expand Down Expand Up @@ -151,6 +154,7 @@ def test_multivariate_te_random():
settings = {
'cmi_estimator': 'JidtDiscreteCMI',
'discretise_method': 'max_ent',
'min_lag_sources': 1,
'max_lag_sources': 5,
'n_perm_max_stat': 200,
'n_perm_min_stat': 200,
Expand All @@ -165,7 +169,7 @@ def test_multivariate_te_random():
results = random_analysis.analyse_single_target(settings, data, t)
assert len(results.get_single_target(t, fdr=False).selected_vars_full) == 1, (
'Conditional contains more/less than 1 variables.')
assert not results.get_single_target(t, fdr=False).selected_vars_sources.size, (
assert not results.get_single_target(t, fdr=False).selected_vars_sources, (
'Conditional sources is not empty.')
assert len(results.get_single_target(t, fdr=False).selected_vars_target) == 1, (
'Conditional target contains more/less than 1 variable.')
Expand Down Expand Up @@ -223,7 +227,7 @@ def test_multivariate_te_lorenz_2():
# Just analyse the coupled direction
results = lorenz_analysis.analyse_single_target(settings, data, 1)
print(results._single_target)
print(results.adjacency_matrix)
print(results.get_adjacency_matrix(weights='binary', fdr=False))


def test_multivariate_te_mute():
Expand Down Expand Up @@ -263,19 +267,29 @@ def test_multivariate_te_mute():
results_eq = network_analysis.analyse_network(settings, data,
targets=[1, 2])

assert (np.isclose(
results_eq.get_single_target(1, fdr=False).omnibus_te,
results_me.get_single_target(1, fdr=False).omnibus_te, rtol=0.05)), (
'TE into first target is not equal for both binning methods.')
assert (np.isclose(
results_eq.get_single_target(2, fdr=False).omnibus_te,
results_me.get_single_target(2, fdr=False).omnibus_te, rtol=0.05)), (
'TE into second target is not equal for both binning methods.')
for t in [1, 2]:
print('Target {0}: equal binning: {1}, max. ent. binning: {2}'.format(
t,
results_eq.get_single_target(t, fdr=False).omnibus_te,
results_me.get_single_target(t, fdr=False).omnibus_te
))
# Skip comparison of estimates if analyses returned different source
# sets. This will always lead to different estimates.
if (results_eq.get_single_target(t, fdr=False).selected_vars_sources ==
results_me.get_single_target(t, fdr=False).selected_vars_sources):
assert (np.isclose(
results_eq.get_single_target(1, fdr=False).omnibus_te,
results_me.get_single_target(1, fdr=False).omnibus_te,
rtol=0.05)), ('Target {0}: unequl results for both binning '
'methods.'.format(t))
else:
continue


if __name__ == '__main__':
test_multivariate_te_lorenz_2()
test_multivariate_te_mute()
test_multivariate_te_random()
test_multivariate_te_lagged_copies()
test_multivariate_te_corr_gaussian()
test_multivariate_te_corr_gaussian('OpenCLKraskovCMI')
5 changes: 2 additions & 3 deletions test/systemtest_mute.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import os
import pickle
import time
from idtxl.multivariate_te import MultivariateTE
Expand All @@ -22,5 +21,5 @@
runtime = time.time() - start_time
print("---- {0} minutes".format(runtime / 60))

path = '{0}output/'.format(os.path.dirname(__file__))
pickle.dump(results, open('{0}test_mute_res_{1}'.format(path, 0), 'wb'))
# Save results
# pickle.dump(results, open('test_mute_results.p', 'wb'))
17 changes: 8 additions & 9 deletions test/systemtest_network_comparison.py
Original file line number Diff line number Diff line change
Expand Up @@ -85,24 +85,23 @@ def test_network_comparison():

def _verify_test(c_within, c_between, res):
# Test values for verification
p = 0.25 # max. attainable p-value
tp = res.adjacency_matrix > 0 # get true positives
print(c_within.adjacency_matrix_union)
assert (c_between.adjacency_matrix_union[tp] == 1).all(), (
tp = res.get_adjacency_matrix('binary') > 0 # get true positives
print(c_within.get_adjacency_matrix('union'))
assert (c_between.get_adjacency_matrix('union')[tp] == 1).all(), (
'Missing union link in between network comparison.')
assert (c_within.adjacency_matrix_union[tp] == 1).all(), (
assert (c_within.get_adjacency_matrix('union')[tp] == 1).all(), (
'Missing union link in wihin network comparison.')
assert (c_between.adjacency_matrix_pvalue[tp] < 1).all(), (
assert (c_between.get_adjacency_matrix('pvalue')[tp] < 1).all(), (
'Wrong p-value in between network comparison.')
assert (c_within.adjacency_matrix_pvalue[tp] < 1).all(), (
assert (c_within.get_adjacency_matrix('pvalue')[tp] < 1).all(), (
'Wrong p-value in wihin network comparison.')
# assert (c_between.adjacency_matrix_comparison[tp]).all(), (
# 'Wrong comparison in between network comparison.')
# assert (c_within.adjacency_matrix_comparison[tp]).all(), (
# 'Wrong comparison in wihin network comparison.')
assert (c_between.adjacency_matrix_diff_abs[tp] > 0).all(), (
assert (c_between.get_adjacency_matrix('diff_abs')[tp] > 0).all(), (
'Missed difference in between network comparison.')
assert (c_within.adjacency_matrix_diff_abs[tp] > 0).all(), (
assert (c_within.get_adjacency_matrix('diff_abs')[tp] > 0).all(), (
'Missed difference in wihin network comparison.')


Expand Down
6 changes: 3 additions & 3 deletions test/systemtest_partial_information_decomposition.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@

def test_pid_xor_data():
"""Test basic calls to PID class."""
n = 20
n = 100
alph = 2
x = np.random.randint(0, alph, n)
y = np.random.randint(0, alph, n)
Expand Down Expand Up @@ -43,9 +43,9 @@ def test_pid_xor_data():
t_sydney = tm.time() - tic

print('\nResults Tartu estimator:')
utils.print_dict(est_tartu)
utils.print_dict(est_tartu.get_single_target(2))
print('\nResults Sydney estimator:')
utils.print_dict(est_sydney)
utils.print_dict(est_sydney.get_single_target(2))

print('\nLogical XOR')
print('Estimator Sydney\t\tTartu\n')
Expand Down
28 changes: 15 additions & 13 deletions test/systemtest_pid_sydney.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
import time as tm
from bitstring import BitArray, Bits
# import estimators_fast_pid as epid
from idtxl.set_estimator import Estimator_pid
from idtxl.estimators_pid import SydneyPID

# LOGICAL AND
alph_x = 2
Expand All @@ -18,19 +18,17 @@
y = np.random.randint(0, alph_y, n)
z = np.logical_and(x, y).astype(int)

cfg = {
settings = {
'alph_s1': alph_x,
'alph_s2': alph_y,
'alph_t': alph_z,
'max_unsuc_swaps_row_parm': 3,
'num_reps': 63,
'max_iters': 10000
}

pid_sydney = Estimator_pid('pid_sydney')
'max_iters': 10000}

tic = tm.time()
est = pid_sydney.estimate(x, y, z, cfg)
pid_sydney = SydneyPID(settings)
est = pid_sydney.estimate(x, y, z)
toc = tm.time()

print('\n\nLOGICAL AND')
Expand All @@ -43,7 +41,7 @@
# LOGICAL XOR
z = np.logical_xor(x, y).astype(int)

cfg = {
settings = {
'alph_s1': alph_x,
'alph_s2': alph_y,
'alph_t': alph_z,
Expand All @@ -53,7 +51,8 @@
}

tic = tm.time()
est = pid_sydney.estimate(x, y, z, cfg)
pid_sydney = SydneyPID(settings)
est = pid_sydney.estimate(x, y, z)
toc = tm.time()

print('\nPID evaluation {:.3f} seconds\n'.format(toc - tic))
Expand All @@ -65,7 +64,7 @@
# SINGLE INPUT COPY
z = x

cfg = {
settings = {
'alph_s1': alph_x,
'alph_s2': alph_y,
'alph_t': alph_z,
Expand All @@ -75,7 +74,8 @@
}

tic = tm.time()
est = pid_sydney.estimate(x, y, z, cfg)
pid_sydney = SydneyPID(settings)
est = pid_sydney.estimate(x, y, z)
toc = tm.time()

print('\nPID evaluation {:.3f} seconds\n'.format(toc - tic))
Expand All @@ -102,6 +102,7 @@ def parity(bytestring):

return par


x = np.zeros((n,), dtype=np.int)
y = np.zeros((n,), dtype=np.int)
z = np.zeros((n,), dtype=np.int)
Expand All @@ -115,7 +116,7 @@ def parity(bytestring):
alph_y = 4
alph_z = 2

cfg = {
settings = {
'alph_s1': alph_x,
'alph_s2': alph_y,
'alph_t': alph_z,
Expand All @@ -125,7 +126,8 @@ def parity(bytestring):
}

tic = tm.time()
est = pid_sydney.estimate(x, y, z, cfg)
pid_sydney = SydneyPID(settings)
est = pid_sydney.estimate(x, y, z)
toc = tm.time()

print('\n\nPARITY')
Expand Down
21 changes: 15 additions & 6 deletions test/systemtest_visualise_graph.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,22 @@ def test_visualise_multivariate_te():
results = network_analysis.analyse_network(settings, data,
targets=[0, 1, 2])
# generate graph plots
visualise_graph.plot_selected_vars(results, target=1, sign_sources=False)
plt.show()
visualise_graph.plot_network(results, fdr=False)
plt.show()
visualise_graph.plot_network(results, fdr=True)
try:
visualise_graph.plot_selected_vars(
results, target=1, sign_sources=False, fdr=True)
plt.show()
except RuntimeError:
print('No FDR-corrected results.')
try:
visualise_graph.plot_network(results, weights='binary', fdr=True)
plt.show()
except RuntimeError:
print('No FDR-corrected results.')

visualise_graph.plot_network(results, weights='binary', fdr=False)
plt.show()
visualise_graph.plot_selected_vars(results, target=1, sign_sources=True)
visualise_graph.plot_selected_vars(
results, target=1, sign_sources=True, fdr=False)
plt.show()


Expand Down

0 comments on commit 847a5fa

Please sign in to comment.