{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from util_results import Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from te_datasim.jointprocess import MVJointProcessSimulator\n",
    "from te_datasim.lineargaussian import MVLinearGaussianSimulator"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CUDA is available. Using GPU.\n"
     ]
    }
   ],
   "source": [
    "import torch; torch.set_printoptions(sci_mode=None)\n",
    "# Check if CUDA is available\n",
    "if torch.cuda.is_available():\n",
    "    compute_device = torch.device(\"cuda\")\n",
    "    print(\"CUDA is available. Using GPU.\")\n",
    "else:\n",
    "    compute_device = torch.device(\"cpu\")\n",
    "    print(\"CUDA is not available. Using CPU.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from reference_njee import TE_njee\n",
    "EPOCHS = 5001\n",
    "BATCH_SIZE = 10000\n",
    "N_BINS = 25"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Basic Validity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "REPLICATES = 5\n",
    "SAMPLE_SIZE = 10000"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Linear Gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Specify the range of lambda values to test\n",
    "lg_lambda_range = list(np.linspace(0, 1, 9, endpoint=True))\n",
    "\n",
    "# Initialize the list of generators with one for each lambda value\n",
    "lg_generator_lst = [MVLinearGaussianSimulator(n_dim=1, coupling=lam) for lam in lg_lambda_range]\n",
    "\n",
    "# get the reference values\n",
    "lg_TE_X2Y_ref_lst = [generator.analytic_transfer_entropy('X', 'Y') for generator in lg_generator_lst]\n",
    "lg_TE_Y2X_ref_lst = [generator.analytic_transfer_entropy('Y', 'X') for generator in lg_generator_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.5162, H(Y|X-,Y-) = 2.503, TE(X->Y) = 0.0132   \n",
      "H(Y|Y-) = 2.0351, H(Y|X-,Y-) = 2.028, TE(X->Y) = 0.0071   \n",
      "# Coupling =  0.125 #\n",
      "H(Y|Y-) = 2.5176, H(Y|X-,Y-) = 2.4993, TE(X->Y) = 0.0183  \n",
      "H(Y|Y-) = 2.042, H(Y|X-,Y-) = 2.0272, TE(X->Y) = 0.0148  \n",
      "# Coupling =  0.25 #\n",
      "H(Y|Y-) = 2.5159, H(Y|X-,Y-) = 2.5065, TE(X->Y) = 0.0094  \n",
      "H(Y|Y-) = 2.0287, H(Y|X-,Y-) = 1.9881, TE(X->Y) = 0.0406  \n",
      "# Coupling =  0.375 #\n",
      "H(Y|Y-) = 2.5172, H(Y|X-,Y-) = 2.5052, TE(X->Y) = 0.012   \n",
      "H(Y|Y-) = 2.0284, H(Y|X-,Y-) = 1.9484, TE(X->Y) = 0.08    \n",
      "# Coupling =  0.5 #\n",
      "H(Y|Y-) = 2.518, H(Y|X-,Y-) = 2.5073, TE(X->Y) = 0.0107  \n",
      "H(Y|Y-) = 2.0273, H(Y|X-,Y-) = 1.9006, TE(X->Y) = 0.1267  \n",
      "# Coupling =  0.625 #\n",
      "H(Y|Y-) = 2.5169, H(Y|X-,Y-) = 2.5075, TE(X->Y) = 0.0094  \n",
      "H(Y|Y-) = 2.0182, H(Y|X-,Y-) = 1.8323, TE(X->Y) = 0.1859  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.5166, H(Y|X-,Y-) = 2.503, TE(X->Y) = 0.0136   \n",
      "H(Y|Y-) = 2.0164, H(Y|X-,Y-) = 1.7722, TE(X->Y) = 0.2442  \n",
      "# Coupling =  0.875 #\n",
      "H(Y|Y-) = 2.5173, H(Y|X-,Y-) = 2.5047, TE(X->Y) = 0.0126  \n",
      "H(Y|Y-) = 2.0117, H(Y|X-,Y-) = 1.706, TE(X->Y) = 0.3057   \n",
      "# Coupling =  1.0 #\n",
      "H(Y|Y-) = 2.5197, H(Y|X-,Y-) = 2.5032, TE(X->Y) = 0.0165  \n",
      "H(Y|Y-) = 2.0125, H(Y|X-,Y-) = 1.647, TE(X->Y) = 0.3655   \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.5147, H(Y|X-,Y-) = 2.508, TE(X->Y) = 0.0067   \n",
      "H(Y|Y-) = 2.0038, H(Y|X-,Y-) = 1.9977, TE(X->Y) = 0.0061  \n",
      "# Coupling =  0.125 #\n",
      "H(Y|Y-) = 2.5153, H(Y|X-,Y-) = 2.5049, TE(X->Y) = 0.0104  \n",
      "H(Y|Y-) = 1.9952, H(Y|X-,Y-) = 1.9816, TE(X->Y) = 0.0136  \n",
      "# Coupling =  0.25 #\n",
      "H(Y|Y-) = 2.5156, H(Y|X-,Y-) = 2.5052, TE(X->Y) = 0.0104  \n",
      "H(Y|Y-) = 1.9911, H(Y|X-,Y-) = 1.9542, TE(X->Y) = 0.0369  \n",
      "# Coupling =  0.375 #\n",
      "H(Y|Y-) = 2.5156, H(Y|X-,Y-) = 2.5039, TE(X->Y) = 0.0117  \n",
      "H(Y|Y-) = 1.9654, H(Y|X-,Y-) = 1.8926, TE(X->Y) = 0.0728  \n",
      "# Coupling =  0.5 #\n",
      "H(Y|Y-) = 2.5157, H(Y|X-,Y-) = 2.5037, TE(X->Y) = 0.012   \n",
      "H(Y|Y-) = 1.9144, H(Y|X-,Y-) = 1.7943, TE(X->Y) = 0.1201  \n",
      "# Coupling =  0.625 #\n",
      "H(Y|Y-) = 2.5157, H(Y|X-,Y-) = 2.5056, TE(X->Y) = 0.0101  \n",
      "H(Y|Y-) = 1.8779, H(Y|X-,Y-) = 1.7075, TE(X->Y) = 0.1704  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.5139, H(Y|X-,Y-) = 2.5055, TE(X->Y) = 0.0084  \n",
      "H(Y|Y-) = 1.8523, H(Y|X-,Y-) = 1.6236, TE(X->Y) = 0.2287  \n",
      "# Coupling =  0.875 #\n",
      "H(Y|Y-) = 2.5159, H(Y|X-,Y-) = 2.5042, TE(X->Y) = 0.0117  \n",
      "H(Y|Y-) = 1.8413, H(Y|X-,Y-) = 1.5513, TE(X->Y) = 0.29    \n",
      "# Coupling =  1.0 #\n",
      "H(Y|Y-) = 2.5149, H(Y|X-,Y-) = 2.5031, TE(X->Y) = 0.0118  \n",
      "H(Y|Y-) = 1.8366, H(Y|X-,Y-) = 1.4913, TE(X->Y) = 0.3453  \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.5243, H(Y|X-,Y-) = 2.5149, TE(X->Y) = 0.0094  \n",
      "H(Y|Y-) = 2.0802, H(Y|X-,Y-) = 2.0757, TE(X->Y) = 0.0045  \n",
      "# Coupling =  0.125 #\n",
      "H(Y|Y-) = 2.5244, H(Y|X-,Y-) = 2.5116, TE(X->Y) = 0.0128  \n",
      "H(Y|Y-) = 2.0667, H(Y|X-,Y-) = 2.0524, TE(X->Y) = 0.0143  \n",
      "# Coupling =  0.25 #\n",
      "H(Y|Y-) = 2.5255, H(Y|X-,Y-) = 2.5115, TE(X->Y) = 0.014   \n",
      "H(Y|Y-) = 2.072, H(Y|X-,Y-) = 2.0316, TE(X->Y) = 0.0404  \n",
      "# Coupling =  0.375 #\n",
      "H(Y|Y-) = 2.5227, H(Y|X-,Y-) = 2.5143, TE(X->Y) = 0.0084  \n",
      "H(Y|Y-) = 2.053, H(Y|X-,Y-) = 1.9727, TE(X->Y) = 0.0803  \n",
      "# Coupling =  0.5 #\n",
      "H(Y|Y-) = 2.5235, H(Y|X-,Y-) = 2.5119, TE(X->Y) = 0.0116  \n",
      "H(Y|Y-) = 2.0223, H(Y|X-,Y-) = 1.8948, TE(X->Y) = 0.1275  \n",
      "# Coupling =  0.625 #\n",
      "H(Y|Y-) = 2.5251, H(Y|X-,Y-) = 2.5088, TE(X->Y) = 0.0163  \n",
      "H(Y|Y-) = 2.0063, H(Y|X-,Y-) = 1.8254, TE(X->Y) = 0.1809  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.523, H(Y|X-,Y-) = 2.5115, TE(X->Y) = 0.0115  \n",
      "H(Y|Y-) = 1.9937, H(Y|X-,Y-) = 1.7532, TE(X->Y) = 0.2405  \n",
      "# Coupling =  0.875 #\n",
      "H(Y|Y-) = 2.5251, H(Y|X-,Y-) = 2.5104, TE(X->Y) = 0.0147  \n",
      "H(Y|Y-) = 1.9769, H(Y|X-,Y-) = 1.6819, TE(X->Y) = 0.295   \n",
      "# Coupling =  1.0 #\n",
      "H(Y|Y-) = 2.5243, H(Y|X-,Y-) = 2.5107, TE(X->Y) = 0.0136  \n",
      "H(Y|Y-) = 1.9527, H(Y|X-,Y-) = 1.595, TE(X->Y) = 0.3577   \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.4506, H(Y|X-,Y-) = 2.4407, TE(X->Y) = 0.0099  \n",
      "H(Y|Y-) = 2.1554, H(Y|X-,Y-) = 2.1483, TE(X->Y) = 0.0071  \n",
      "# Coupling =  0.125 #\n",
      "H(Y|Y-) = 2.4506, H(Y|X-,Y-) = 2.4372, TE(X->Y) = 0.0134  \n",
      "H(Y|Y-) = 2.1503, H(Y|X-,Y-) = 2.1349, TE(X->Y) = 0.0154  \n",
      "# Coupling =  0.25 #\n",
      "H(Y|Y-) = 2.4489, H(Y|X-,Y-) = 2.4391, TE(X->Y) = 0.0098  \n",
      "H(Y|Y-) = 2.117, H(Y|X-,Y-) = 2.0802, TE(X->Y) = 0.0368  \n",
      "# Coupling =  0.375 #\n",
      "H(Y|Y-) = 2.4491, H(Y|X-,Y-) = 2.4394, TE(X->Y) = 0.0097  \n",
      "H(Y|Y-) = 2.0286, H(Y|X-,Y-) = 1.9531, TE(X->Y) = 0.0755  \n",
      "# Coupling =  0.5 #\n",
      "H(Y|Y-) = 2.4502, H(Y|X-,Y-) = 2.4379, TE(X->Y) = 0.0123  \n",
      "H(Y|Y-) = 1.9688, H(Y|X-,Y-) = 1.8464, TE(X->Y) = 0.1224  \n",
      "# Coupling =  0.625 #\n",
      "H(Y|Y-) = 2.4497, H(Y|X-,Y-) = 2.4369, TE(X->Y) = 0.0128  \n",
      "H(Y|Y-) = 1.9281, H(Y|X-,Y-) = 1.7519, TE(X->Y) = 0.1762  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.449, H(Y|X-,Y-) = 2.4362, TE(X->Y) = 0.0128  \n",
      "H(Y|Y-) = 1.8839, H(Y|X-,Y-) = 1.6457, TE(X->Y) = 0.2382  \n",
      "# Coupling =  0.875 #\n",
      "H(Y|Y-) = 2.4492, H(Y|X-,Y-) = 2.4356, TE(X->Y) = 0.0136  \n",
      "H(Y|Y-) = 1.849, H(Y|X-,Y-) = 1.5482, TE(X->Y) = 0.3008  \n",
      "# Coupling =  1.0 #\n",
      "H(Y|Y-) = 2.4481, H(Y|X-,Y-) = 2.435, TE(X->Y) = 0.0131   \n",
      "H(Y|Y-) = 1.8238, H(Y|X-,Y-) = 1.4662, TE(X->Y) = 0.3576  \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.4642, H(Y|X-,Y-) = 2.451, TE(X->Y) = 0.0132   \n",
      "H(Y|Y-) = 2.1119, H(Y|X-,Y-) = 2.1058, TE(X->Y) = 0.0061  \n",
      "# Coupling =  0.125 #\n",
      "H(Y|Y-) = 2.4639, H(Y|X-,Y-) = 2.4477, TE(X->Y) = 0.0162  \n",
      "H(Y|Y-) = 2.0636, H(Y|X-,Y-) = 2.05, TE(X->Y) = 0.0136    \n",
      "# Coupling =  0.25 #\n",
      "H(Y|Y-) = 2.4636, H(Y|X-,Y-) = 2.4505, TE(X->Y) = 0.0131  \n",
      "H(Y|Y-) = 2.0367, H(Y|X-,Y-) = 1.9941, TE(X->Y) = 0.0426  \n",
      "# Coupling =  0.375 #\n",
      "H(Y|Y-) = 2.4634, H(Y|X-,Y-) = 2.4496, TE(X->Y) = 0.0138  \n",
      "H(Y|Y-) = 2.0173, H(Y|X-,Y-) = 1.9335, TE(X->Y) = 0.0838  \n",
      "# Coupling =  0.5 #\n",
      "H(Y|Y-) = 2.4645, H(Y|X-,Y-) = 2.4505, TE(X->Y) = 0.014   \n",
      "H(Y|Y-) = 2.0189, H(Y|X-,Y-) = 1.8872, TE(X->Y) = 0.1317  \n",
      "# Coupling =  0.625 #\n",
      "H(Y|Y-) = 2.4647, H(Y|X-,Y-) = 2.4516, TE(X->Y) = 0.0131  \n",
      "H(Y|Y-) = 2.0167, H(Y|X-,Y-) = 1.8232, TE(X->Y) = 0.1935  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.464, H(Y|X-,Y-) = 2.4546, TE(X->Y) = 0.0094  \n",
      "H(Y|Y-) = 2.0258, H(Y|X-,Y-) = 1.7756, TE(X->Y) = 0.2502  \n",
      "# Coupling =  0.875 #\n",
      "H(Y|Y-) = 2.464, H(Y|X-,Y-) = 2.4501, TE(X->Y) = 0.0139  \n",
      "H(Y|Y-) = 2.0011, H(Y|X-,Y-) = 1.6878, TE(X->Y) = 0.3133  \n",
      "# Coupling =  1.0 #\n",
      "H(Y|Y-) = 2.4645, H(Y|X-,Y-) = 2.4497, TE(X->Y) = 0.0148  \n",
      "H(Y|Y-) = 1.9692, H(Y|X-,Y-) = 1.5958, TE(X->Y) = 0.3734  \n"
     ]
    }
   ],
   "source": [
    "lg_results_TE_X2Y = Results(columns=['method', 'coupling'])\n",
    "lg_results_TE_Y2X = Results(columns=['method', 'coupling'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for lam, generator in zip(lg_lambda_range, lg_generator_lst):\n",
    "        print(\"# Coupling = \", lam, \"#\")\n",
    "        # Simulate data\n",
    "        X, Y = generator.simulate(time=SAMPLE_SIZE, seed=r)\n",
    "        # Estimate X -> Y\n",
    "        TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        lg_results_TE_X2Y.write(method='njee', coupling=lam, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        lg_results_TE_Y2X.write(method='njee', coupling=lam, value=TE_Y2X)\n",
    "\n",
    "lg_results_TE_X2Y.df.to_csv('results/njee/lg_results_TE_X2Y_bv.csv', index=False)\n",
    "lg_results_TE_Y2X.df.to_csv('results/njee/lg_results_TE_Y2X_bv.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Specify the range of lambda values to test\n",
    "jp_lambda_range = list(np.linspace(-3, 3, 9, endpoint=True))\n",
    "\n",
    "# Initialize the list of generators with one for each lambda value\n",
    "jp_generator_lst = [MVJointProcessSimulator(n_dim=1, lam=lam) for lam in jp_lambda_range]\n",
    "\n",
    "# get the reference values\n",
    "jp_TE_X2Y_ref_lst = [generator.analytic_transfer_entropy('X', 'Y') for generator in jp_generator_lst]\n",
    "jp_TE_Y2X_ref_lst = [generator.analytic_transfer_entropy('Y', 'X') for generator in jp_generator_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "H(Y|Y-) = 2.5414, H(Y|X-,Y-) = 1.7294, TE(X->Y) = 0.812   \n",
      "H(Y|Y-) = 2.5387, H(Y|X-,Y-) = 2.5242, TE(X->Y) = 0.0145  \n",
      "# Coupling =  -2.25 #\n",
      "H(Y|Y-) = 2.5407, H(Y|X-,Y-) = 1.7392, TE(X->Y) = 0.8015  \n",
      "H(Y|Y-) = 2.5383, H(Y|X-,Y-) = 2.5248, TE(X->Y) = 0.0135  \n",
      "# Coupling =  -1.5 #\n",
      "H(Y|Y-) = 2.542, H(Y|X-,Y-) = 1.7881, TE(X->Y) = 0.7539  \n",
      "H(Y|Y-) = 2.5386, H(Y|X-,Y-) = 2.5238, TE(X->Y) = 0.0148  \n",
      "# Coupling =  -0.75 #\n",
      "H(Y|Y-) = 2.5388, H(Y|X-,Y-) = 1.9164, TE(X->Y) = 0.6224  \n",
      "H(Y|Y-) = 2.5391, H(Y|X-,Y-) = 2.5234, TE(X->Y) = 0.0157  \n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.5305, H(Y|X-,Y-) = 2.1384, TE(X->Y) = 0.3921  \n",
      "H(Y|Y-) = 2.5391, H(Y|X-,Y-) = 2.5262, TE(X->Y) = 0.0129  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.602, H(Y|X-,Y-) = 2.4201, TE(X->Y) = 0.1819  \n",
      "H(Y|Y-) = 2.538, H(Y|X-,Y-) = 2.5268, TE(X->Y) = 0.0112  \n",
      "# Coupling =  1.5 #\n",
      "H(Y|Y-) = 2.5999, H(Y|X-,Y-) = 2.542, TE(X->Y) = 0.0579   \n",
      "H(Y|Y-) = 2.5381, H(Y|X-,Y-) = 2.5304, TE(X->Y) = 0.0077  \n",
      "# Coupling =  2.25 #\n",
      "H(Y|Y-) = 2.5961, H(Y|X-,Y-) = 2.5794, TE(X->Y) = 0.0167  \n",
      "H(Y|Y-) = 2.5383, H(Y|X-,Y-) = 2.5282, TE(X->Y) = 0.0101  \n",
      "# Coupling =  3.0 #\n",
      "H(Y|Y-) = 2.5962, H(Y|X-,Y-) = 2.5837, TE(X->Y) = 0.0125  \n",
      "H(Y|Y-) = 2.5376, H(Y|X-,Y-) = 2.5275, TE(X->Y) = 0.0101  \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "H(Y|Y-) = 2.6223, H(Y|X-,Y-) = 1.807, TE(X->Y) = 0.8153   \n",
      "H(Y|Y-) = 2.601, H(Y|X-,Y-) = 2.5843, TE(X->Y) = 0.0167  \n",
      "# Coupling =  -2.25 #\n",
      "H(Y|Y-) = 2.6225, H(Y|X-,Y-) = 1.8213, TE(X->Y) = 0.8012  \n",
      "H(Y|Y-) = 2.5992, H(Y|X-,Y-) = 2.5879, TE(X->Y) = 0.0113  \n",
      "# Coupling =  -1.5 #\n",
      "H(Y|Y-) = 2.6236, H(Y|X-,Y-) = 1.8682, TE(X->Y) = 0.7554  \n",
      "H(Y|Y-) = 2.5996, H(Y|X-,Y-) = 2.5862, TE(X->Y) = 0.0134  \n",
      "# Coupling =  -0.75 #\n",
      "H(Y|Y-) = 2.5841, H(Y|X-,Y-) = 1.9578, TE(X->Y) = 0.6263  \n",
      "H(Y|Y-) = 2.5991, H(Y|X-,Y-) = 2.5873, TE(X->Y) = 0.0118  \n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.5738, H(Y|X-,Y-) = 2.1571, TE(X->Y) = 0.4167  \n",
      "H(Y|Y-) = 2.5987, H(Y|X-,Y-) = 2.5832, TE(X->Y) = 0.0155  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.5716, H(Y|X-,Y-) = 2.3909, TE(X->Y) = 0.1807  \n",
      "H(Y|Y-) = 2.5989, H(Y|X-,Y-) = 2.5843, TE(X->Y) = 0.0146  \n",
      "# Coupling =  1.5 #\n",
      "H(Y|Y-) = 2.5901, H(Y|X-,Y-) = 2.5356, TE(X->Y) = 0.0545  \n",
      "H(Y|Y-) = 2.5988, H(Y|X-,Y-) = 2.5863, TE(X->Y) = 0.0125  \n",
      "# Coupling =  2.25 #\n",
      "H(Y|Y-) = 2.5912, H(Y|X-,Y-) = 2.5714, TE(X->Y) = 0.0198  \n",
      "H(Y|Y-) = 2.5988, H(Y|X-,Y-) = 2.5844, TE(X->Y) = 0.0144  \n",
      "# Coupling =  3.0 #\n",
      "H(Y|Y-) = 2.5895, H(Y|X-,Y-) = 2.5753, TE(X->Y) = 0.0142  \n",
      "H(Y|Y-) = 2.6007, H(Y|X-,Y-) = 2.5873, TE(X->Y) = 0.0134  \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "H(Y|Y-) = 2.6472, H(Y|X-,Y-) = 1.8277, TE(X->Y) = 0.8195  \n",
      "H(Y|Y-) = 2.5768, H(Y|X-,Y-) = 2.561, TE(X->Y) = 0.0158   \n",
      "# Coupling =  -2.25 #\n",
      "H(Y|Y-) = 2.6454, H(Y|X-,Y-) = 1.8425, TE(X->Y) = 0.8029  \n",
      "H(Y|Y-) = 2.5756, H(Y|X-,Y-) = 2.5631, TE(X->Y) = 0.0125  \n",
      "# Coupling =  -1.5 #\n",
      "H(Y|Y-) = 2.6646, H(Y|X-,Y-) = 1.9097, TE(X->Y) = 0.7549  \n",
      "H(Y|Y-) = 2.5777, H(Y|X-,Y-) = 2.563, TE(X->Y) = 0.0147   \n",
      "# Coupling =  -0.75 #\n",
      "H(Y|Y-) = 2.6625, H(Y|X-,Y-) = 2.0397, TE(X->Y) = 0.6228  \n",
      "H(Y|Y-) = 2.5775, H(Y|X-,Y-) = 2.5649, TE(X->Y) = 0.0126  \n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.6046, H(Y|X-,Y-) = 2.1977, TE(X->Y) = 0.4069  \n",
      "H(Y|Y-) = 2.5774, H(Y|X-,Y-) = 2.5614, TE(X->Y) = 0.016   \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.5977, H(Y|X-,Y-) = 2.4118, TE(X->Y) = 0.1859  \n",
      "H(Y|Y-) = 2.5773, H(Y|X-,Y-) = 2.5647, TE(X->Y) = 0.0126  \n",
      "# Coupling =  1.5 #\n",
      "H(Y|Y-) = 2.5871, H(Y|X-,Y-) = 2.5377, TE(X->Y) = 0.0494  \n",
      "H(Y|Y-) = 2.578, H(Y|X-,Y-) = 2.5604, TE(X->Y) = 0.0176  \n",
      "# Coupling =  2.25 #\n",
      "H(Y|Y-) = 2.5882, H(Y|X-,Y-) = 2.5712, TE(X->Y) = 0.017   \n",
      "H(Y|Y-) = 2.5762, H(Y|X-,Y-) = 2.5624, TE(X->Y) = 0.0138  \n",
      "# Coupling =  3.0 #\n",
      "H(Y|Y-) = 2.5875, H(Y|X-,Y-) = 2.5746, TE(X->Y) = 0.0129  \n",
      "H(Y|Y-) = 2.5774, H(Y|X-,Y-) = 2.5613, TE(X->Y) = 0.0161  \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "H(Y|Y-) = 2.5793, H(Y|X-,Y-) = 1.7752, TE(X->Y) = 0.8041  \n",
      "H(Y|Y-) = 2.5172, H(Y|X-,Y-) = 2.502, TE(X->Y) = 0.0152   \n",
      "# Coupling =  -2.25 #\n",
      "H(Y|Y-) = 2.5789, H(Y|X-,Y-) = 1.7832, TE(X->Y) = 0.7957  \n",
      "H(Y|Y-) = 2.5179, H(Y|X-,Y-) = 2.5023, TE(X->Y) = 0.0156  \n",
      "# Coupling =  -1.5 #\n",
      "H(Y|Y-) = 2.5804, H(Y|X-,Y-) = 1.8391, TE(X->Y) = 0.7413  \n",
      "H(Y|Y-) = 2.5179, H(Y|X-,Y-) = 2.5078, TE(X->Y) = 0.0101  \n",
      "# Coupling =  -0.75 #\n",
      "H(Y|Y-) = 2.5789, H(Y|X-,Y-) = 1.9727, TE(X->Y) = 0.6062  \n",
      "H(Y|Y-) = 2.5181, H(Y|X-,Y-) = 2.5037, TE(X->Y) = 0.0144  \n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.5594, H(Y|X-,Y-) = 2.1639, TE(X->Y) = 0.3955  \n",
      "H(Y|Y-) = 2.517, H(Y|X-,Y-) = 2.5061, TE(X->Y) = 0.0109  \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.5765, H(Y|X-,Y-) = 2.3974, TE(X->Y) = 0.1791  \n",
      "H(Y|Y-) = 2.5172, H(Y|X-,Y-) = 2.5042, TE(X->Y) = 0.013   \n",
      "# Coupling =  1.5 #\n",
      "H(Y|Y-) = 2.5908, H(Y|X-,Y-) = 2.5427, TE(X->Y) = 0.0481  \n",
      "H(Y|Y-) = 2.5179, H(Y|X-,Y-) = 2.5062, TE(X->Y) = 0.0117  \n",
      "# Coupling =  2.25 #\n",
      "H(Y|Y-) = 2.5672, H(Y|X-,Y-) = 2.5526, TE(X->Y) = 0.0146  \n",
      "H(Y|Y-) = 2.5185, H(Y|X-,Y-) = 2.504, TE(X->Y) = 0.0145   \n",
      "# Coupling =  3.0 #\n",
      "H(Y|Y-) = 2.5681, H(Y|X-,Y-) = 2.5573, TE(X->Y) = 0.0108  \n",
      "H(Y|Y-) = 2.5163, H(Y|X-,Y-) = 2.5042, TE(X->Y) = 0.0121  \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "H(Y|Y-) = 2.5517, H(Y|X-,Y-) = 1.7386, TE(X->Y) = 0.8131  \n",
      "H(Y|Y-) = 2.497, H(Y|X-,Y-) = 2.4798, TE(X->Y) = 0.0172  \n",
      "# Coupling =  -2.25 #\n",
      "H(Y|Y-) = 2.5536, H(Y|X-,Y-) = 1.7539, TE(X->Y) = 0.7997  \n",
      "H(Y|Y-) = 2.496, H(Y|X-,Y-) = 2.4812, TE(X->Y) = 0.0148  \n",
      "# Coupling =  -1.5 #\n",
      "H(Y|Y-) = 2.549, H(Y|X-,Y-) = 1.8034, TE(X->Y) = 0.7456  \n",
      "H(Y|Y-) = 2.4981, H(Y|X-,Y-) = 2.4836, TE(X->Y) = 0.0145  \n",
      "# Coupling =  -0.75 #\n",
      "H(Y|Y-) = 2.6063, H(Y|X-,Y-) = 1.9873, TE(X->Y) = 0.619   \n",
      "H(Y|Y-) = 2.4977, H(Y|X-,Y-) = 2.484, TE(X->Y) = 0.0137   \n",
      "# Coupling =  0.0 #\n",
      "H(Y|Y-) = 2.6011, H(Y|X-,Y-) = 2.2041, TE(X->Y) = 0.397   \n",
      "H(Y|Y-) = 2.4967, H(Y|X-,Y-) = 2.4857, TE(X->Y) = 0.011   \n",
      "# Coupling =  0.75 #\n",
      "H(Y|Y-) = 2.5407, H(Y|X-,Y-) = 2.3585, TE(X->Y) = 0.1822  \n",
      "H(Y|Y-) = 2.4971, H(Y|X-,Y-) = 2.4835, TE(X->Y) = 0.0136  \n",
      "# Coupling =  1.5 #\n",
      "H(Y|Y-) = 2.5783, H(Y|X-,Y-) = 2.5244, TE(X->Y) = 0.0539  \n",
      "H(Y|Y-) = 2.4968, H(Y|X-,Y-) = 2.4818, TE(X->Y) = 0.015   \n",
      "# Coupling =  2.25 #\n",
      "H(Y|Y-) = 2.575, H(Y|X-,Y-) = 2.5621, TE(X->Y) = 0.0129  \n",
      "H(Y|Y-) = 2.4986, H(Y|X-,Y-) = 2.4834, TE(X->Y) = 0.0152  \n",
      "# Coupling =  3.0 #\n",
      "H(Y|Y-) = 2.5743, H(Y|X-,Y-) = 2.5633, TE(X->Y) = 0.011   \n",
      "H(Y|Y-) = 2.4977, H(Y|X-,Y-) = 2.4832, TE(X->Y) = 0.0145  \n"
     ]
    }
   ],
   "source": [
    "jp_results_TE_X2Y = Results(columns=['method', 'coupling'])\n",
    "jp_results_TE_Y2X = Results(columns=['method', 'coupling'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for lam, generator in zip(jp_lambda_range, jp_generator_lst):\n",
    "        print(\"# Coupling = \", lam, \"#\")\n",
    "        # Simulate data\n",
    "        X, Y = generator.simulate(time=SAMPLE_SIZE, seed=r)\n",
    "        # Estimate X -> Y\n",
    "        TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        jp_results_TE_X2Y.write(method='njee', coupling=lam, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        jp_results_TE_Y2X.write(method='njee', coupling=lam, value=TE_Y2X)\n",
    "\n",
    "jp_results_TE_X2Y.df.to_csv('results/njee/jp_results_TE_X2Y_bv.csv', index=False)\n",
    "jp_results_TE_Y2X.df.to_csv('results/njee/jp_results_TE_Y2X_bv.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sample size scaling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "lg_generator = MVLinearGaussianSimulator(n_dim=1, coupling=0.5)\n",
    "jp_generator = MVJointProcessSimulator(n_dim=1, lam=0.0)\n",
    "sample_sizes = [500, 1000, 5000, 10000, 50000, 100000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.5722, H(Y|X-,Y-) = 2.2519, TE(X->Y) = 0.3203  \n",
      "H(Y|Y-) = 2.1984, H(Y|X-,Y-) = 1.8299, TE(X->Y) = 0.3685  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.6864, H(Y|X-,Y-) = 2.51, TE(X->Y) = 0.1764    \n",
      "H(Y|Y-) = 2.2154, H(Y|X-,Y-) = 1.9957, TE(X->Y) = 0.2197  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.5734, H(Y|X-,Y-) = 2.5471, TE(X->Y) = 0.0263  \n",
      "H(Y|Y-) = 2.1107, H(Y|X-,Y-) = 1.9809, TE(X->Y) = 0.1298  \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.516, H(Y|X-,Y-) = 2.5065, TE(X->Y) = 0.0095  \n",
      "H(Y|Y-) = 2.0279, H(Y|X-,Y-) = 1.8981, TE(X->Y) = 0.1298  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.4853, H(Y|X-,Y-) = 2.4836, TE(X->Y) = 0.0017  \n",
      "H(Y|Y-) = 1.8095, H(Y|X-,Y-) = 1.688, TE(X->Y) = 0.1215   \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.4662, H(Y|X-,Y-) = 2.4655, TE(X->Y) = 0.0007  \n",
      "H(Y|Y-) = 1.8072, H(Y|X-,Y-) = 1.6888, TE(X->Y) = 0.1184  \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.411, H(Y|X-,Y-) = 2.0423, TE(X->Y) = 0.3687  \n",
      "H(Y|Y-) = 2.279, H(Y|X-,Y-) = 1.9294, TE(X->Y) = 0.3496  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.5146, H(Y|X-,Y-) = 2.337, TE(X->Y) = 0.1776   \n",
      "H(Y|Y-) = 2.1624, H(Y|X-,Y-) = 1.9836, TE(X->Y) = 0.1788  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.5315, H(Y|X-,Y-) = 2.5109, TE(X->Y) = 0.0206  \n",
      "H(Y|Y-) = 2.0359, H(Y|X-,Y-) = 1.8981, TE(X->Y) = 0.1378  \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.5152, H(Y|X-,Y-) = 2.5064, TE(X->Y) = 0.0088  \n",
      "H(Y|Y-) = 1.9144, H(Y|X-,Y-) = 1.7943, TE(X->Y) = 0.1201  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.4519, H(Y|X-,Y-) = 2.4499, TE(X->Y) = 0.002   \n",
      "H(Y|Y-) = 1.8211, H(Y|X-,Y-) = 1.6965, TE(X->Y) = 0.1246  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.4323, H(Y|X-,Y-) = 2.4346, TE(X->Y) = -0.0023 \n",
      "H(Y|Y-) = 1.8196, H(Y|X-,Y-) = 1.6977, TE(X->Y) = 0.1219  \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.5064, H(Y|X-,Y-) = 2.1982, TE(X->Y) = 0.3082  \n",
      "H(Y|Y-) = 2.1189, H(Y|X-,Y-) = 1.7849, TE(X->Y) = 0.334   \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.5925, H(Y|X-,Y-) = 2.4357, TE(X->Y) = 0.1568  \n",
      "H(Y|Y-) = 2.0907, H(Y|X-,Y-) = 1.875, TE(X->Y) = 0.2157   \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.6034, H(Y|X-,Y-) = 2.5771, TE(X->Y) = 0.0263  \n",
      "H(Y|Y-) = 2.0343, H(Y|X-,Y-) = 1.8979, TE(X->Y) = 0.1364  \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.5253, H(Y|X-,Y-) = 2.5139, TE(X->Y) = 0.0114  \n",
      "H(Y|Y-) = 2.0216, H(Y|X-,Y-) = 1.8939, TE(X->Y) = 0.1277  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.414, H(Y|X-,Y-) = 2.4142, TE(X->Y) = -0.0002 \n",
      "H(Y|Y-) = 1.9671, H(Y|X-,Y-) = 1.8424, TE(X->Y) = 0.1247  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.3298, H(Y|X-,Y-) = 2.3282, TE(X->Y) = 0.0016  \n",
      "H(Y|Y-) = 1.8823, H(Y|X-,Y-) = 1.7582, TE(X->Y) = 0.1241  \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.4542, H(Y|X-,Y-) = 2.0596, TE(X->Y) = 0.3946  \n",
      "H(Y|Y-) = 1.985, H(Y|X-,Y-) = 1.7005, TE(X->Y) = 0.2845  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.5147, H(Y|X-,Y-) = 2.3298, TE(X->Y) = 0.1849  \n",
      "H(Y|Y-) = 2.0585, H(Y|X-,Y-) = 1.865, TE(X->Y) = 0.1935   \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.4669, H(Y|X-,Y-) = 2.4375, TE(X->Y) = 0.0294  \n",
      "H(Y|Y-) = 2.0668, H(Y|X-,Y-) = 1.9422, TE(X->Y) = 0.1246  \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.45, H(Y|X-,Y-) = 2.4371, TE(X->Y) = 0.0129  \n",
      "H(Y|Y-) = 1.9698, H(Y|X-,Y-) = 1.8466, TE(X->Y) = 0.1232  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.3439, H(Y|X-,Y-) = 2.3425, TE(X->Y) = 0.0014  \n",
      "H(Y|Y-) = 1.8457, H(Y|X-,Y-) = 1.7228, TE(X->Y) = 0.1229  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.3432, H(Y|X-,Y-) = 2.3405, TE(X->Y) = 0.0027  \n",
      "H(Y|Y-) = 1.8476, H(Y|X-,Y-) = 1.7276, TE(X->Y) = 0.12    \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.5616, H(Y|X-,Y-) = 2.202, TE(X->Y) = 0.3596   \n",
      "H(Y|Y-) = 2.0897, H(Y|X-,Y-) = 1.751, TE(X->Y) = 0.3387   \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.5412, H(Y|X-,Y-) = 2.3912, TE(X->Y) = 0.15    \n",
      "H(Y|Y-) = 2.1209, H(Y|X-,Y-) = 1.9025, TE(X->Y) = 0.2184  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.4623, H(Y|X-,Y-) = 2.4374, TE(X->Y) = 0.0249  \n",
      "H(Y|Y-) = 2.1503, H(Y|X-,Y-) = 2.0103, TE(X->Y) = 0.14    \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.4657, H(Y|X-,Y-) = 2.451, TE(X->Y) = 0.0147   \n",
      "H(Y|Y-) = 2.0189, H(Y|X-,Y-) = 1.8856, TE(X->Y) = 0.1333  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.3442, H(Y|X-,Y-) = 2.3426, TE(X->Y) = 0.0016  \n",
      "H(Y|Y-) = 1.9105, H(Y|X-,Y-) = 1.7885, TE(X->Y) = 0.122   \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.3438, H(Y|X-,Y-) = 2.3443, TE(X->Y) = -0.0005 \n",
      "H(Y|Y-) = 1.9143, H(Y|X-,Y-) = 1.7926, TE(X->Y) = 0.1217  \n"
     ]
    }
   ],
   "source": [
    "lg_results_TE_X2Y = Results(columns=['method', 'sample_size'])\n",
    "lg_results_TE_Y2X = Results(columns=['method', 'sample_size'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for samples in sample_sizes:\n",
    "        print(\"# Samples = \", samples, \"#\")\n",
    "        # Simulate data\n",
    "        X, Y = lg_generator.simulate(time=samples, seed=r)\n",
    "        # Estimate X -> Y\n",
    "        TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        lg_results_TE_X2Y.write(method='njee', sample_size=samples, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        lg_results_TE_Y2X.write(method='njee', sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "lg_results_TE_X2Y.df.to_csv('results/njee/lg_results_TE_X2Y_ss.csv', index=False)\n",
    "lg_results_TE_Y2X.df.to_csv('results/njee/lg_results_TE_Y2X_ss.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.4875, H(Y|X-,Y-) = 1.5899, TE(X->Y) = 0.8976  \n",
      "H(Y|Y-) = 2.5318, H(Y|X-,Y-) = 2.1453, TE(X->Y) = 0.3865  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.6888, H(Y|X-,Y-) = 1.8736, TE(X->Y) = 0.8152  \n",
      "H(Y|Y-) = 2.6333, H(Y|X-,Y-) = 2.4562, TE(X->Y) = 0.1771  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.6888, H(Y|X-,Y-) = 1.8665, TE(X->Y) = 0.8223  \n",
      "H(Y|Y-) = 2.7449, H(Y|X-,Y-) = 2.709, TE(X->Y) = 0.0359   \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.5428, H(Y|X-,Y-) = 1.728, TE(X->Y) = 0.8148   \n",
      "H(Y|Y-) = 2.5367, H(Y|X-,Y-) = 2.523, TE(X->Y) = 0.0137   \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.4524, H(Y|X-,Y-) = 1.6499, TE(X->Y) = 0.8025  \n",
      "H(Y|Y-) = 2.4333, H(Y|X-,Y-) = 2.4311, TE(X->Y) = 0.0022  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.4456, H(Y|X-,Y-) = 1.6408, TE(X->Y) = 0.8048  \n",
      "H(Y|Y-) = 2.447, H(Y|X-,Y-) = 2.4469, TE(X->Y) = 0.0001  \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.4597, H(Y|X-,Y-) = 1.5372, TE(X->Y) = 0.9225  \n",
      "H(Y|Y-) = 2.4229, H(Y|X-,Y-) = 2.0803, TE(X->Y) = 0.3426  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.706, H(Y|X-,Y-) = 1.7896, TE(X->Y) = 0.9164  \n",
      "H(Y|Y-) = 2.6257, H(Y|X-,Y-) = 2.468, TE(X->Y) = 0.1577   \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.6048, H(Y|X-,Y-) = 1.7979, TE(X->Y) = 0.8069  \n",
      "H(Y|Y-) = 2.5718, H(Y|X-,Y-) = 2.5432, TE(X->Y) = 0.0286  \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.6217, H(Y|X-,Y-) = 1.8066, TE(X->Y) = 0.8151  \n",
      "H(Y|Y-) = 2.599, H(Y|X-,Y-) = 2.5855, TE(X->Y) = 0.0135  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.4742, H(Y|X-,Y-) = 1.6746, TE(X->Y) = 0.7996  \n",
      "H(Y|Y-) = 2.5119, H(Y|X-,Y-) = 2.5093, TE(X->Y) = 0.0026  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.4503, H(Y|X-,Y-) = 1.6507, TE(X->Y) = 0.7996  \n",
      "H(Y|Y-) = 2.4935, H(Y|X-,Y-) = 2.4939, TE(X->Y) = -0.0004 \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.6206, H(Y|X-,Y-) = 1.6836, TE(X->Y) = 0.937   \n",
      "H(Y|Y-) = 2.5562, H(Y|X-,Y-) = 2.1499, TE(X->Y) = 0.4063  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.599, H(Y|X-,Y-) = 1.775, TE(X->Y) = 0.824    \n",
      "H(Y|Y-) = 2.5668, H(Y|X-,Y-) = 2.3963, TE(X->Y) = 0.1705  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.7027, H(Y|X-,Y-) = 1.8923, TE(X->Y) = 0.8104  \n",
      "H(Y|Y-) = 2.6599, H(Y|X-,Y-) = 2.6239, TE(X->Y) = 0.036   \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.6445, H(Y|X-,Y-) = 1.8265, TE(X->Y) = 0.818   \n",
      "H(Y|Y-) = 2.5775, H(Y|X-,Y-) = 2.562, TE(X->Y) = 0.0155   \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.5832, H(Y|X-,Y-) = 1.774, TE(X->Y) = 0.8092   \n",
      "H(Y|Y-) = 2.5523, H(Y|X-,Y-) = 2.5501, TE(X->Y) = 0.0022  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.3845, H(Y|X-,Y-) = 1.5905, TE(X->Y) = 0.794   \n",
      "H(Y|Y-) = 2.4276, H(Y|X-,Y-) = 2.4272, TE(X->Y) = 0.0004  \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.5254, H(Y|X-,Y-) = 1.6954, TE(X->Y) = 0.83    \n",
      "H(Y|Y-) = 2.4805, H(Y|X-,Y-) = 2.1004, TE(X->Y) = 0.3801  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.6437, H(Y|X-,Y-) = 1.8072, TE(X->Y) = 0.8365  \n",
      "H(Y|Y-) = 2.5937, H(Y|X-,Y-) = 2.4155, TE(X->Y) = 0.1782  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.5437, H(Y|X-,Y-) = 1.7361, TE(X->Y) = 0.8076  \n",
      "H(Y|Y-) = 2.6687, H(Y|X-,Y-) = 2.6414, TE(X->Y) = 0.0273  \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.5811, H(Y|X-,Y-) = 1.7726, TE(X->Y) = 0.8085  \n",
      "H(Y|Y-) = 2.5184, H(Y|X-,Y-) = 2.5049, TE(X->Y) = 0.0135  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.5183, H(Y|X-,Y-) = 1.7169, TE(X->Y) = 0.8014  \n",
      "H(Y|Y-) = 2.449, H(Y|X-,Y-) = 2.4491, TE(X->Y) = -0.0001 \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.4724, H(Y|X-,Y-) = 1.6657, TE(X->Y) = 0.8067  \n",
      "H(Y|Y-) = 2.4714, H(Y|X-,Y-) = 2.4736, TE(X->Y) = -0.0022 \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "# Samples =  500 #\n",
      "H(Y|Y-) = 2.5295, H(Y|X-,Y-) = 1.6608, TE(X->Y) = 0.8687  \n",
      "H(Y|Y-) = 2.5485, H(Y|X-,Y-) = 2.2197, TE(X->Y) = 0.3288  \n",
      "# Samples =  1000 #\n",
      "H(Y|Y-) = 2.5724, H(Y|X-,Y-) = 1.6958, TE(X->Y) = 0.8766  \n",
      "H(Y|Y-) = 2.5468, H(Y|X-,Y-) = 2.3676, TE(X->Y) = 0.1792  \n",
      "# Samples =  5000 #\n",
      "H(Y|Y-) = 2.6661, H(Y|X-,Y-) = 1.8215, TE(X->Y) = 0.8446  \n",
      "H(Y|Y-) = 2.6032, H(Y|X-,Y-) = 2.5722, TE(X->Y) = 0.031   \n",
      "# Samples =  10000 #\n",
      "H(Y|Y-) = 2.551, H(Y|X-,Y-) = 1.738, TE(X->Y) = 0.813    \n",
      "H(Y|Y-) = 2.4979, H(Y|X-,Y-) = 2.4831, TE(X->Y) = 0.0148  \n",
      "# Samples =  50000 #\n",
      "H(Y|Y-) = 2.5484, H(Y|X-,Y-) = 1.7431, TE(X->Y) = 0.8053  \n",
      "H(Y|Y-) = 2.5724, H(Y|X-,Y-) = 2.5718, TE(X->Y) = 0.0006  \n",
      "# Samples =  100000 #\n",
      "H(Y|Y-) = 2.4929, H(Y|X-,Y-) = 1.6872, TE(X->Y) = 0.8057  \n",
      "H(Y|Y-) = 2.4272, H(Y|X-,Y-) = 2.4311, TE(X->Y) = -0.0039 \n"
     ]
    }
   ],
   "source": [
    "jp_results_TE_X2Y = Results(columns=['method', 'sample_size'])\n",
    "jp_results_TE_Y2X = Results(columns=['method', 'sample_size'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for samples in sample_sizes:\n",
    "        print(\"# Samples = \", samples, \"#\")\n",
    "        # Simulate data\n",
    "        X, Y = jp_generator.simulate(time=samples, seed=r)\n",
    "        # Estimate X -> Y\n",
    "        TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        jp_results_TE_X2Y.write(method='njee', sample_size=samples, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "        jp_results_TE_Y2X.write(method='njee', sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "jp_results_TE_X2Y.df.to_csv('results/njee/jp_results_TE_X2Y_ss.csv', index=False)\n",
    "jp_results_TE_Y2X.df.to_csv('results/njee/jp_results_TE_Y2X_ss.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Dimensionality Scaling with redundant dimensions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "dim_range = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]\n",
    "sample_sizes = [10000, 100000]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Linear Gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the list of generators with one for each dimension\n",
    "lg_generator_lst = [MVLinearGaussianSimulator(n_dim=dim, n_redundant_dim=dim-1) for dim in dim_range]\n",
    "# Get the reference values\n",
    "lg_TE_X2Y_ref_lst = [generator.analytic_transfer_entropy('X', 'Y') for generator in lg_generator_lst]\n",
    "lg_TE_Y2X_ref_lst = [generator.analytic_transfer_entropy('Y', 'X') for generator in lg_generator_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5174, H(Y|X-,Y-) = 2.5077, TE(X->Y) = 0.0097  \n",
      "H(Y|Y-) = 2.027, H(Y|X-,Y-) = 1.8983, TE(X->Y) = 0.1287  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4663, H(Y|X-,Y-) = 2.4654, TE(X->Y) = 0.0009  \n",
      "H(Y|Y-) = 1.8079, H(Y|X-,Y-) = 1.6884, TE(X->Y) = 0.1195  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0677, H(Y|X-,Y-) = 5.0411, TE(X->Y) = 0.0266  \n",
      "H(Y|Y-) = 4.4901, H(Y|X-,Y-) = 4.3457, TE(X->Y) = 0.1444  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9438, H(Y|X-,Y-) = 4.9458, TE(X->Y) = -0.002  \n",
      "H(Y|Y-) = 4.3512, H(Y|X-,Y-) = 4.2275, TE(X->Y) = 0.1237  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.5649, H(Y|X-,Y-) = 7.522, TE(X->Y) = 0.0429   \n",
      "H(Y|Y-) = 7.0837, H(Y|X-,Y-) = 6.9237, TE(X->Y) = 0.16    \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.3036, H(Y|X-,Y-) = 7.2913, TE(X->Y) = 0.0123  \n",
      "H(Y|Y-) = 6.8025, H(Y|X-,Y-) = 6.6765, TE(X->Y) = 0.126   \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 9.9883, H(Y|X-,Y-) = 9.9222, TE(X->Y) = 0.0661  \n",
      "H(Y|Y-) = 9.6934, H(Y|X-,Y-) = 9.5092, TE(X->Y) = 0.1842  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.7301, H(Y|X-,Y-) = 9.7264, TE(X->Y) = 0.0037  \n",
      "H(Y|Y-) = 9.2148, H(Y|X-,Y-) = 9.0964, TE(X->Y) = 0.1184  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.6374, H(Y|X-,Y-) = 12.5427, TE(X->Y) = 0.0947 \n",
      "H(Y|Y-) = 12.189, H(Y|X-,Y-) = 11.9778, TE(X->Y) = 0.2112 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.2967, H(Y|X-,Y-) = 12.293, TE(X->Y) = 0.0037  \n",
      "H(Y|Y-) = 11.6214, H(Y|X-,Y-) = 11.4997, TE(X->Y) = 0.1217 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.2176, H(Y|X-,Y-) = 15.0818, TE(X->Y) = 0.1358 \n",
      "H(Y|Y-) = 14.5858, H(Y|X-,Y-) = 14.3327, TE(X->Y) = 0.2531 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.7398, H(Y|X-,Y-) = 14.7233, TE(X->Y) = 0.0165 \n",
      "H(Y|Y-) = 14.0367, H(Y|X-,Y-) = 13.911, TE(X->Y) = 0.1257  \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.8015, H(Y|X-,Y-) = 17.6041, TE(X->Y) = 0.1974 \n",
      "H(Y|Y-) = 17.0719, H(Y|X-,Y-) = 16.7721, TE(X->Y) = 0.2998 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.223, H(Y|X-,Y-) = 17.1993, TE(X->Y) = 0.0237 \n",
      "H(Y|Y-) = 16.4921, H(Y|X-,Y-) = 16.365, TE(X->Y) = 0.1271  \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.2462, H(Y|X-,Y-) = 20.0279, TE(X->Y) = 0.2183 \n",
      "H(Y|Y-) = 19.5608, H(Y|X-,Y-) = 19.2258, TE(X->Y) = 0.335  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.7997, H(Y|X-,Y-) = 19.78, TE(X->Y) = 0.0197   \n",
      "H(Y|Y-) = 18.9529, H(Y|X-,Y-) = 18.8273, TE(X->Y) = 0.1256 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.69, H(Y|X-,Y-) = 22.4162, TE(X->Y) = 0.2738 \n",
      "H(Y|Y-) = 22.2018, H(Y|X-,Y-) = 21.7944, TE(X->Y) = 0.4074 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.2457, H(Y|X-,Y-) = 22.2331, TE(X->Y) = 0.0126 \n",
      "H(Y|Y-) = 21.502, H(Y|X-,Y-) = 21.3646, TE(X->Y) = 0.1374 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.0764, H(Y|X-,Y-) = 24.7547, TE(X->Y) = 0.3217 \n",
      "H(Y|Y-) = 24.6053, H(Y|X-,Y-) = 24.1555, TE(X->Y) = 0.4498 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.7345, H(Y|X-,Y-) = 24.7164, TE(X->Y) = 0.0181 \n",
      "H(Y|Y-) = 23.9312, H(Y|X-,Y-) = 23.7903, TE(X->Y) = 0.1409 \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5149, H(Y|X-,Y-) = 2.5036, TE(X->Y) = 0.0113  \n",
      "H(Y|Y-) = 1.9142, H(Y|X-,Y-) = 1.7939, TE(X->Y) = 0.1203  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4322, H(Y|X-,Y-) = 2.4345, TE(X->Y) = -0.0023 \n",
      "H(Y|Y-) = 1.8198, H(Y|X-,Y-) = 1.6976, TE(X->Y) = 0.1222  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.1377, H(Y|X-,Y-) = 5.1099, TE(X->Y) = 0.0278  \n",
      "H(Y|Y-) = 4.448, H(Y|X-,Y-) = 4.3181, TE(X->Y) = 0.1299  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9444, H(Y|X-,Y-) = 4.9434, TE(X->Y) = 0.001   \n",
      "H(Y|Y-) = 4.2987, H(Y|X-,Y-) = 4.1767, TE(X->Y) = 0.122   \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.6477, H(Y|X-,Y-) = 7.6051, TE(X->Y) = 0.0426  \n",
      "H(Y|Y-) = 7.0843, H(Y|X-,Y-) = 6.9233, TE(X->Y) = 0.161   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.3867, H(Y|X-,Y-) = 7.3815, TE(X->Y) = 0.0052  \n",
      "H(Y|Y-) = 6.7884, H(Y|X-,Y-) = 6.6652, TE(X->Y) = 0.1232  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.1844, H(Y|X-,Y-) = 10.1108, TE(X->Y) = 0.0736 \n",
      "H(Y|Y-) = 9.5355, H(Y|X-,Y-) = 9.361, TE(X->Y) = 0.1745   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.8106, H(Y|X-,Y-) = 9.8039, TE(X->Y) = 0.0067  \n",
      "H(Y|Y-) = 9.2452, H(Y|X-,Y-) = 9.1191, TE(X->Y) = 0.1261  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.6213, H(Y|X-,Y-) = 12.5173, TE(X->Y) = 0.104  \n",
      "H(Y|Y-) = 12.1214, H(Y|X-,Y-) = 11.9121, TE(X->Y) = 0.2093 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3453, H(Y|X-,Y-) = 12.3449, TE(X->Y) = 0.0004 \n",
      "H(Y|Y-) = 11.6743, H(Y|X-,Y-) = 11.5445, TE(X->Y) = 0.1298 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.1533, H(Y|X-,Y-) = 15.009, TE(X->Y) = 0.1443  \n",
      "H(Y|Y-) = 14.6222, H(Y|X-,Y-) = 14.3873, TE(X->Y) = 0.2349 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.9269, H(Y|X-,Y-) = 14.9155, TE(X->Y) = 0.0114 \n",
      "H(Y|Y-) = 14.1713, H(Y|X-,Y-) = 14.0363, TE(X->Y) = 0.135  \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.6591, H(Y|X-,Y-) = 17.478, TE(X->Y) = 0.1811  \n",
      "H(Y|Y-) = 17.1209, H(Y|X-,Y-) = 16.8323, TE(X->Y) = 0.2886 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.4516, H(Y|X-,Y-) = 17.4473, TE(X->Y) = 0.0043 \n",
      "H(Y|Y-) = 16.6784, H(Y|X-,Y-) = 16.5459, TE(X->Y) = 0.1325 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.2561, H(Y|X-,Y-) = 20.0302, TE(X->Y) = 0.2259 \n",
      "H(Y|Y-) = 19.6329, H(Y|X-,Y-) = 19.3137, TE(X->Y) = 0.3192 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.7301, H(Y|X-,Y-) = 19.7217, TE(X->Y) = 0.0084 \n",
      "H(Y|Y-) = 19.0538, H(Y|X-,Y-) = 18.9234, TE(X->Y) = 0.1304 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.6339, H(Y|X-,Y-) = 22.3907, TE(X->Y) = 0.2432 \n",
      "H(Y|Y-) = 22.0351, H(Y|X-,Y-) = 21.6639, TE(X->Y) = 0.3712 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.1076, H(Y|X-,Y-) = 22.0859, TE(X->Y) = 0.0217 \n",
      "H(Y|Y-) = 21.6593, H(Y|X-,Y-) = 21.5213, TE(X->Y) = 0.138  \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.1935, H(Y|X-,Y-) = 24.8507, TE(X->Y) = 0.3428 \n",
      "H(Y|Y-) = 24.6147, H(Y|X-,Y-) = 24.1978, TE(X->Y) = 0.4169 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.5651, H(Y|X-,Y-) = 24.5418, TE(X->Y) = 0.0233 \n",
      "H(Y|Y-) = 24.0897, H(Y|X-,Y-) = 23.937, TE(X->Y) = 0.1527  \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5245, H(Y|X-,Y-) = 2.5103, TE(X->Y) = 0.0142  \n",
      "H(Y|Y-) = 2.0222, H(Y|X-,Y-) = 1.8936, TE(X->Y) = 0.1286  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.33, H(Y|X-,Y-) = 2.3279, TE(X->Y) = 0.0021  \n",
      "H(Y|Y-) = 1.8824, H(Y|X-,Y-) = 1.7582, TE(X->Y) = 0.1242  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.1053, H(Y|X-,Y-) = 5.0687, TE(X->Y) = 0.0366  \n",
      "H(Y|Y-) = 4.6138, H(Y|X-,Y-) = 4.4743, TE(X->Y) = 0.1395  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8315, H(Y|X-,Y-) = 4.8301, TE(X->Y) = 0.0014  \n",
      "H(Y|Y-) = 4.3162, H(Y|X-,Y-) = 4.1968, TE(X->Y) = 0.1194  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.5412, H(Y|X-,Y-) = 7.4963, TE(X->Y) = 0.0449  \n",
      "H(Y|Y-) = 7.2272, H(Y|X-,Y-) = 7.0667, TE(X->Y) = 0.1605  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.3487, H(Y|X-,Y-) = 7.347, TE(X->Y) = 0.0017   \n",
      "H(Y|Y-) = 6.8089, H(Y|X-,Y-) = 6.6863, TE(X->Y) = 0.1226  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2046, H(Y|X-,Y-) = 10.129, TE(X->Y) = 0.0756  \n",
      "H(Y|Y-) = 9.6233, H(Y|X-,Y-) = 9.4495, TE(X->Y) = 0.1738  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.6942, H(Y|X-,Y-) = 9.6932, TE(X->Y) = 0.001   \n",
      "H(Y|Y-) = 9.3175, H(Y|X-,Y-) = 9.1937, TE(X->Y) = 0.1238  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.8539, H(Y|X-,Y-) = 12.7586, TE(X->Y) = 0.0953 \n",
      "H(Y|Y-) = 12.1958, H(Y|X-,Y-) = 11.981, TE(X->Y) = 0.2148  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.1175, H(Y|X-,Y-) = 12.1119, TE(X->Y) = 0.0056 \n",
      "H(Y|Y-) = 11.8389, H(Y|X-,Y-) = 11.7155, TE(X->Y) = 0.1234 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.1596, H(Y|X-,Y-) = 15.0252, TE(X->Y) = 0.1344 \n",
      "H(Y|Y-) = 14.684, H(Y|X-,Y-) = 14.4329, TE(X->Y) = 0.2511 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.6984, H(Y|X-,Y-) = 14.6834, TE(X->Y) = 0.015  \n",
      "H(Y|Y-) = 14.2654, H(Y|X-,Y-) = 14.1472, TE(X->Y) = 0.1182 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.749, H(Y|X-,Y-) = 17.5723, TE(X->Y) = 0.1767 \n",
      "H(Y|Y-) = 17.2459, H(Y|X-,Y-) = 16.9591, TE(X->Y) = 0.2868 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.1158, H(Y|X-,Y-) = 17.1021, TE(X->Y) = 0.0137 \n",
      "H(Y|Y-) = 16.769, H(Y|X-,Y-) = 16.6331, TE(X->Y) = 0.1359 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.1757, H(Y|X-,Y-) = 19.9322, TE(X->Y) = 0.2435 \n",
      "H(Y|Y-) = 19.7441, H(Y|X-,Y-) = 19.4048, TE(X->Y) = 0.3393 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.5965, H(Y|X-,Y-) = 19.5822, TE(X->Y) = 0.0143 \n",
      "H(Y|Y-) = 19.1147, H(Y|X-,Y-) = 18.9872, TE(X->Y) = 0.1275 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.5953, H(Y|X-,Y-) = 22.3201, TE(X->Y) = 0.2752 \n",
      "H(Y|Y-) = 22.4578, H(Y|X-,Y-) = 22.053, TE(X->Y) = 0.4048  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.1597, H(Y|X-,Y-) = 22.1321, TE(X->Y) = 0.0276 \n",
      "H(Y|Y-) = 21.7278, H(Y|X-,Y-) = 21.5782, TE(X->Y) = 0.1496 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.1057, H(Y|X-,Y-) = 24.7607, TE(X->Y) = 0.345  \n",
      "H(Y|Y-) = 24.695, H(Y|X-,Y-) = 24.2488, TE(X->Y) = 0.4462 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.3402, H(Y|X-,Y-) = 24.3107, TE(X->Y) = 0.0295 \n",
      "H(Y|Y-) = 24.181, H(Y|X-,Y-) = 24.0324, TE(X->Y) = 0.1486 \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.4471, H(Y|X-,Y-) = 2.4378, TE(X->Y) = 0.0093  \n",
      "H(Y|Y-) = 1.9683, H(Y|X-,Y-) = 1.8486, TE(X->Y) = 0.1197  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.3433, H(Y|X-,Y-) = 2.3403, TE(X->Y) = 0.003   \n",
      "H(Y|Y-) = 1.8471, H(Y|X-,Y-) = 1.7277, TE(X->Y) = 0.1194  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 4.92, H(Y|X-,Y-) = 4.8904, TE(X->Y) = 0.0296  \n",
      "H(Y|Y-) = 4.3967, H(Y|X-,Y-) = 4.2595, TE(X->Y) = 0.1372  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8696, H(Y|X-,Y-) = 4.8747, TE(X->Y) = -0.0051 \n",
      "H(Y|Y-) = 4.3575, H(Y|X-,Y-) = 4.2355, TE(X->Y) = 0.122   \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.4079, H(Y|X-,Y-) = 7.3649, TE(X->Y) = 0.043   \n",
      "H(Y|Y-) = 6.8542, H(Y|X-,Y-) = 6.6931, TE(X->Y) = 0.1611  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.3109, H(Y|X-,Y-) = 7.3055, TE(X->Y) = 0.0054  \n",
      "H(Y|Y-) = 6.873, H(Y|X-,Y-) = 6.7501, TE(X->Y) = 0.1229  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.0587, H(Y|X-,Y-) = 9.9959, TE(X->Y) = 0.0628  \n",
      "H(Y|Y-) = 9.4287, H(Y|X-,Y-) = 9.2429, TE(X->Y) = 0.1858  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.8069, H(Y|X-,Y-) = 9.8026, TE(X->Y) = 0.0043  \n",
      "H(Y|Y-) = 9.3859, H(Y|X-,Y-) = 9.2641, TE(X->Y) = 0.1218  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.6899, H(Y|X-,Y-) = 12.5817, TE(X->Y) = 0.1082 \n",
      "H(Y|Y-) = 11.794, H(Y|X-,Y-) = 11.5885, TE(X->Y) = 0.2055 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3016, H(Y|X-,Y-) = 12.2991, TE(X->Y) = 0.0025 \n",
      "H(Y|Y-) = 11.8051, H(Y|X-,Y-) = 11.6769, TE(X->Y) = 0.1282 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.0998, H(Y|X-,Y-) = 14.9753, TE(X->Y) = 0.1245 \n",
      "H(Y|Y-) = 14.3816, H(Y|X-,Y-) = 14.1428, TE(X->Y) = 0.2388 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.7305, H(Y|X-,Y-) = 14.7157, TE(X->Y) = 0.0148 \n",
      "H(Y|Y-) = 14.3609, H(Y|X-,Y-) = 14.2309, TE(X->Y) = 0.13   \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.6491, H(Y|X-,Y-) = 17.4745, TE(X->Y) = 0.1746 \n",
      "H(Y|Y-) = 16.8804, H(Y|X-,Y-) = 16.5788, TE(X->Y) = 0.3016 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.1145, H(Y|X-,Y-) = 17.0957, TE(X->Y) = 0.0188 \n",
      "H(Y|Y-) = 16.8808, H(Y|X-,Y-) = 16.7465, TE(X->Y) = 0.1343 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.1986, H(Y|X-,Y-) = 19.9909, TE(X->Y) = 0.2077 \n",
      "H(Y|Y-) = 19.3094, H(Y|X-,Y-) = 18.9784, TE(X->Y) = 0.331  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6495, H(Y|X-,Y-) = 19.634, TE(X->Y) = 0.0155  \n",
      "H(Y|Y-) = 19.3831, H(Y|X-,Y-) = 19.2466, TE(X->Y) = 0.1365 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.5962, H(Y|X-,Y-) = 22.3491, TE(X->Y) = 0.2471 \n",
      "H(Y|Y-) = 21.758, H(Y|X-,Y-) = 21.3818, TE(X->Y) = 0.3762 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.007, H(Y|X-,Y-) = 21.9864, TE(X->Y) = 0.0206 \n",
      "H(Y|Y-) = 21.7598, H(Y|X-,Y-) = 21.6192, TE(X->Y) = 0.1406 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.0894, H(Y|X-,Y-) = 24.744, TE(X->Y) = 0.3454  \n",
      "H(Y|Y-) = 24.2991, H(Y|X-,Y-) = 23.8412, TE(X->Y) = 0.4579 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.5305, H(Y|X-,Y-) = 24.5194, TE(X->Y) = 0.0111 \n",
      "H(Y|Y-) = 24.2227, H(Y|X-,Y-) = 24.0845, TE(X->Y) = 0.1382 \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.4639, H(Y|X-,Y-) = 2.4498, TE(X->Y) = 0.0141  \n",
      "H(Y|Y-) = 2.0188, H(Y|X-,Y-) = 1.8866, TE(X->Y) = 0.1322  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.3436, H(Y|X-,Y-) = 2.3441, TE(X->Y) = -0.0005 \n",
      "H(Y|Y-) = 1.9143, H(Y|X-,Y-) = 1.7926, TE(X->Y) = 0.1217  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0601, H(Y|X-,Y-) = 5.0382, TE(X->Y) = 0.0219  \n",
      "H(Y|Y-) = 4.4401, H(Y|X-,Y-) = 4.2932, TE(X->Y) = 0.1469  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8268, H(Y|X-,Y-) = 4.8223, TE(X->Y) = 0.0045  \n",
      "H(Y|Y-) = 4.3677, H(Y|X-,Y-) = 4.2397, TE(X->Y) = 0.128   \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.6149, H(Y|X-,Y-) = 7.5691, TE(X->Y) = 0.0458  \n",
      "H(Y|Y-) = 7.0266, H(Y|X-,Y-) = 6.857, TE(X->Y) = 0.1696   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.2631, H(Y|X-,Y-) = 7.2583, TE(X->Y) = 0.0048  \n",
      "H(Y|Y-) = 6.8434, H(Y|X-,Y-) = 6.7207, TE(X->Y) = 0.1227  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.1119, H(Y|X-,Y-) = 10.045, TE(X->Y) = 0.0669  \n",
      "H(Y|Y-) = 9.6038, H(Y|X-,Y-) = 9.416, TE(X->Y) = 0.1878   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.7762, H(Y|X-,Y-) = 9.766, TE(X->Y) = 0.0102   \n",
      "H(Y|Y-) = 9.2982, H(Y|X-,Y-) = 9.171, TE(X->Y) = 0.1272   \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.7483, H(Y|X-,Y-) = 12.6476, TE(X->Y) = 0.1007 \n",
      "H(Y|Y-) = 12.1335, H(Y|X-,Y-) = 11.9174, TE(X->Y) = 0.2161 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.1792, H(Y|X-,Y-) = 12.1725, TE(X->Y) = 0.0067 \n",
      "H(Y|Y-) = 11.7343, H(Y|X-,Y-) = 11.6057, TE(X->Y) = 0.1286 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.3434, H(Y|X-,Y-) = 15.2086, TE(X->Y) = 0.1348 \n",
      "H(Y|Y-) = 14.6463, H(Y|X-,Y-) = 14.3904, TE(X->Y) = 0.2559 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.6363, H(Y|X-,Y-) = 14.6287, TE(X->Y) = 0.0076 \n",
      "H(Y|Y-) = 14.217, H(Y|X-,Y-) = 14.087, TE(X->Y) = 0.13    \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.6725, H(Y|X-,Y-) = 17.4917, TE(X->Y) = 0.1808 \n",
      "H(Y|Y-) = 17.1796, H(Y|X-,Y-) = 16.8916, TE(X->Y) = 0.288  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.799, H(Y|X-,Y-) = 16.795, TE(X->Y) = 0.004   \n",
      "H(Y|Y-) = 16.7069, H(Y|X-,Y-) = 16.5787, TE(X->Y) = 0.1282 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.0669, H(Y|X-,Y-) = 19.8388, TE(X->Y) = 0.2281 \n",
      "H(Y|Y-) = 19.7801, H(Y|X-,Y-) = 19.4415, TE(X->Y) = 0.3386 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.4528, H(Y|X-,Y-) = 19.4369, TE(X->Y) = 0.0159 \n",
      "H(Y|Y-) = 19.0519, H(Y|X-,Y-) = 18.9137, TE(X->Y) = 0.1382 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.491, H(Y|X-,Y-) = 22.2186, TE(X->Y) = 0.2724 \n",
      "H(Y|Y-) = 22.3272, H(Y|X-,Y-) = 21.9436, TE(X->Y) = 0.3836 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 21.866, H(Y|X-,Y-) = 21.8429, TE(X->Y) = 0.0231 \n",
      "H(Y|Y-) = 21.5653, H(Y|X-,Y-) = 21.4219, TE(X->Y) = 0.1434 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.8918, H(Y|X-,Y-) = 24.5778, TE(X->Y) = 0.314  \n",
      "H(Y|Y-) = 24.7788, H(Y|X-,Y-) = 24.3326, TE(X->Y) = 0.4462 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.2463, H(Y|X-,Y-) = 24.2191, TE(X->Y) = 0.0272 \n",
      "H(Y|Y-) = 23.8007, H(Y|X-,Y-) = 23.6562, TE(X->Y) = 0.1445 \n"
     ]
    }
   ],
   "source": [
    "lg_results_TE_X2Y = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "lg_results_TE_Y2X = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for dim, generator in zip(dim_range, lg_generator_lst):\n",
    "        print(\"## Dim = \", dim, \"#\")\n",
    "        for samples in sample_sizes:\n",
    "            print(\"# Sample size = \", samples, \"#\")\n",
    "            # Simulate data\n",
    "            X, Y = generator.simulate(time=samples, seed=r)\n",
    "            # Estimate X -> Y\n",
    "            TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            lg_results_TE_X2Y.write(method='njee', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            lg_results_TE_Y2X.write(method='njee', n_dim=dim, sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "lg_results_TE_X2Y.df.to_csv('results/njee/lg_results_TE_X2Y_dimred.csv', index=False)\n",
    "lg_results_TE_Y2X.df.to_csv('results/njee/lg_results_TE_Y2X_dimred.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Joint Process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the list of generators with one for each dimension\n",
    "jp_generator_lst = [MVJointProcessSimulator(n_dim=dim, n_redundant_dim=dim-1, lam = 0.0) for dim in dim_range]\n",
    "# Get the reference values\n",
    "jp_TE_X2Y_ref_lst = [generator.analytic_transfer_entropy('X', 'Y') for generator in jp_generator_lst]\n",
    "jp_TE_Y2X_ref_lst = [generator.analytic_transfer_entropy('Y', 'X') for generator in jp_generator_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5395, H(Y|X-,Y-) = 1.7288, TE(X->Y) = 0.8107  \n",
      "H(Y|Y-) = 2.5377, H(Y|X-,Y-) = 2.5237, TE(X->Y) = 0.014   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4457, H(Y|X-,Y-) = 1.6411, TE(X->Y) = 0.8046  \n",
      "H(Y|Y-) = 2.447, H(Y|X-,Y-) = 2.4468, TE(X->Y) = 0.0002  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0888, H(Y|X-,Y-) = 4.2757, TE(X->Y) = 0.8131  \n",
      "H(Y|Y-) = 4.995, H(Y|X-,Y-) = 4.9758, TE(X->Y) = 0.0192  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9215, H(Y|X-,Y-) = 4.1166, TE(X->Y) = 0.8049  \n",
      "H(Y|Y-) = 4.9913, H(Y|X-,Y-) = 4.9904, TE(X->Y) = 0.0009  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.5947, H(Y|X-,Y-) = 6.7529, TE(X->Y) = 0.8418  \n",
      "H(Y|Y-) = 7.5849, H(Y|X-,Y-) = 7.5462, TE(X->Y) = 0.0387  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.2791, H(Y|X-,Y-) = 6.4735, TE(X->Y) = 0.8056  \n",
      "H(Y|Y-) = 7.4352, H(Y|X-,Y-) = 7.434, TE(X->Y) = 0.0012   \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.0116, H(Y|X-,Y-) = 9.1486, TE(X->Y) = 0.863   \n",
      "H(Y|Y-) = 10.2014, H(Y|X-,Y-) = 10.1467, TE(X->Y) = 0.0547 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.7097, H(Y|X-,Y-) = 8.9001, TE(X->Y) = 0.8096  \n",
      "H(Y|Y-) = 9.8517, H(Y|X-,Y-) = 9.8465, TE(X->Y) = 0.0052  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.6545, H(Y|X-,Y-) = 11.7713, TE(X->Y) = 0.8832 \n",
      "H(Y|Y-) = 12.6985, H(Y|X-,Y-) = 12.5988, TE(X->Y) = 0.0997 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.2783, H(Y|X-,Y-) = 11.4657, TE(X->Y) = 0.8126 \n",
      "H(Y|Y-) = 12.2634, H(Y|X-,Y-) = 12.2533, TE(X->Y) = 0.0101 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.2444, H(Y|X-,Y-) = 14.3269, TE(X->Y) = 0.9175 \n",
      "H(Y|Y-) = 15.087, H(Y|X-,Y-) = 14.9628, TE(X->Y) = 0.1242 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.7129, H(Y|X-,Y-) = 13.9022, TE(X->Y) = 0.8107 \n",
      "H(Y|Y-) = 14.6722, H(Y|X-,Y-) = 14.6653, TE(X->Y) = 0.0069 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.8177, H(Y|X-,Y-) = 16.857, TE(X->Y) = 0.9607  \n",
      "H(Y|Y-) = 17.5738, H(Y|X-,Y-) = 17.4022, TE(X->Y) = 0.1716 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.1895, H(Y|X-,Y-) = 16.3778, TE(X->Y) = 0.8117 \n",
      "H(Y|Y-) = 17.1288, H(Y|X-,Y-) = 17.1223, TE(X->Y) = 0.0065 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.2821, H(Y|X-,Y-) = 19.2655, TE(X->Y) = 1.0166 \n",
      "H(Y|Y-) = 20.0742, H(Y|X-,Y-) = 19.8448, TE(X->Y) = 0.2294 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.7755, H(Y|X-,Y-) = 18.9585, TE(X->Y) = 0.817  \n",
      "H(Y|Y-) = 19.5956, H(Y|X-,Y-) = 19.5778, TE(X->Y) = 0.0178 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.7045, H(Y|X-,Y-) = 21.6456, TE(X->Y) = 1.0589 \n",
      "H(Y|Y-) = 22.6895, H(Y|X-,Y-) = 22.4274, TE(X->Y) = 0.2621 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.2267, H(Y|X-,Y-) = 21.4117, TE(X->Y) = 0.815  \n",
      "H(Y|Y-) = 22.1361, H(Y|X-,Y-) = 22.1115, TE(X->Y) = 0.0246 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.0894, H(Y|X-,Y-) = 23.9756, TE(X->Y) = 1.1138 \n",
      "H(Y|Y-) = 25.107, H(Y|X-,Y-) = 24.7965, TE(X->Y) = 0.3105 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.7147, H(Y|X-,Y-) = 23.89, TE(X->Y) = 0.8247   \n",
      "H(Y|Y-) = 24.5682, H(Y|X-,Y-) = 24.5512, TE(X->Y) = 0.017  \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.6207, H(Y|X-,Y-) = 1.8075, TE(X->Y) = 0.8132  \n",
      "H(Y|Y-) = 2.6001, H(Y|X-,Y-) = 2.5866, TE(X->Y) = 0.0135  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4505, H(Y|X-,Y-) = 1.6509, TE(X->Y) = 0.7996  \n",
      "H(Y|Y-) = 2.4935, H(Y|X-,Y-) = 2.4941, TE(X->Y) = -0.0006 \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.2294, H(Y|X-,Y-) = 4.3997, TE(X->Y) = 0.8297  \n",
      "H(Y|Y-) = 5.1252, H(Y|X-,Y-) = 5.101, TE(X->Y) = 0.0242   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9586, H(Y|X-,Y-) = 4.1557, TE(X->Y) = 0.8029  \n",
      "H(Y|Y-) = 4.9695, H(Y|X-,Y-) = 4.9709, TE(X->Y) = -0.0014 \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.7515, H(Y|X-,Y-) = 6.9118, TE(X->Y) = 0.8397  \n",
      "H(Y|Y-) = 7.756, H(Y|X-,Y-) = 7.719, TE(X->Y) = 0.037    \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.4017, H(Y|X-,Y-) = 6.597, TE(X->Y) = 0.8047   \n",
      "H(Y|Y-) = 7.4624, H(Y|X-,Y-) = 7.4587, TE(X->Y) = 0.0037  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2957, H(Y|X-,Y-) = 9.4276, TE(X->Y) = 0.8681  \n",
      "H(Y|Y-) = 10.22, H(Y|X-,Y-) = 10.1457, TE(X->Y) = 0.0743 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.8228, H(Y|X-,Y-) = 9.0197, TE(X->Y) = 0.8031  \n",
      "H(Y|Y-) = 9.9179, H(Y|X-,Y-) = 9.9087, TE(X->Y) = 0.0092  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.7385, H(Y|X-,Y-) = 11.8328, TE(X->Y) = 0.9057 \n",
      "H(Y|Y-) = 12.8027, H(Y|X-,Y-) = 12.7246, TE(X->Y) = 0.0781 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3676, H(Y|X-,Y-) = 11.5607, TE(X->Y) = 0.8069 \n",
      "H(Y|Y-) = 12.3398, H(Y|X-,Y-) = 12.3385, TE(X->Y) = 0.0013 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.2547, H(Y|X-,Y-) = 14.3158, TE(X->Y) = 0.9389 \n",
      "H(Y|Y-) = 15.2929, H(Y|X-,Y-) = 15.1691, TE(X->Y) = 0.1238 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.9486, H(Y|X-,Y-) = 14.137, TE(X->Y) = 0.8116  \n",
      "H(Y|Y-) = 14.8477, H(Y|X-,Y-) = 14.8347, TE(X->Y) = 0.013  \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.7643, H(Y|X-,Y-) = 16.7836, TE(X->Y) = 0.9807 \n",
      "H(Y|Y-) = 17.808, H(Y|X-,Y-) = 17.6228, TE(X->Y) = 0.1852 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.4715, H(Y|X-,Y-) = 16.6598, TE(X->Y) = 0.8117 \n",
      "H(Y|Y-) = 17.3424, H(Y|X-,Y-) = 17.3371, TE(X->Y) = 0.0053 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.3617, H(Y|X-,Y-) = 19.3354, TE(X->Y) = 1.0263 \n",
      "H(Y|Y-) = 20.3024, H(Y|X-,Y-) = 20.0927, TE(X->Y) = 0.2097 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.7429, H(Y|X-,Y-) = 18.9326, TE(X->Y) = 0.8103 \n",
      "H(Y|Y-) = 19.7255, H(Y|X-,Y-) = 19.714, TE(X->Y) = 0.0115  \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.7654, H(Y|X-,Y-) = 21.7125, TE(X->Y) = 1.0529 \n",
      "H(Y|Y-) = 22.7196, H(Y|X-,Y-) = 22.4307, TE(X->Y) = 0.2889 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.1201, H(Y|X-,Y-) = 21.3071, TE(X->Y) = 0.813  \n",
      "H(Y|Y-) = 22.3358, H(Y|X-,Y-) = 22.3083, TE(X->Y) = 0.0275 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.2988, H(Y|X-,Y-) = 24.1622, TE(X->Y) = 1.1366 \n",
      "H(Y|Y-) = 25.2933, H(Y|X-,Y-) = 24.9619, TE(X->Y) = 0.3314 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.5772, H(Y|X-,Y-) = 23.7569, TE(X->Y) = 0.8203 \n",
      "H(Y|Y-) = 24.766, H(Y|X-,Y-) = 24.7297, TE(X->Y) = 0.0363 \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.6454, H(Y|X-,Y-) = 1.8294, TE(X->Y) = 0.816   \n",
      "H(Y|Y-) = 2.577, H(Y|X-,Y-) = 2.56, TE(X->Y) = 0.017     \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.3844, H(Y|X-,Y-) = 1.5901, TE(X->Y) = 0.7943  \n",
      "H(Y|Y-) = 2.4275, H(Y|X-,Y-) = 2.4269, TE(X->Y) = 0.0006  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.2185, H(Y|X-,Y-) = 4.39, TE(X->Y) = 0.8285    \n",
      "H(Y|Y-) = 5.1665, H(Y|X-,Y-) = 5.1421, TE(X->Y) = 0.0244  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8868, H(Y|X-,Y-) = 4.0963, TE(X->Y) = 0.7905  \n",
      "H(Y|Y-) = 4.8611, H(Y|X-,Y-) = 4.8585, TE(X->Y) = 0.0026  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.6656, H(Y|X-,Y-) = 6.818, TE(X->Y) = 0.8476   \n",
      "H(Y|Y-) = 7.7817, H(Y|X-,Y-) = 7.7264, TE(X->Y) = 0.0553  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.3996, H(Y|X-,Y-) = 6.6094, TE(X->Y) = 0.7902  \n",
      "H(Y|Y-) = 7.35, H(Y|X-,Y-) = 7.3479, TE(X->Y) = 0.0021  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.3142, H(Y|X-,Y-) = 9.4544, TE(X->Y) = 0.8598  \n",
      "H(Y|Y-) = 10.1645, H(Y|X-,Y-) = 10.1016, TE(X->Y) = 0.0629 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.7509, H(Y|X-,Y-) = 8.9541, TE(X->Y) = 0.7968  \n",
      "H(Y|Y-) = 9.8645, H(Y|X-,Y-) = 9.8502, TE(X->Y) = 0.0143  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.9746, H(Y|X-,Y-) = 12.0915, TE(X->Y) = 0.8831 \n",
      "H(Y|Y-) = 12.7303, H(Y|X-,Y-) = 12.6356, TE(X->Y) = 0.0947 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.1712, H(Y|X-,Y-) = 11.3803, TE(X->Y) = 0.7909 \n",
      "H(Y|Y-) = 12.382, H(Y|X-,Y-) = 12.3726, TE(X->Y) = 0.0094 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.276, H(Y|X-,Y-) = 14.3463, TE(X->Y) = 0.9297 \n",
      "H(Y|Y-) = 15.2194, H(Y|X-,Y-) = 15.0987, TE(X->Y) = 0.1207 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.747, H(Y|X-,Y-) = 13.9436, TE(X->Y) = 0.8034 \n",
      "H(Y|Y-) = 14.8107, H(Y|X-,Y-) = 14.8084, TE(X->Y) = 0.0023 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.8442, H(Y|X-,Y-) = 16.8868, TE(X->Y) = 0.9574 \n",
      "H(Y|Y-) = 17.7877, H(Y|X-,Y-) = 17.6056, TE(X->Y) = 0.1821 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.1676, H(Y|X-,Y-) = 16.3673, TE(X->Y) = 0.8003 \n",
      "H(Y|Y-) = 17.3123, H(Y|X-,Y-) = 17.3002, TE(X->Y) = 0.0121 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.2794, H(Y|X-,Y-) = 19.2517, TE(X->Y) = 1.0277 \n",
      "H(Y|Y-) = 20.278, H(Y|X-,Y-) = 20.0543, TE(X->Y) = 0.2237 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6445, H(Y|X-,Y-) = 18.8388, TE(X->Y) = 0.8057 \n",
      "H(Y|Y-) = 19.6578, H(Y|X-,Y-) = 19.653, TE(X->Y) = 0.0048  \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.7095, H(Y|X-,Y-) = 21.6252, TE(X->Y) = 1.0843 \n",
      "H(Y|Y-) = 22.9838, H(Y|X-,Y-) = 22.7013, TE(X->Y) = 0.2825 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.2035, H(Y|X-,Y-) = 21.4027, TE(X->Y) = 0.8008 \n",
      "H(Y|Y-) = 22.2653, H(Y|X-,Y-) = 22.2495, TE(X->Y) = 0.0158 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.2191, H(Y|X-,Y-) = 24.0841, TE(X->Y) = 1.135  \n",
      "H(Y|Y-) = 25.2267, H(Y|X-,Y-) = 24.891, TE(X->Y) = 0.3357  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.3965, H(Y|X-,Y-) = 23.5811, TE(X->Y) = 0.8154 \n",
      "H(Y|Y-) = 24.721, H(Y|X-,Y-) = 24.7007, TE(X->Y) = 0.0203 \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5803, H(Y|X-,Y-) = 1.7754, TE(X->Y) = 0.8049  \n",
      "H(Y|Y-) = 2.5162, H(Y|X-,Y-) = 2.505, TE(X->Y) = 0.0112   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4724, H(Y|X-,Y-) = 1.6658, TE(X->Y) = 0.8066  \n",
      "H(Y|Y-) = 2.4714, H(Y|X-,Y-) = 2.4736, TE(X->Y) = -0.0022 \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0439, H(Y|X-,Y-) = 4.2339, TE(X->Y) = 0.81    \n",
      "H(Y|Y-) = 4.9385, H(Y|X-,Y-) = 4.9127, TE(X->Y) = 0.0258  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 5.0043, H(Y|X-,Y-) = 4.1949, TE(X->Y) = 0.8094  \n",
      "H(Y|Y-) = 4.9857, H(Y|X-,Y-) = 4.9843, TE(X->Y) = 0.0014  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.5427, H(Y|X-,Y-) = 6.7047, TE(X->Y) = 0.838   \n",
      "H(Y|Y-) = 7.3949, H(Y|X-,Y-) = 7.3521, TE(X->Y) = 0.0428  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.4394, H(Y|X-,Y-) = 6.6341, TE(X->Y) = 0.8053  \n",
      "H(Y|Y-) = 7.4999, H(Y|X-,Y-) = 7.4965, TE(X->Y) = 0.0034  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.1898, H(Y|X-,Y-) = 9.342, TE(X->Y) = 0.8478   \n",
      "H(Y|Y-) = 9.9673, H(Y|X-,Y-) = 9.8997, TE(X->Y) = 0.0676  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.9396, H(Y|X-,Y-) = 9.1305, TE(X->Y) = 0.8091  \n",
      "H(Y|Y-) = 10.0106, H(Y|X-,Y-) = 10.0135, TE(X->Y) = -0.0029\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.8166, H(Y|X-,Y-) = 11.9375, TE(X->Y) = 0.8791 \n",
      "H(Y|Y-) = 12.3453, H(Y|X-,Y-) = 12.2396, TE(X->Y) = 0.1057 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.4349, H(Y|X-,Y-) = 11.6275, TE(X->Y) = 0.8074 \n",
      "H(Y|Y-) = 12.4313, H(Y|X-,Y-) = 12.426, TE(X->Y) = 0.0053  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.2269, H(Y|X-,Y-) = 14.3095, TE(X->Y) = 0.9174 \n",
      "H(Y|Y-) = 14.92, H(Y|X-,Y-) = 14.7959, TE(X->Y) = 0.1241 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.8548, H(Y|X-,Y-) = 14.0474, TE(X->Y) = 0.8074 \n",
      "H(Y|Y-) = 14.9863, H(Y|X-,Y-) = 14.9742, TE(X->Y) = 0.0121 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.777, H(Y|X-,Y-) = 16.8143, TE(X->Y) = 0.9627 \n",
      "H(Y|Y-) = 17.4038, H(Y|X-,Y-) = 17.2269, TE(X->Y) = 0.1769 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.249, H(Y|X-,Y-) = 16.4171, TE(X->Y) = 0.8319 \n",
      "H(Y|Y-) = 17.5024, H(Y|X-,Y-) = 17.4928, TE(X->Y) = 0.0096 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.3371, H(Y|X-,Y-) = 19.32, TE(X->Y) = 1.0171   \n",
      "H(Y|Y-) = 19.8547, H(Y|X-,Y-) = 19.645, TE(X->Y) = 0.2097  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.7799, H(Y|X-,Y-) = 18.9663, TE(X->Y) = 0.8136 \n",
      "H(Y|Y-) = 20.012, H(Y|X-,Y-) = 19.9909, TE(X->Y) = 0.0211 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.7255, H(Y|X-,Y-) = 21.6831, TE(X->Y) = 1.0424 \n",
      "H(Y|Y-) = 22.3047, H(Y|X-,Y-) = 22.0263, TE(X->Y) = 0.2784 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.1447, H(Y|X-,Y-) = 21.3128, TE(X->Y) = 0.8319 \n",
      "H(Y|Y-) = 22.3914, H(Y|X-,Y-) = 22.3639, TE(X->Y) = 0.0275 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.2258, H(Y|X-,Y-) = 24.1236, TE(X->Y) = 1.1022 \n",
      "H(Y|Y-) = 24.8348, H(Y|X-,Y-) = 24.5252, TE(X->Y) = 0.3096 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.6779, H(Y|X-,Y-) = 23.834, TE(X->Y) = 0.8439  \n",
      "H(Y|Y-) = 24.8496, H(Y|X-,Y-) = 24.8239, TE(X->Y) = 0.0257 \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.551, H(Y|X-,Y-) = 1.7385, TE(X->Y) = 0.8125  \n",
      "H(Y|Y-) = 2.4969, H(Y|X-,Y-) = 2.4808, TE(X->Y) = 0.0161  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.493, H(Y|X-,Y-) = 1.6868, TE(X->Y) = 0.8062  \n",
      "H(Y|Y-) = 2.4271, H(Y|X-,Y-) = 2.431, TE(X->Y) = -0.0039  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.1474, H(Y|X-,Y-) = 4.3248, TE(X->Y) = 0.8226  \n",
      "H(Y|Y-) = 4.9125, H(Y|X-,Y-) = 4.89, TE(X->Y) = 0.0225    \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9734, H(Y|X-,Y-) = 4.1683, TE(X->Y) = 0.8051  \n",
      "H(Y|Y-) = 4.8803, H(Y|X-,Y-) = 4.8763, TE(X->Y) = 0.004   \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.7012, H(Y|X-,Y-) = 6.8652, TE(X->Y) = 0.836   \n",
      "H(Y|Y-) = 7.4791, H(Y|X-,Y-) = 7.4458, TE(X->Y) = 0.0333  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.4099, H(Y|X-,Y-) = 6.5974, TE(X->Y) = 0.8125  \n",
      "H(Y|Y-) = 7.3553, H(Y|X-,Y-) = 7.3551, TE(X->Y) = 0.0002  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.1945, H(Y|X-,Y-) = 9.3337, TE(X->Y) = 0.8608  \n",
      "H(Y|Y-) = 10.0757, H(Y|X-,Y-) = 10.0046, TE(X->Y) = 0.0711 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.9204, H(Y|X-,Y-) = 9.116, TE(X->Y) = 0.8044   \n",
      "H(Y|Y-) = 9.8136, H(Y|X-,Y-) = 9.8093, TE(X->Y) = 0.0043  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.8201, H(Y|X-,Y-) = 11.9373, TE(X->Y) = 0.8828 \n",
      "H(Y|Y-) = 12.6031, H(Y|X-,Y-) = 12.5105, TE(X->Y) = 0.0926 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3326, H(Y|X-,Y-) = 11.5193, TE(X->Y) = 0.8133 \n",
      "H(Y|Y-) = 12.2553, H(Y|X-,Y-) = 12.247, TE(X->Y) = 0.0083  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.4331, H(Y|X-,Y-) = 14.5037, TE(X->Y) = 0.9294 \n",
      "H(Y|Y-) = 15.1066, H(Y|X-,Y-) = 14.9828, TE(X->Y) = 0.1238 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.783, H(Y|X-,Y-) = 13.9711, TE(X->Y) = 0.8119 \n",
      "H(Y|Y-) = 14.7331, H(Y|X-,Y-) = 14.7189, TE(X->Y) = 0.0142 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.7497, H(Y|X-,Y-) = 16.7783, TE(X->Y) = 0.9714 \n",
      "H(Y|Y-) = 17.645, H(Y|X-,Y-) = 17.4732, TE(X->Y) = 0.1718 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.9498, H(Y|X-,Y-) = 16.1391, TE(X->Y) = 0.8107 \n",
      "H(Y|Y-) = 17.2259, H(Y|X-,Y-) = 17.2158, TE(X->Y) = 0.0101 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.1551, H(Y|X-,Y-) = 19.1319, TE(X->Y) = 1.0232 \n",
      "H(Y|Y-) = 20.2399, H(Y|X-,Y-) = 20.0096, TE(X->Y) = 0.2303 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6052, H(Y|X-,Y-) = 18.7884, TE(X->Y) = 0.8168 \n",
      "H(Y|Y-) = 19.5646, H(Y|X-,Y-) = 19.5425, TE(X->Y) = 0.0221 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.574, H(Y|X-,Y-) = 21.5231, TE(X->Y) = 1.0509 \n",
      "H(Y|Y-) = 22.7954, H(Y|X-,Y-) = 22.513, TE(X->Y) = 0.2824  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.0161, H(Y|X-,Y-) = 21.1892, TE(X->Y) = 0.8269 \n",
      "H(Y|Y-) = 22.0799, H(Y|X-,Y-) = 22.0553, TE(X->Y) = 0.0246 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.9865, H(Y|X-,Y-) = 23.862, TE(X->Y) = 1.1245  \n",
      "H(Y|Y-) = 25.236, H(Y|X-,Y-) = 24.9222, TE(X->Y) = 0.3138 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.3878, H(Y|X-,Y-) = 23.568, TE(X->Y) = 0.8198  \n",
      "H(Y|Y-) = 24.312, H(Y|X-,Y-) = 24.2847, TE(X->Y) = 0.0273 \n"
     ]
    }
   ],
   "source": [
    "jp_results_TE_X2Y = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "jp_results_TE_Y2X = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for dim, generator in zip(dim_range, jp_generator_lst):\n",
    "        print(\"## Dim = \", dim, \"#\")\n",
    "        for samples in sample_sizes:\n",
    "            print(\"# Sample size = \", samples, \"#\")\n",
    "            # Simulate data\n",
    "            X, Y = generator.simulate(time=samples, seed=r)\n",
    "            # Estimate X -> Y\n",
    "            TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            jp_results_TE_X2Y.write(method='njee', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            jp_results_TE_Y2X.write(method='njee', n_dim=dim, sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "jp_results_TE_X2Y.df.to_csv('results/njee/jp_results_TE_X2Y_dimred.csv', index=False)\n",
    "jp_results_TE_Y2X.df.to_csv('results/njee/jp_results_TE_Y2X_dimred.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Dimensionality Scaling without redundant dimensions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "dim_range = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]\n",
    "sample_sizes = [10000, 100000]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Linear Gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the list of generators with one for each dimension\n",
    "lg_generator_lst = [MVLinearGaussianSimulator(n_dim=dim) for dim in dim_range]\n",
    "# Get the reference values\n",
    "lg_TE_X2Y_ref_lst = [generator.analytic_transfer_entropy('X', 'Y') for generator in lg_generator_lst]\n",
    "lg_TE_Y2X_ref_lst = [generator.analytic_transfer_entropy('Y', 'X') for generator in lg_generator_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5175, H(Y|X-,Y-) = 2.5037, TE(X->Y) = 0.0138  \n",
      "H(Y|Y-) = 2.0275, H(Y|X-,Y-) = 1.8985, TE(X->Y) = 0.129   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4663, H(Y|X-,Y-) = 2.4655, TE(X->Y) = 0.0008  \n",
      "H(Y|Y-) = 1.8077, H(Y|X-,Y-) = 1.6889, TE(X->Y) = 0.1188  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0046, H(Y|X-,Y-) = 4.9689, TE(X->Y) = 0.0357  \n",
      "H(Y|Y-) = 3.9193, H(Y|X-,Y-) = 3.6659, TE(X->Y) = 0.2534  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9045, H(Y|X-,Y-) = 4.8989, TE(X->Y) = 0.0056  \n",
      "H(Y|Y-) = 3.6261, H(Y|X-,Y-) = 3.3874, TE(X->Y) = 0.2387  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.4832, H(Y|X-,Y-) = 7.4299, TE(X->Y) = 0.0533  \n",
      "H(Y|Y-) = 5.9056, H(Y|X-,Y-) = 5.5118, TE(X->Y) = 0.3938  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.2293, H(Y|X-,Y-) = 7.2254, TE(X->Y) = 0.0039  \n",
      "H(Y|Y-) = 5.5031, H(Y|X-,Y-) = 5.1409, TE(X->Y) = 0.3622  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 9.8734, H(Y|X-,Y-) = 9.7985, TE(X->Y) = 0.0749  \n",
      "H(Y|Y-) = 7.8234, H(Y|X-,Y-) = 7.2949, TE(X->Y) = 0.5285  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.5675, H(Y|X-,Y-) = 9.5641, TE(X->Y) = 0.0034  \n",
      "H(Y|Y-) = 7.3542, H(Y|X-,Y-) = 6.8672, TE(X->Y) = 0.487   \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.2699, H(Y|X-,Y-) = 12.1782, TE(X->Y) = 0.0917 \n",
      "H(Y|Y-) = 9.7815, H(Y|X-,Y-) = 9.0942, TE(X->Y) = 0.6873  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 11.9118, H(Y|X-,Y-) = 11.898, TE(X->Y) = 0.0138  \n",
      "H(Y|Y-) = 9.2641, H(Y|X-,Y-) = 8.6562, TE(X->Y) = 0.6079  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 14.7313, H(Y|X-,Y-) = 14.602, TE(X->Y) = 0.1293  \n",
      "H(Y|Y-) = 11.7785, H(Y|X-,Y-) = 10.9395, TE(X->Y) = 0.839  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.2895, H(Y|X-,Y-) = 14.2699, TE(X->Y) = 0.0196 \n",
      "H(Y|Y-) = 11.172, H(Y|X-,Y-) = 10.4366, TE(X->Y) = 0.7354 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.1738, H(Y|X-,Y-) = 16.9972, TE(X->Y) = 0.1766 \n",
      "H(Y|Y-) = 13.7242, H(Y|X-,Y-) = 12.7465, TE(X->Y) = 0.9777 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.6353, H(Y|X-,Y-) = 16.6202, TE(X->Y) = 0.0151 \n",
      "H(Y|Y-) = 13.1121, H(Y|X-,Y-) = 12.2528, TE(X->Y) = 0.8593 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 19.6304, H(Y|X-,Y-) = 19.4077, TE(X->Y) = 0.2227 \n",
      "H(Y|Y-) = 15.7093, H(Y|X-,Y-) = 14.5456, TE(X->Y) = 1.1637 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.0364, H(Y|X-,Y-) = 19.0141, TE(X->Y) = 0.0223 \n",
      "H(Y|Y-) = 15.0237, H(Y|X-,Y-) = 14.047, TE(X->Y) = 0.9767  \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.0872, H(Y|X-,Y-) = 21.8285, TE(X->Y) = 0.2587 \n",
      "H(Y|Y-) = 17.6289, H(Y|X-,Y-) = 16.2969, TE(X->Y) = 1.332  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 21.367, H(Y|X-,Y-) = 21.3554, TE(X->Y) = 0.0116 \n",
      "H(Y|Y-) = 16.9356, H(Y|X-,Y-) = 15.8394, TE(X->Y) = 1.0962 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.4412, H(Y|X-,Y-) = 24.1349, TE(X->Y) = 0.3063 \n",
      "H(Y|Y-) = 19.4254, H(Y|X-,Y-) = 17.9179, TE(X->Y) = 1.5075 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 23.7101, H(Y|X-,Y-) = 23.6919, TE(X->Y) = 0.0182 \n",
      "H(Y|Y-) = 18.719, H(Y|X-,Y-) = 17.493, TE(X->Y) = 1.226   \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5129, H(Y|X-,Y-) = 2.5062, TE(X->Y) = 0.0067  \n",
      "H(Y|Y-) = 1.9148, H(Y|X-,Y-) = 1.7937, TE(X->Y) = 0.1211  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4323, H(Y|X-,Y-) = 2.4348, TE(X->Y) = -0.0025 \n",
      "H(Y|Y-) = 1.8196, H(Y|X-,Y-) = 1.6972, TE(X->Y) = 0.1224  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0174, H(Y|X-,Y-) = 4.9783, TE(X->Y) = 0.0391  \n",
      "H(Y|Y-) = 3.9126, H(Y|X-,Y-) = 3.6602, TE(X->Y) = 0.2524  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.7617, H(Y|X-,Y-) = 4.7609, TE(X->Y) = 0.0008  \n",
      "H(Y|Y-) = 3.7035, H(Y|X-,Y-) = 3.4547, TE(X->Y) = 0.2488  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.4087, H(Y|X-,Y-) = 7.3718, TE(X->Y) = 0.0369  \n",
      "H(Y|Y-) = 5.8457, H(Y|X-,Y-) = 5.459, TE(X->Y) = 0.3867   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.1067, H(Y|X-,Y-) = 7.1, TE(X->Y) = 0.0067     \n",
      "H(Y|Y-) = 5.5446, H(Y|X-,Y-) = 5.1847, TE(X->Y) = 0.3599  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 9.822, H(Y|X-,Y-) = 9.75, TE(X->Y) = 0.072     \n",
      "H(Y|Y-) = 7.8128, H(Y|X-,Y-) = 7.2734, TE(X->Y) = 0.5394  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.4449, H(Y|X-,Y-) = 9.4406, TE(X->Y) = 0.0043  \n",
      "H(Y|Y-) = 7.456, H(Y|X-,Y-) = 6.9727, TE(X->Y) = 0.4833  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.2898, H(Y|X-,Y-) = 12.1994, TE(X->Y) = 0.0904 \n",
      "H(Y|Y-) = 9.829, H(Y|X-,Y-) = 9.1414, TE(X->Y) = 0.6876  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 11.8208, H(Y|X-,Y-) = 11.8153, TE(X->Y) = 0.0055 \n",
      "H(Y|Y-) = 9.3635, H(Y|X-,Y-) = 8.7488, TE(X->Y) = 0.6147  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 14.7378, H(Y|X-,Y-) = 14.6117, TE(X->Y) = 0.1261 \n",
      "H(Y|Y-) = 11.782, H(Y|X-,Y-) = 10.9413, TE(X->Y) = 0.8407 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.1757, H(Y|X-,Y-) = 14.164, TE(X->Y) = 0.0117  \n",
      "H(Y|Y-) = 11.3114, H(Y|X-,Y-) = 10.5648, TE(X->Y) = 0.7466 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.2072, H(Y|X-,Y-) = 17.0384, TE(X->Y) = 0.1688 \n",
      "H(Y|Y-) = 13.7652, H(Y|X-,Y-) = 12.7704, TE(X->Y) = 0.9948 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.5711, H(Y|X-,Y-) = 16.5619, TE(X->Y) = 0.0092 \n",
      "H(Y|Y-) = 13.2162, H(Y|X-,Y-) = 12.3595, TE(X->Y) = 0.8567 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 19.6817, H(Y|X-,Y-) = 19.4628, TE(X->Y) = 0.2189 \n",
      "H(Y|Y-) = 15.6978, H(Y|X-,Y-) = 14.5385, TE(X->Y) = 1.1593 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 18.9164, H(Y|X-,Y-) = 18.8992, TE(X->Y) = 0.0172 \n",
      "H(Y|Y-) = 15.1322, H(Y|X-,Y-) = 14.1483, TE(X->Y) = 0.9839 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.0441, H(Y|X-,Y-) = 21.7847, TE(X->Y) = 0.2594 \n",
      "H(Y|Y-) = 17.5008, H(Y|X-,Y-) = 16.1751, TE(X->Y) = 1.3257 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 21.26, H(Y|X-,Y-) = 21.2416, TE(X->Y) = 0.0184 \n",
      "H(Y|Y-) = 16.9225, H(Y|X-,Y-) = 15.8094, TE(X->Y) = 1.1131 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.4247, H(Y|X-,Y-) = 24.089, TE(X->Y) = 0.3357  \n",
      "H(Y|Y-) = 19.5027, H(Y|X-,Y-) = 18.009, TE(X->Y) = 1.4937  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 23.5933, H(Y|X-,Y-) = 23.5678, TE(X->Y) = 0.0255 \n",
      "H(Y|Y-) = 18.8128, H(Y|X-,Y-) = 17.5784, TE(X->Y) = 1.2344 \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5252, H(Y|X-,Y-) = 2.5116, TE(X->Y) = 0.0136  \n",
      "H(Y|Y-) = 2.0219, H(Y|X-,Y-) = 1.8975, TE(X->Y) = 0.1244  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.33, H(Y|X-,Y-) = 2.3282, TE(X->Y) = 0.0018  \n",
      "H(Y|Y-) = 1.8822, H(Y|X-,Y-) = 1.758, TE(X->Y) = 0.1242   \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 4.947, H(Y|X-,Y-) = 4.9175, TE(X->Y) = 0.0295  \n",
      "H(Y|Y-) = 3.9721, H(Y|X-,Y-) = 3.7136, TE(X->Y) = 0.2585  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.6709, H(Y|X-,Y-) = 4.6687, TE(X->Y) = 0.0022  \n",
      "H(Y|Y-) = 3.7288, H(Y|X-,Y-) = 3.485, TE(X->Y) = 0.2438   \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.3654, H(Y|X-,Y-) = 7.3127, TE(X->Y) = 0.0527  \n",
      "H(Y|Y-) = 5.9462, H(Y|X-,Y-) = 5.5496, TE(X->Y) = 0.3966  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.0134, H(Y|X-,Y-) = 7.0138, TE(X->Y) = -0.0004 \n",
      "H(Y|Y-) = 5.6404, H(Y|X-,Y-) = 5.2711, TE(X->Y) = 0.3693  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 9.8471, H(Y|X-,Y-) = 9.7716, TE(X->Y) = 0.0755  \n",
      "H(Y|Y-) = 7.9785, H(Y|X-,Y-) = 7.4345, TE(X->Y) = 0.544   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.3927, H(Y|X-,Y-) = 9.3874, TE(X->Y) = 0.0053  \n",
      "H(Y|Y-) = 7.5466, H(Y|X-,Y-) = 7.0492, TE(X->Y) = 0.4974  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.3022, H(Y|X-,Y-) = 12.2084, TE(X->Y) = 0.0938 \n",
      "H(Y|Y-) = 9.9308, H(Y|X-,Y-) = 9.2399, TE(X->Y) = 0.6909  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 11.7456, H(Y|X-,Y-) = 11.7292, TE(X->Y) = 0.0164 \n",
      "H(Y|Y-) = 9.4887, H(Y|X-,Y-) = 8.8741, TE(X->Y) = 0.6146  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 14.7742, H(Y|X-,Y-) = 14.646, TE(X->Y) = 0.1282  \n",
      "H(Y|Y-) = 11.9169, H(Y|X-,Y-) = 11.0862, TE(X->Y) = 0.8307 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.146, H(Y|X-,Y-) = 14.1351, TE(X->Y) = 0.0109 \n",
      "H(Y|Y-) = 11.4036, H(Y|X-,Y-) = 10.6675, TE(X->Y) = 0.7361 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.2585, H(Y|X-,Y-) = 17.1016, TE(X->Y) = 0.1569 \n",
      "H(Y|Y-) = 13.8748, H(Y|X-,Y-) = 12.8759, TE(X->Y) = 0.9989 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.4823, H(Y|X-,Y-) = 16.4642, TE(X->Y) = 0.0181 \n",
      "H(Y|Y-) = 13.3151, H(Y|X-,Y-) = 12.4556, TE(X->Y) = 0.8595 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 19.629, H(Y|X-,Y-) = 19.4233, TE(X->Y) = 0.2057 \n",
      "H(Y|Y-) = 15.6821, H(Y|X-,Y-) = 14.5194, TE(X->Y) = 1.1627 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 18.8323, H(Y|X-,Y-) = 18.8118, TE(X->Y) = 0.0205 \n",
      "H(Y|Y-) = 15.1089, H(Y|X-,Y-) = 14.1194, TE(X->Y) = 0.9895 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.0233, H(Y|X-,Y-) = 21.766, TE(X->Y) = 0.2573  \n",
      "H(Y|Y-) = 17.6842, H(Y|X-,Y-) = 16.3453, TE(X->Y) = 1.3389 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 21.1671, H(Y|X-,Y-) = 21.1387, TE(X->Y) = 0.0284 \n",
      "H(Y|Y-) = 17.0025, H(Y|X-,Y-) = 15.8857, TE(X->Y) = 1.1168 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.3406, H(Y|X-,Y-) = 24.0266, TE(X->Y) = 0.314  \n",
      "H(Y|Y-) = 19.552, H(Y|X-,Y-) = 18.0308, TE(X->Y) = 1.5212 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 23.5519, H(Y|X-,Y-) = 23.5215, TE(X->Y) = 0.0304 \n",
      "H(Y|Y-) = 18.8502, H(Y|X-,Y-) = 17.6179, TE(X->Y) = 1.2323 \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.4462, H(Y|X-,Y-) = 2.4382, TE(X->Y) = 0.008   \n",
      "H(Y|Y-) = 1.9692, H(Y|X-,Y-) = 1.8479, TE(X->Y) = 0.1213  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.3432, H(Y|X-,Y-) = 2.3405, TE(X->Y) = 0.0027  \n",
      "H(Y|Y-) = 1.8471, H(Y|X-,Y-) = 1.7275, TE(X->Y) = 0.1196  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 4.88, H(Y|X-,Y-) = 4.8502, TE(X->Y) = 0.0298  \n",
      "H(Y|Y-) = 3.9674, H(Y|X-,Y-) = 3.7023, TE(X->Y) = 0.2651  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.6892, H(Y|X-,Y-) = 4.6844, TE(X->Y) = 0.0048  \n",
      "H(Y|Y-) = 3.7616, H(Y|X-,Y-) = 3.5122, TE(X->Y) = 0.2494  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.3709, H(Y|X-,Y-) = 7.3287, TE(X->Y) = 0.0422  \n",
      "H(Y|Y-) = 6.0027, H(Y|X-,Y-) = 5.604, TE(X->Y) = 0.3987   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.0642, H(Y|X-,Y-) = 7.0622, TE(X->Y) = 0.002   \n",
      "H(Y|Y-) = 5.6597, H(Y|X-,Y-) = 5.3036, TE(X->Y) = 0.3561  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 9.851, H(Y|X-,Y-) = 9.7781, TE(X->Y) = 0.0729  \n",
      "H(Y|Y-) = 7.9728, H(Y|X-,Y-) = 7.4235, TE(X->Y) = 0.5493  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.4185, H(Y|X-,Y-) = 9.4076, TE(X->Y) = 0.0109  \n",
      "H(Y|Y-) = 7.6078, H(Y|X-,Y-) = 7.1217, TE(X->Y) = 0.4861  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.3347, H(Y|X-,Y-) = 12.2337, TE(X->Y) = 0.101  \n",
      "H(Y|Y-) = 9.9654, H(Y|X-,Y-) = 9.2836, TE(X->Y) = 0.6818  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 11.8156, H(Y|X-,Y-) = 11.8102, TE(X->Y) = 0.0054 \n",
      "H(Y|Y-) = 9.5244, H(Y|X-,Y-) = 8.9065, TE(X->Y) = 0.6179  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 14.8206, H(Y|X-,Y-) = 14.687, TE(X->Y) = 0.1336  \n",
      "H(Y|Y-) = 11.9439, H(Y|X-,Y-) = 11.0845, TE(X->Y) = 0.8594 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.1569, H(Y|X-,Y-) = 14.1435, TE(X->Y) = 0.0134 \n",
      "H(Y|Y-) = 11.4373, H(Y|X-,Y-) = 10.6983, TE(X->Y) = 0.739  \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.21, H(Y|X-,Y-) = 17.0282, TE(X->Y) = 0.1818 \n",
      "H(Y|Y-) = 13.7463, H(Y|X-,Y-) = 12.7281, TE(X->Y) = 1.0182 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.5061, H(Y|X-,Y-) = 16.485, TE(X->Y) = 0.0211  \n",
      "H(Y|Y-) = 13.2245, H(Y|X-,Y-) = 12.3683, TE(X->Y) = 0.8562 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 19.5971, H(Y|X-,Y-) = 19.3699, TE(X->Y) = 0.2272 \n",
      "H(Y|Y-) = 15.7585, H(Y|X-,Y-) = 14.576, TE(X->Y) = 1.1825  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 18.8451, H(Y|X-,Y-) = 18.8297, TE(X->Y) = 0.0154 \n",
      "H(Y|Y-) = 15.1198, H(Y|X-,Y-) = 14.1384, TE(X->Y) = 0.9814 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 21.9296, H(Y|X-,Y-) = 21.654, TE(X->Y) = 0.2756  \n",
      "H(Y|Y-) = 17.6351, H(Y|X-,Y-) = 16.289, TE(X->Y) = 1.3461  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 21.2197, H(Y|X-,Y-) = 21.1975, TE(X->Y) = 0.0222 \n",
      "H(Y|Y-) = 16.9661, H(Y|X-,Y-) = 15.8667, TE(X->Y) = 1.0994 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.3672, H(Y|X-,Y-) = 24.0555, TE(X->Y) = 0.3117 \n",
      "H(Y|Y-) = 19.5722, H(Y|X-,Y-) = 18.0458, TE(X->Y) = 1.5264 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 23.6321, H(Y|X-,Y-) = 23.5895, TE(X->Y) = 0.0426 \n",
      "H(Y|Y-) = 18.7426, H(Y|X-,Y-) = 17.5188, TE(X->Y) = 1.2238 \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.4636, H(Y|X-,Y-) = 2.4507, TE(X->Y) = 0.0129  \n",
      "H(Y|Y-) = 2.0171, H(Y|X-,Y-) = 1.885, TE(X->Y) = 0.1321   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.3438, H(Y|X-,Y-) = 2.3442, TE(X->Y) = -0.0004 \n",
      "H(Y|Y-) = 1.9146, H(Y|X-,Y-) = 1.7926, TE(X->Y) = 0.122   \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 4.9726, H(Y|X-,Y-) = 4.9418, TE(X->Y) = 0.0308  \n",
      "H(Y|Y-) = 4.0728, H(Y|X-,Y-) = 3.8031, TE(X->Y) = 0.2697  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.7243, H(Y|X-,Y-) = 4.7245, TE(X->Y) = -0.0002 \n",
      "H(Y|Y-) = 3.8185, H(Y|X-,Y-) = 3.5747, TE(X->Y) = 0.2438  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.4564, H(Y|X-,Y-) = 7.406, TE(X->Y) = 0.0504   \n",
      "H(Y|Y-) = 6.049, H(Y|X-,Y-) = 5.6445, TE(X->Y) = 0.4045  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.0747, H(Y|X-,Y-) = 7.0742, TE(X->Y) = 0.0005  \n",
      "H(Y|Y-) = 5.7628, H(Y|X-,Y-) = 5.395, TE(X->Y) = 0.3678   \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 9.9422, H(Y|X-,Y-) = 9.8802, TE(X->Y) = 0.062   \n",
      "H(Y|Y-) = 8.0609, H(Y|X-,Y-) = 7.5144, TE(X->Y) = 0.5465  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.4782, H(Y|X-,Y-) = 9.4762, TE(X->Y) = 0.002   \n",
      "H(Y|Y-) = 7.6774, H(Y|X-,Y-) = 7.1864, TE(X->Y) = 0.491   \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.4457, H(Y|X-,Y-) = 12.344, TE(X->Y) = 0.1017  \n",
      "H(Y|Y-) = 10.0361, H(Y|X-,Y-) = 9.3311, TE(X->Y) = 0.705   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 11.819, H(Y|X-,Y-) = 11.8137, TE(X->Y) = 0.0053 \n",
      "H(Y|Y-) = 9.592, H(Y|X-,Y-) = 8.9779, TE(X->Y) = 0.6141  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 14.8379, H(Y|X-,Y-) = 14.7044, TE(X->Y) = 0.1335 \n",
      "H(Y|Y-) = 11.8625, H(Y|X-,Y-) = 11.0015, TE(X->Y) = 0.861  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.1704, H(Y|X-,Y-) = 14.1585, TE(X->Y) = 0.0119 \n",
      "H(Y|Y-) = 11.3792, H(Y|X-,Y-) = 10.6425, TE(X->Y) = 0.7367 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.2254, H(Y|X-,Y-) = 17.055, TE(X->Y) = 0.1704  \n",
      "H(Y|Y-) = 13.8701, H(Y|X-,Y-) = 12.8695, TE(X->Y) = 1.0006 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 16.5054, H(Y|X-,Y-) = 16.4943, TE(X->Y) = 0.0111 \n",
      "H(Y|Y-) = 13.2773, H(Y|X-,Y-) = 12.4114, TE(X->Y) = 0.8659 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 19.5776, H(Y|X-,Y-) = 19.3612, TE(X->Y) = 0.2164 \n",
      "H(Y|Y-) = 15.7569, H(Y|X-,Y-) = 14.5914, TE(X->Y) = 1.1655 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 18.8897, H(Y|X-,Y-) = 18.8705, TE(X->Y) = 0.0192 \n",
      "H(Y|Y-) = 15.1319, H(Y|X-,Y-) = 14.1434, TE(X->Y) = 0.9885 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.035, H(Y|X-,Y-) = 21.7811, TE(X->Y) = 0.2539 \n",
      "H(Y|Y-) = 17.7077, H(Y|X-,Y-) = 16.356, TE(X->Y) = 1.3517  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 21.2857, H(Y|X-,Y-) = 21.2627, TE(X->Y) = 0.023  \n",
      "H(Y|Y-) = 16.9047, H(Y|X-,Y-) = 15.7905, TE(X->Y) = 1.1142 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 24.538, H(Y|X-,Y-) = 24.221, TE(X->Y) = 0.317   \n",
      "H(Y|Y-) = 19.6792, H(Y|X-,Y-) = 18.1674, TE(X->Y) = 1.5118 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 23.7083, H(Y|X-,Y-) = 23.6828, TE(X->Y) = 0.0255 \n",
      "H(Y|Y-) = 18.7642, H(Y|X-,Y-) = 17.5239, TE(X->Y) = 1.2403 \n"
     ]
    }
   ],
   "source": [
    "lg_results_TE_X2Y = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "lg_results_TE_Y2X = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for dim, generator in zip(dim_range, lg_generator_lst):\n",
    "        print(\"## Dim = \", dim, \"#\")\n",
    "        for samples in sample_sizes:\n",
    "            print(\"# Sample size = \", samples, \"#\")\n",
    "            # Simulate data\n",
    "            X, Y = generator.simulate(time=samples, seed=r)\n",
    "            # Estimate X -> Y\n",
    "            TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            lg_results_TE_X2Y.write(method='njee', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            lg_results_TE_Y2X.write(method='njee', n_dim=dim, sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "lg_results_TE_X2Y.df.to_csv('results/njee/lg_results_TE_X2Y_dim.csv', index=False)\n",
    "lg_results_TE_Y2X.df.to_csv('results/njee/lg_results_TE_Y2X_dim.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Joint Process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the list of generators with one for each dimension\n",
    "jp_generator_lst = [MVJointProcessSimulator(n_dim=dim, lam=0.0) for dim in dim_range]\n",
    "# Get the reference values\n",
    "jp_TE_X2Y_ref_lst = [generator.analytic_transfer_entropy('X', 'Y') for generator in jp_generator_lst]\n",
    "jp_TE_Y2X_ref_lst = [generator.analytic_transfer_entropy('Y', 'X') for generator in jp_generator_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.541, H(Y|X-,Y-) = 1.7312, TE(X->Y) = 0.8098  \n",
      "H(Y|Y-) = 2.5376, H(Y|X-,Y-) = 2.5255, TE(X->Y) = 0.0121  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4456, H(Y|X-,Y-) = 1.6413, TE(X->Y) = 0.8043  \n",
      "H(Y|Y-) = 2.447, H(Y|X-,Y-) = 2.4468, TE(X->Y) = 0.0002  \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.1318, H(Y|X-,Y-) = 3.5155, TE(X->Y) = 1.6163  \n",
      "H(Y|Y-) = 5.1038, H(Y|X-,Y-) = 5.0731, TE(X->Y) = 0.0307  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8954, H(Y|X-,Y-) = 3.2917, TE(X->Y) = 1.6037  \n",
      "H(Y|Y-) = 4.9385, H(Y|X-,Y-) = 4.9366, TE(X->Y) = 0.0019  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.7324, H(Y|X-,Y-) = 5.2934, TE(X->Y) = 2.439   \n",
      "H(Y|Y-) = 7.6316, H(Y|X-,Y-) = 7.5887, TE(X->Y) = 0.0429  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.2769, H(Y|X-,Y-) = 4.8827, TE(X->Y) = 2.3942  \n",
      "H(Y|Y-) = 7.3603, H(Y|X-,Y-) = 7.3564, TE(X->Y) = 0.0039  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2521, H(Y|X-,Y-) = 7.0006, TE(X->Y) = 3.2515  \n",
      "H(Y|Y-) = 10.1001, H(Y|X-,Y-) = 10.0343, TE(X->Y) = 0.0658 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.7441, H(Y|X-,Y-) = 6.5524, TE(X->Y) = 3.1917  \n",
      "H(Y|Y-) = 9.8303, H(Y|X-,Y-) = 9.8225, TE(X->Y) = 0.0078  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.7405, H(Y|X-,Y-) = 8.6563, TE(X->Y) = 4.0842  \n",
      "H(Y|Y-) = 12.5361, H(Y|X-,Y-) = 12.435, TE(X->Y) = 0.1011  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.2312, H(Y|X-,Y-) = 8.2292, TE(X->Y) = 4.002   \n",
      "H(Y|Y-) = 12.2609, H(Y|X-,Y-) = 12.249, TE(X->Y) = 0.0119  \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.3064, H(Y|X-,Y-) = 10.4017, TE(X->Y) = 4.9047 \n",
      "H(Y|Y-) = 15.0991, H(Y|X-,Y-) = 14.9597, TE(X->Y) = 0.1394 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.6895, H(Y|X-,Y-) = 9.8923, TE(X->Y) = 4.7972  \n",
      "H(Y|Y-) = 14.7291, H(Y|X-,Y-) = 14.7152, TE(X->Y) = 0.0139 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.7895, H(Y|X-,Y-) = 12.0722, TE(X->Y) = 5.7173 \n",
      "H(Y|Y-) = 17.6011, H(Y|X-,Y-) = 17.4111, TE(X->Y) = 0.19   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.2029, H(Y|X-,Y-) = 11.5912, TE(X->Y) = 5.6117 \n",
      "H(Y|Y-) = 17.1764, H(Y|X-,Y-) = 17.1691, TE(X->Y) = 0.0073 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.3338, H(Y|X-,Y-) = 13.7851, TE(X->Y) = 6.5487 \n",
      "H(Y|Y-) = 20.0973, H(Y|X-,Y-) = 19.8732, TE(X->Y) = 0.2241 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6092, H(Y|X-,Y-) = 13.2075, TE(X->Y) = 6.4017 \n",
      "H(Y|Y-) = 19.4972, H(Y|X-,Y-) = 19.4785, TE(X->Y) = 0.0187 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.7512, H(Y|X-,Y-) = 15.3682, TE(X->Y) = 7.383  \n",
      "H(Y|Y-) = 22.5047, H(Y|X-,Y-) = 22.2122, TE(X->Y) = 0.2925 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.0916, H(Y|X-,Y-) = 14.8777, TE(X->Y) = 7.2139 \n",
      "H(Y|Y-) = 21.9223, H(Y|X-,Y-) = 21.9089, TE(X->Y) = 0.0134 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.1245, H(Y|X-,Y-) = 16.8836, TE(X->Y) = 8.2409 \n",
      "H(Y|Y-) = 24.9867, H(Y|X-,Y-) = 24.6387, TE(X->Y) = 0.348  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.532, H(Y|X-,Y-) = 16.5316, TE(X->Y) = 8.0004 \n",
      "H(Y|Y-) = 24.3872, H(Y|X-,Y-) = 24.3711, TE(X->Y) = 0.0161 \n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.6221, H(Y|X-,Y-) = 1.8062, TE(X->Y) = 0.8159  \n",
      "H(Y|Y-) = 2.5983, H(Y|X-,Y-) = 2.5847, TE(X->Y) = 0.0136  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4504, H(Y|X-,Y-) = 1.6506, TE(X->Y) = 0.7998  \n",
      "H(Y|Y-) = 2.4935, H(Y|X-,Y-) = 2.4939, TE(X->Y) = -0.0004 \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.2318, H(Y|X-,Y-) = 3.6034, TE(X->Y) = 1.6284  \n",
      "H(Y|Y-) = 5.1416, H(Y|X-,Y-) = 5.1166, TE(X->Y) = 0.025   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8332, H(Y|X-,Y-) = 3.2433, TE(X->Y) = 1.5899  \n",
      "H(Y|Y-) = 4.9195, H(Y|X-,Y-) = 4.9165, TE(X->Y) = 0.003   \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.7648, H(Y|X-,Y-) = 5.3331, TE(X->Y) = 2.4317  \n",
      "H(Y|Y-) = 7.6137, H(Y|X-,Y-) = 7.5669, TE(X->Y) = 0.0468  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.2989, H(Y|X-,Y-) = 4.9074, TE(X->Y) = 2.3915  \n",
      "H(Y|Y-) = 7.3895, H(Y|X-,Y-) = 7.3854, TE(X->Y) = 0.0041  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2535, H(Y|X-,Y-) = 7.005, TE(X->Y) = 3.2485   \n",
      "H(Y|Y-) = 10.061, H(Y|X-,Y-) = 9.9984, TE(X->Y) = 0.0626  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.7928, H(Y|X-,Y-) = 6.596, TE(X->Y) = 3.1968   \n",
      "H(Y|Y-) = 9.8111, H(Y|X-,Y-) = 9.8059, TE(X->Y) = 0.0052  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.8384, H(Y|X-,Y-) = 8.7613, TE(X->Y) = 4.0771  \n",
      "H(Y|Y-) = 12.6387, H(Y|X-,Y-) = 12.5352, TE(X->Y) = 0.1035 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.2503, H(Y|X-,Y-) = 8.2534, TE(X->Y) = 3.9969  \n",
      "H(Y|Y-) = 12.2801, H(Y|X-,Y-) = 12.2828, TE(X->Y) = -0.0027\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.3272, H(Y|X-,Y-) = 10.4443, TE(X->Y) = 4.8829 \n",
      "H(Y|Y-) = 15.1521, H(Y|X-,Y-) = 15.0099, TE(X->Y) = 0.1422 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.7518, H(Y|X-,Y-) = 9.9584, TE(X->Y) = 4.7934  \n",
      "H(Y|Y-) = 14.7404, H(Y|X-,Y-) = 14.7357, TE(X->Y) = 0.0047 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.8805, H(Y|X-,Y-) = 12.161, TE(X->Y) = 5.7195  \n",
      "H(Y|Y-) = 17.6664, H(Y|X-,Y-) = 17.4864, TE(X->Y) = 0.18   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.1687, H(Y|X-,Y-) = 11.5646, TE(X->Y) = 5.6041 \n",
      "H(Y|Y-) = 17.06, H(Y|X-,Y-) = 17.0516, TE(X->Y) = 0.0084 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.3118, H(Y|X-,Y-) = 13.7643, TE(X->Y) = 6.5475 \n",
      "H(Y|Y-) = 20.0728, H(Y|X-,Y-) = 19.8469, TE(X->Y) = 0.2259 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6397, H(Y|X-,Y-) = 13.2486, TE(X->Y) = 6.3911 \n",
      "H(Y|Y-) = 19.4865, H(Y|X-,Y-) = 19.4669, TE(X->Y) = 0.0196 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.69, H(Y|X-,Y-) = 15.3141, TE(X->Y) = 7.3759 \n",
      "H(Y|Y-) = 22.5568, H(Y|X-,Y-) = 22.2813, TE(X->Y) = 0.2755 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.0986, H(Y|X-,Y-) = 14.8952, TE(X->Y) = 7.2034 \n",
      "H(Y|Y-) = 21.9549, H(Y|X-,Y-) = 21.9384, TE(X->Y) = 0.0165 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.1294, H(Y|X-,Y-) = 16.9088, TE(X->Y) = 8.2206 \n",
      "H(Y|Y-) = 25.0779, H(Y|X-,Y-) = 24.7328, TE(X->Y) = 0.3451 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.5282, H(Y|X-,Y-) = 16.5124, TE(X->Y) = 8.0158 \n",
      "H(Y|Y-) = 24.4393, H(Y|X-,Y-) = 24.4065, TE(X->Y) = 0.0328 \n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.6456, H(Y|X-,Y-) = 1.8286, TE(X->Y) = 0.817   \n",
      "H(Y|Y-) = 2.5773, H(Y|X-,Y-) = 2.5632, TE(X->Y) = 0.0141  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.3845, H(Y|X-,Y-) = 1.5898, TE(X->Y) = 0.7947  \n",
      "H(Y|Y-) = 2.4276, H(Y|X-,Y-) = 2.427, TE(X->Y) = 0.0006   \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.1891, H(Y|X-,Y-) = 3.5749, TE(X->Y) = 1.6142  \n",
      "H(Y|Y-) = 5.0616, H(Y|X-,Y-) = 5.0305, TE(X->Y) = 0.0311  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.8513, H(Y|X-,Y-) = 3.258, TE(X->Y) = 1.5933   \n",
      "H(Y|Y-) = 4.8956, H(Y|X-,Y-) = 4.8992, TE(X->Y) = -0.0036 \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.6926, H(Y|X-,Y-) = 5.2629, TE(X->Y) = 2.4297  \n",
      "H(Y|Y-) = 7.518, H(Y|X-,Y-) = 7.4678, TE(X->Y) = 0.0502  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.3476, H(Y|X-,Y-) = 4.9428, TE(X->Y) = 2.4048  \n",
      "H(Y|Y-) = 7.3212, H(Y|X-,Y-) = 7.3173, TE(X->Y) = 0.0039  \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2852, H(Y|X-,Y-) = 7.0386, TE(X->Y) = 3.2466  \n",
      "H(Y|Y-) = 10.0968, H(Y|X-,Y-) = 10.0255, TE(X->Y) = 0.0713 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.8048, H(Y|X-,Y-) = 6.6049, TE(X->Y) = 3.1999  \n",
      "H(Y|Y-) = 9.7999, H(Y|X-,Y-) = 9.7984, TE(X->Y) = 0.0015  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.794, H(Y|X-,Y-) = 8.7233, TE(X->Y) = 4.0707  \n",
      "H(Y|Y-) = 12.6154, H(Y|X-,Y-) = 12.5221, TE(X->Y) = 0.0933 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3144, H(Y|X-,Y-) = 8.3045, TE(X->Y) = 4.0099  \n",
      "H(Y|Y-) = 12.2543, H(Y|X-,Y-) = 12.2466, TE(X->Y) = 0.0077 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.3401, H(Y|X-,Y-) = 10.4786, TE(X->Y) = 4.8615 \n",
      "H(Y|Y-) = 15.1507, H(Y|X-,Y-) = 15.0069, TE(X->Y) = 0.1438 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.7174, H(Y|X-,Y-) = 9.9195, TE(X->Y) = 4.7979  \n",
      "H(Y|Y-) = 14.5699, H(Y|X-,Y-) = 14.5604, TE(X->Y) = 0.0095 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.7834, H(Y|X-,Y-) = 12.0888, TE(X->Y) = 5.6946 \n",
      "H(Y|Y-) = 17.5673, H(Y|X-,Y-) = 17.3922, TE(X->Y) = 0.1751 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.1956, H(Y|X-,Y-) = 11.5985, TE(X->Y) = 5.5971 \n",
      "H(Y|Y-) = 16.9998, H(Y|X-,Y-) = 16.992, TE(X->Y) = 0.0078  \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.1835, H(Y|X-,Y-) = 13.6499, TE(X->Y) = 6.5336 \n",
      "H(Y|Y-) = 20.0551, H(Y|X-,Y-) = 19.8382, TE(X->Y) = 0.2169 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6571, H(Y|X-,Y-) = 13.2551, TE(X->Y) = 6.402  \n",
      "H(Y|Y-) = 19.4631, H(Y|X-,Y-) = 19.443, TE(X->Y) = 0.0201  \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.6427, H(Y|X-,Y-) = 15.2607, TE(X->Y) = 7.382  \n",
      "H(Y|Y-) = 22.5975, H(Y|X-,Y-) = 22.3207, TE(X->Y) = 0.2768 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.0762, H(Y|X-,Y-) = 14.8848, TE(X->Y) = 7.1914 \n",
      "H(Y|Y-) = 21.952, H(Y|X-,Y-) = 21.9318, TE(X->Y) = 0.0202 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.1356, H(Y|X-,Y-) = 16.9173, TE(X->Y) = 8.2183 \n",
      "H(Y|Y-) = 24.9015, H(Y|X-,Y-) = 24.5841, TE(X->Y) = 0.3174 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.5015, H(Y|X-,Y-) = 16.5, TE(X->Y) = 8.0015    \n",
      "H(Y|Y-) = 24.421, H(Y|X-,Y-) = 24.3959, TE(X->Y) = 0.0251 \n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5789, H(Y|X-,Y-) = 1.7747, TE(X->Y) = 0.8042  \n",
      "H(Y|Y-) = 2.5188, H(Y|X-,Y-) = 2.5047, TE(X->Y) = 0.0141  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4724, H(Y|X-,Y-) = 1.666, TE(X->Y) = 0.8064   \n",
      "H(Y|Y-) = 2.4715, H(Y|X-,Y-) = 2.4739, TE(X->Y) = -0.0024 \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.0938, H(Y|X-,Y-) = 3.487, TE(X->Y) = 1.6068   \n",
      "H(Y|Y-) = 4.984, H(Y|X-,Y-) = 4.9535, TE(X->Y) = 0.0305  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9624, H(Y|X-,Y-) = 3.3532, TE(X->Y) = 1.6092  \n",
      "H(Y|Y-) = 4.9038, H(Y|X-,Y-) = 4.9032, TE(X->Y) = 0.0006  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.6967, H(Y|X-,Y-) = 5.2788, TE(X->Y) = 2.4179  \n",
      "H(Y|Y-) = 7.5792, H(Y|X-,Y-) = 7.5337, TE(X->Y) = 0.0455  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.4236, H(Y|X-,Y-) = 5.0139, TE(X->Y) = 2.4097  \n",
      "H(Y|Y-) = 7.3827, H(Y|X-,Y-) = 7.375, TE(X->Y) = 0.0077   \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2092, H(Y|X-,Y-) = 6.9747, TE(X->Y) = 3.2345  \n",
      "H(Y|Y-) = 10.1065, H(Y|X-,Y-) = 10.0471, TE(X->Y) = 0.0594 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.9304, H(Y|X-,Y-) = 6.7164, TE(X->Y) = 3.214   \n",
      "H(Y|Y-) = 9.8297, H(Y|X-,Y-) = 9.8313, TE(X->Y) = -0.0016 \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.7852, H(Y|X-,Y-) = 8.7353, TE(X->Y) = 4.0499  \n",
      "H(Y|Y-) = 12.642, H(Y|X-,Y-) = 12.5488, TE(X->Y) = 0.0932 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3477, H(Y|X-,Y-) = 8.3305, TE(X->Y) = 4.0172  \n",
      "H(Y|Y-) = 12.1487, H(Y|X-,Y-) = 12.1487, TE(X->Y) = 0.0    \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.2324, H(Y|X-,Y-) = 10.3564, TE(X->Y) = 4.876  \n",
      "H(Y|Y-) = 15.071, H(Y|X-,Y-) = 14.9496, TE(X->Y) = 0.1214 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.8237, H(Y|X-,Y-) = 10.0141, TE(X->Y) = 4.8096 \n",
      "H(Y|Y-) = 14.5877, H(Y|X-,Y-) = 14.5703, TE(X->Y) = 0.0174 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.6423, H(Y|X-,Y-) = 11.935, TE(X->Y) = 5.7073  \n",
      "H(Y|Y-) = 17.5655, H(Y|X-,Y-) = 17.4045, TE(X->Y) = 0.161  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.2742, H(Y|X-,Y-) = 11.6637, TE(X->Y) = 5.6105 \n",
      "H(Y|Y-) = 17.0477, H(Y|X-,Y-) = 17.0288, TE(X->Y) = 0.0189 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.0837, H(Y|X-,Y-) = 13.5539, TE(X->Y) = 6.5298 \n",
      "H(Y|Y-) = 20.1174, H(Y|X-,Y-) = 19.9012, TE(X->Y) = 0.2162 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.6968, H(Y|X-,Y-) = 13.2867, TE(X->Y) = 6.4101 \n",
      "H(Y|Y-) = 19.5375, H(Y|X-,Y-) = 19.5121, TE(X->Y) = 0.0254 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.6131, H(Y|X-,Y-) = 15.2358, TE(X->Y) = 7.3773 \n",
      "H(Y|Y-) = 22.4417, H(Y|X-,Y-) = 22.162, TE(X->Y) = 0.2797  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.1333, H(Y|X-,Y-) = 14.9138, TE(X->Y) = 7.2195 \n",
      "H(Y|Y-) = 21.9857, H(Y|X-,Y-) = 21.9779, TE(X->Y) = 0.0078 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.1026, H(Y|X-,Y-) = 16.8857, TE(X->Y) = 8.2169 \n",
      "H(Y|Y-) = 24.9224, H(Y|X-,Y-) = 24.5895, TE(X->Y) = 0.3329 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.5135, H(Y|X-,Y-) = 16.4976, TE(X->Y) = 8.0159 \n",
      "H(Y|Y-) = 24.3779, H(Y|X-,Y-) = 24.3429, TE(X->Y) = 0.035  \n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 2.5492, H(Y|X-,Y-) = 1.7366, TE(X->Y) = 0.8126  \n",
      "H(Y|Y-) = 2.4976, H(Y|X-,Y-) = 2.4834, TE(X->Y) = 0.0142  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 2.4929, H(Y|X-,Y-) = 1.6869, TE(X->Y) = 0.806   \n",
      "H(Y|Y-) = 2.4271, H(Y|X-,Y-) = 2.4312, TE(X->Y) = -0.0041 \n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 5.17, H(Y|X-,Y-) = 3.5497, TE(X->Y) = 1.6203  \n",
      "H(Y|Y-) = 5.1098, H(Y|X-,Y-) = 5.083, TE(X->Y) = 0.0268   \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 4.9495, H(Y|X-,Y-) = 3.3468, TE(X->Y) = 1.6027  \n",
      "H(Y|Y-) = 4.9065, H(Y|X-,Y-) = 4.909, TE(X->Y) = -0.0025  \n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 7.6835, H(Y|X-,Y-) = 5.269, TE(X->Y) = 2.4145   \n",
      "H(Y|Y-) = 7.6469, H(Y|X-,Y-) = 7.6095, TE(X->Y) = 0.0374  \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 7.4616, H(Y|X-,Y-) = 5.0518, TE(X->Y) = 2.4098  \n",
      "H(Y|Y-) = 7.3538, H(Y|X-,Y-) = 7.3555, TE(X->Y) = -0.0017 \n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 10.2745, H(Y|X-,Y-) = 7.0383, TE(X->Y) = 3.2362  \n",
      "H(Y|Y-) = 10.1859, H(Y|X-,Y-) = 10.1305, TE(X->Y) = 0.0554 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 9.872, H(Y|X-,Y-) = 6.6628, TE(X->Y) = 3.2092  \n",
      "H(Y|Y-) = 9.684, H(Y|X-,Y-) = 9.6769, TE(X->Y) = 0.0071  \n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 12.724, H(Y|X-,Y-) = 8.6879, TE(X->Y) = 4.0361  \n",
      "H(Y|Y-) = 12.6345, H(Y|X-,Y-) = 12.5347, TE(X->Y) = 0.0998 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 12.3645, H(Y|X-,Y-) = 8.3542, TE(X->Y) = 4.0103  \n",
      "H(Y|Y-) = 12.1088, H(Y|X-,Y-) = 12.1062, TE(X->Y) = 0.0026 \n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 15.1433, H(Y|X-,Y-) = 10.2597, TE(X->Y) = 4.8836 \n",
      "H(Y|Y-) = 15.1367, H(Y|X-,Y-) = 15.0091, TE(X->Y) = 0.1276 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 14.8101, H(Y|X-,Y-) = 9.9992, TE(X->Y) = 4.8109  \n",
      "H(Y|Y-) = 14.5795, H(Y|X-,Y-) = 14.5697, TE(X->Y) = 0.0098 \n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 17.6149, H(Y|X-,Y-) = 11.9026, TE(X->Y) = 5.7123 \n",
      "H(Y|Y-) = 17.6935, H(Y|X-,Y-) = 17.5172, TE(X->Y) = 0.1763 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 17.236, H(Y|X-,Y-) = 11.6191, TE(X->Y) = 5.6169 \n",
      "H(Y|Y-) = 17.0588, H(Y|X-,Y-) = 17.0524, TE(X->Y) = 0.0064 \n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 20.1531, H(Y|X-,Y-) = 13.5688, TE(X->Y) = 6.5843 \n",
      "H(Y|Y-) = 20.0401, H(Y|X-,Y-) = 19.8002, TE(X->Y) = 0.2399 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 19.668, H(Y|X-,Y-) = 13.2532, TE(X->Y) = 6.4148 \n",
      "H(Y|Y-) = 19.5246, H(Y|X-,Y-) = 19.5108, TE(X->Y) = 0.0138 \n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 22.6345, H(Y|X-,Y-) = 15.248, TE(X->Y) = 7.3865  \n",
      "H(Y|Y-) = 22.5272, H(Y|X-,Y-) = 22.2364, TE(X->Y) = 0.2908 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 22.0443, H(Y|X-,Y-) = 14.8357, TE(X->Y) = 7.2086 \n",
      "H(Y|Y-) = 21.9149, H(Y|X-,Y-) = 21.8946, TE(X->Y) = 0.0203 \n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "H(Y|Y-) = 25.0012, H(Y|X-,Y-) = 16.7821, TE(X->Y) = 8.2191 \n",
      "H(Y|Y-) = 24.9366, H(Y|X-,Y-) = 24.5902, TE(X->Y) = 0.3464 \n",
      "# Sample size =  100000 #\n",
      "H(Y|Y-) = 24.532, H(Y|X-,Y-) = 16.5049, TE(X->Y) = 8.0271 \n",
      "H(Y|Y-) = 24.4077, H(Y|X-,Y-) = 24.3804, TE(X->Y) = 0.0273 \n"
     ]
    }
   ],
   "source": [
    "jp_results_TE_X2Y = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "jp_results_TE_Y2X = Results(columns=['method', 'n_dim', 'sample_size'])\n",
    "\n",
    "for r in range(REPLICATES):\n",
    "    print(f\"\\n### REPLICATE {r+1}/{REPLICATES} ###\\n\")\n",
    "    for dim, generator in zip(dim_range, jp_generator_lst):\n",
    "        print(\"## Dim = \", dim, \"#\")\n",
    "        for samples in sample_sizes:\n",
    "            print(\"# Sample size = \", samples, \"#\")\n",
    "            # Simulate data\n",
    "            X, Y = generator.simulate(time=samples, seed=r)\n",
    "            # Estimate X -> Y\n",
    "            TE_X2Y = TE_njee(X, Y, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            jp_results_TE_X2Y.write(method='njee', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X = TE_njee(Y, X, device=compute_device, n_bins=N_BINS, epochs=EPOCHS, batch_size=BATCH_SIZE)\n",
    "            jp_results_TE_Y2X.write(method='njee', n_dim=dim, sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "jp_results_TE_X2Y.df.to_csv('results/njee/jp_results_TE_X2Y_dim.csv', index=False)\n",
    "jp_results_TE_Y2X.df.to_csv('results/njee/jp_results_TE_Y2X_dim.csv', index=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
