{
 "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 te_datasim.jointprocess import MVJointProcessSimulator\n",
    "from te_datasim.lineargaussian import MVLinearGaussianSimulator"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from reference_knnksg import TE_knnksg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from util_results import Results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Basic Validity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "REPLICATES = 10\n",
    "SAMPLE_SIZE = 10000"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Linear Gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "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": 180,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 2/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 3/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 4/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 5/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 6/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 7/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 8/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 9/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 10/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 11/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 12/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 13/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 14/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 15/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 16/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 17/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 18/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 19/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 20/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 21/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 22/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 23/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 24/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 25/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 26/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 27/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 28/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 29/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 30/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 31/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 32/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 33/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 34/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 35/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 36/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 37/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 38/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 39/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 40/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 41/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 42/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 43/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 44/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 45/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 46/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 47/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 48/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 49/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\n",
      "\n",
      "### REPLICATE 50/50 ###\n",
      "\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.125 #\n",
      "# Coupling =  0.25 #\n",
      "# Coupling =  0.375 #\n",
      "# Coupling =  0.5 #\n",
      "# Coupling =  0.625 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  0.875 #\n",
      "# Coupling =  1.0 #\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_knnksg(X, Y)\n",
    "        lg_results_TE_X2Y.write(method='knnksg', coupling=lam, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_knnksg(Y, X)\n",
    "        lg_results_TE_Y2X.write(method='knnksg', coupling=lam, value=TE_Y2X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "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": 182,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 2/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 3/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 4/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 5/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 6/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 7/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 8/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 9/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 10/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 11/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 12/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 13/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 14/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 15/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 16/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 17/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 18/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 19/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 20/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 21/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 22/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 23/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 24/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 25/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 26/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 27/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 28/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 29/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 30/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 31/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 32/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 33/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 34/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 35/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 36/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 37/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 38/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 39/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 40/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 41/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 42/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 43/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 44/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 45/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 46/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 47/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 48/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 49/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 50/50 ###\n",
      "\n",
      "# Coupling =  -3.0 #\n",
      "# Coupling =  -2.25 #\n",
      "# Coupling =  -1.5 #\n",
      "# Coupling =  -0.75 #\n",
      "# Coupling =  0.0 #\n",
      "# Coupling =  0.75 #\n",
      "# Coupling =  1.5 #\n",
      "# Coupling =  2.25 #\n",
      "# Coupling =  3.0 #\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_knnksg(X, Y)\n",
    "        jp_results_TE_X2Y.write(method='knnksg', coupling=lam, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_knnksg(Y, X)\n",
    "        jp_results_TE_Y2X.write(method='knnksg', coupling=lam, value=TE_Y2X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sample size scaling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "metadata": {},
   "outputs": [],
   "source": [
    "REPLICATES = 50"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "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": 200,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 2/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 3/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 4/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 5/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 6/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 7/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 8/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 9/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 10/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 11/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 12/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 13/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 14/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 15/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 16/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 17/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 18/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 19/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 20/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 21/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 22/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 23/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 24/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 25/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 26/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 27/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 28/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 29/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 30/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 31/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 32/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 33/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 34/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 35/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 36/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 37/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 38/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 39/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 40/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 41/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 42/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 43/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 44/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 45/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 46/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 47/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 48/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 49/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 50/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\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, \"samples\")\n",
    "        # Simulate data\n",
    "        X, Y = lg_generator.simulate(time=samples, seed=r)\n",
    "        # Estimate X -> Y\n",
    "        TE_X2Y = TE_knnksg(X, Y)\n",
    "        lg_results_TE_X2Y.write(method='knnksg', sample_size=samples, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_knnksg(Y, X)\n",
    "        lg_results_TE_Y2X.write(method='knnksg', sample_size=samples, value=TE_Y2X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 2/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 3/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 4/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 5/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 6/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 7/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 8/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 9/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 10/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 11/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 12/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 13/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 14/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 15/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 16/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 17/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 18/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 19/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 20/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 21/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 22/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 23/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 24/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 25/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 26/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 27/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 28/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 29/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 30/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 31/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 32/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 33/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 34/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 35/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 36/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 37/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 38/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 39/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 40/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 41/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 42/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 43/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 44/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 45/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 46/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 47/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 48/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 49/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "\n",
      "### REPLICATE 50/50 ###\n",
      "\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\n",
      "# Coupling =  3.0 #\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_knnksg(X, Y)\n",
    "        jp_results_TE_X2Y.write(method='knnksg', sample_size=samples, value=TE_X2Y)\n",
    "        # Estimate Y -> X\n",
    "        TE_Y2X = TE_knnksg(Y, X)\n",
    "        jp_results_TE_Y2X.write(method='knnksg', sample_size=samples, value=TE_Y2X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Dimensionality Scaling with redundant dimensions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "REPLICATES = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": 13,
   "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": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "# Sample size =  100000 #\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[14], line 16\u001b[0m\n\u001b[1;32m     14\u001b[0m lg_results_TE_X2Y\u001b[38;5;241m.\u001b[39mwrite(method\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mknnksg\u001b[39m\u001b[38;5;124m'\u001b[39m, n_dim\u001b[38;5;241m=\u001b[39mdim, sample_size\u001b[38;5;241m=\u001b[39msamples, value\u001b[38;5;241m=\u001b[39mTE_X2Y)\n\u001b[1;32m     15\u001b[0m \u001b[38;5;66;03m# Estimate Y -> X\u001b[39;00m\n\u001b[0;32m---> 16\u001b[0m TE_Y2X \u001b[38;5;241m=\u001b[39m TE_knnksg(Y, X)\n\u001b[1;32m     17\u001b[0m lg_results_TE_Y2X\u001b[38;5;241m.\u001b[39mwrite(method\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mknnksg\u001b[39m\u001b[38;5;124m'\u001b[39m, n_dim\u001b[38;5;241m=\u001b[39mdim, sample_size\u001b[38;5;241m=\u001b[39msamples, value\u001b[38;5;241m=\u001b[39mTE_Y2X)\n",
      "File \u001b[0;32m~/Cloud/Projects/2023_UCL_Causal_Direction/Testing/Simulated_te_datasim/reference_knnksg.py:130\u001b[0m, in \u001b[0;36mTE_knnksg\u001b[0;34m(var_from_data, var_to_data, slice_size, k)\u001b[0m\n\u001b[1;32m    128\u001b[0m results \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m    129\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m0\u001b[39m, \u001b[38;5;28mlen\u001b[39m(X_m), slice_size):\n\u001b[0;32m--> 130\u001b[0m     results\u001b[38;5;241m.\u001b[39mappend(mi(X_m[i:i\u001b[38;5;241m+\u001b[39mslice_size], Y_n[i:i\u001b[38;5;241m+\u001b[39mslice_size], Y_m[i:i\u001b[38;5;241m+\u001b[39mslice_size], k\u001b[38;5;241m=\u001b[39mk))\n\u001b[1;32m    134\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m np\u001b[38;5;241m.\u001b[39mround(np\u001b[38;5;241m.\u001b[39mmean(results),\u001b[38;5;241m4\u001b[39m)\n",
      "File \u001b[0;32m~/Cloud/Projects/2023_UCL_Causal_Direction/Testing/Simulated_te_datasim/reference_knnksg.py:91\u001b[0m, in \u001b[0;36mmi\u001b[0;34m(x, y, z, k, alpha)\u001b[0m\n\u001b[1;32m     88\u001b[0m     xz \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mc_[x, z]\n\u001b[1;32m     89\u001b[0m     yz \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mc_[y, z]\n\u001b[1;32m     90\u001b[0m     a, b, c, d \u001b[38;5;241m=\u001b[39m avgdigamma(xz, dvec), avgdigamma(\n\u001b[0;32m---> 91\u001b[0m         yz, dvec), avgdigamma(z, dvec), digamma(k)\n\u001b[1;32m     92\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m (\u001b[38;5;241m-\u001b[39ma \u001b[38;5;241m-\u001b[39m b \u001b[38;5;241m+\u001b[39m c \u001b[38;5;241m+\u001b[39m d)\n",
      "File \u001b[0;32m~/Cloud/Projects/2023_UCL_Causal_Direction/Testing/Simulated_te_datasim/reference_knnksg.py:30\u001b[0m, in \u001b[0;36mavgdigamma\u001b[0;34m(points, dvec)\u001b[0m\n\u001b[1;32m     28\u001b[0m tree \u001b[38;5;241m=\u001b[39m build_tree(points)\n\u001b[1;32m     29\u001b[0m dvec \u001b[38;5;241m=\u001b[39m dvec \u001b[38;5;241m-\u001b[39m \u001b[38;5;241m1e-15\u001b[39m\n\u001b[0;32m---> 30\u001b[0m num_points \u001b[38;5;241m=\u001b[39m count_neighbors(tree, points, dvec)\n\u001b[1;32m     31\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m np\u001b[38;5;241m.\u001b[39mmean(digamma(num_points))\n",
      "File \u001b[0;32m~/Cloud/Projects/2023_UCL_Causal_Direction/Testing/Simulated_te_datasim/reference_knnksg.py:22\u001b[0m, in \u001b[0;36mcount_neighbors\u001b[0;34m(tree, x, r)\u001b[0m\n\u001b[1;32m     21\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcount_neighbors\u001b[39m(tree, x, r):\n\u001b[0;32m---> 22\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m tree\u001b[38;5;241m.\u001b[39mquery_radius(x, r, count_only\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "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_knnksg(X, Y)\n",
    "            lg_results_TE_X2Y.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X = TE_knnksg(Y, X)\n",
    "            lg_results_TE_Y2X.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_Y2X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Joint Process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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) 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": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 2/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 3/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 4/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 5/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 6/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 7/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 8/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 9/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "\n",
      "### REPLICATE 10/10 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  2 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  3 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  4 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  5 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  6 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  7 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  8 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  9 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\n",
      "## Dim =  10 #\n",
      "# Sample size =  1000 #\n",
      "# Sample size =  10000 #\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_knnksg(X, Y)\n",
    "            jp_results_TE_X2Y.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X = TE_knnksg(Y, X)\n",
    "            jp_results_TE_Y2X.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_Y2X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Dimensionality Scaling without redundant dimensions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### REPLICATE 1/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0014\n",
      "TE(Y->X) = 0.1513\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0022\n",
      "TE(Y->X) = 0.1313\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0032\n",
      "TE(Y->X) = 0.225\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0019\n",
      "TE(Y->X) = 0.2184\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0069\n",
      "TE(Y->X) = 0.2474\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0031\n",
      "TE(Y->X) = 0.2505\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0232\n",
      "TE(Y->X) = 0.25\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0151\n",
      "TE(Y->X) = 0.2518\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.033\n",
      "TE(Y->X) = 0.2512\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0316\n",
      "TE(Y->X) = 0.2506\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0527\n",
      "TE(Y->X) = 0.2478\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.049\n",
      "TE(Y->X) = 0.2452\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0754\n",
      "TE(Y->X) = 0.2457\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0722\n",
      "TE(Y->X) = 0.2452\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1032\n",
      "TE(Y->X) = 0.2449\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0976\n",
      "TE(Y->X) = 0.2468\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1251\n",
      "TE(Y->X) = 0.2525\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.123\n",
      "TE(Y->X) = 0.2459\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1517\n",
      "TE(Y->X) = 0.248\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1469\n",
      "TE(Y->X) = 0.2451\n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = -0.0101\n",
      "TE(Y->X) = 0.1237\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = -0.0036\n",
      "TE(Y->X) = 0.1285\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0007\n",
      "TE(Y->X) = 0.2227\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = -0.0037\n",
      "TE(Y->X) = 0.2237\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0049\n",
      "TE(Y->X) = 0.2368\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0059\n",
      "TE(Y->X) = 0.2486\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0097\n",
      "TE(Y->X) = 0.254\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0138\n",
      "TE(Y->X) = 0.2512\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0477\n",
      "TE(Y->X) = 0.2531\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0326\n",
      "TE(Y->X) = 0.2476\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0595\n",
      "TE(Y->X) = 0.2508\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.054\n",
      "TE(Y->X) = 0.2472\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.086\n",
      "TE(Y->X) = 0.2535\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0761\n",
      "TE(Y->X) = 0.247\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1042\n",
      "TE(Y->X) = 0.2608\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0981\n",
      "TE(Y->X) = 0.2458\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.134\n",
      "TE(Y->X) = 0.2576\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1248\n",
      "TE(Y->X) = 0.2474\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1466\n",
      "TE(Y->X) = 0.248\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1451\n",
      "TE(Y->X) = 0.2434\n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0144\n",
      "TE(Y->X) = 0.1307\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0059\n",
      "TE(Y->X) = 0.1273\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0019\n",
      "TE(Y->X) = 0.2102\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0013\n",
      "TE(Y->X) = 0.2179\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0111\n",
      "TE(Y->X) = 0.2473\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0034\n",
      "TE(Y->X) = 0.2511\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0074\n",
      "TE(Y->X) = 0.2607\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0157\n",
      "TE(Y->X) = 0.2525\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.021\n",
      "TE(Y->X) = 0.2617\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0295\n",
      "TE(Y->X) = 0.2512\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0412\n",
      "TE(Y->X) = 0.2578\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0498\n",
      "TE(Y->X) = 0.2469\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0756\n",
      "TE(Y->X) = 0.2557\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0724\n",
      "TE(Y->X) = 0.2426\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1054\n",
      "TE(Y->X) = 0.2568\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0995\n",
      "TE(Y->X) = 0.2455\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.126\n",
      "TE(Y->X) = 0.2505\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1222\n",
      "TE(Y->X) = 0.2453\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1579\n",
      "TE(Y->X) = 0.2525\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1454\n",
      "TE(Y->X) = 0.2457\n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0085\n",
      "TE(Y->X) = 0.1152\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = -0.0002\n",
      "TE(Y->X) = 0.1262\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = -0.0076\n",
      "TE(Y->X) = 0.2199\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = -0.0064\n",
      "TE(Y->X) = 0.2212\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0094\n",
      "TE(Y->X) = 0.2566\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0076\n",
      "TE(Y->X) = 0.2494\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0159\n",
      "TE(Y->X) = 0.2639\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0154\n",
      "TE(Y->X) = 0.2543\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0282\n",
      "TE(Y->X) = 0.2643\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0291\n",
      "TE(Y->X) = 0.2524\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0447\n",
      "TE(Y->X) = 0.2627\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0485\n",
      "TE(Y->X) = 0.2471\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0775\n",
      "TE(Y->X) = 0.2559\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0733\n",
      "TE(Y->X) = 0.2468\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1077\n",
      "TE(Y->X) = 0.2502\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1005\n",
      "TE(Y->X) = 0.2459\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1358\n",
      "TE(Y->X) = 0.2561\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1249\n",
      "TE(Y->X) = 0.2464\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1539\n",
      "TE(Y->X) = 0.247\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.146\n",
      "TE(Y->X) = 0.2431\n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = -0.0105\n",
      "TE(Y->X) = 0.1335\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = -0.0035\n",
      "TE(Y->X) = 0.129\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = -0.0095\n",
      "TE(Y->X) = 0.2213\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = -0.0008\n",
      "TE(Y->X) = 0.2181\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0035\n",
      "TE(Y->X) = 0.2516\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.004\n",
      "TE(Y->X) = 0.2509\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.01\n",
      "TE(Y->X) = 0.2597\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.015\n",
      "TE(Y->X) = 0.2584\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0225\n",
      "TE(Y->X) = 0.2604\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0278\n",
      "TE(Y->X) = 0.2477\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0413\n",
      "TE(Y->X) = 0.2452\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0482\n",
      "TE(Y->X) = 0.2464\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.0684\n",
      "TE(Y->X) = 0.2487\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0724\n",
      "TE(Y->X) = 0.248\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1104\n",
      "TE(Y->X) = 0.2553\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.0984\n",
      "TE(Y->X) = 0.2472\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1174\n",
      "TE(Y->X) = 0.249\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1215\n",
      "TE(Y->X) = 0.2455\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.1442\n",
      "TE(Y->X) = 0.2469\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.1459\n",
      "TE(Y->X) = 0.2454\n"
     ]
    }
   ],
   "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]\n",
    "\n",
    "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_knnksg(X, Y)\n",
    "            print(f\"TE(X->Y) = {TE_X2Y}\")\n",
    "            lg_results_TE_X2Y.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X =TE_knnksg(Y, X)\n",
    "            print(f\"TE(Y->X) = {TE_Y2X}\")\n",
    "            lg_results_TE_Y2X.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "lg_results_TE_X2Y.df.to_csv('results/knnksg/lg_results_TE_X2Y_dim.csv', index=False)\n",
    "lg_results_TE_Y2X.df.to_csv('results/knnksg/lg_results_TE_Y2X_dim.csv', index=False)"
   ]
  },
  {
   "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",
      "TE(X->Y) = 0.4079\n",
      "TE(Y->X) = -0.0212\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.4135\n",
      "TE(Y->X) = 0.0033\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6805\n",
      "TE(Y->X) = 0.0154\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6714\n",
      "TE(Y->X) = 0.0042\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7415\n",
      "TE(Y->X) = 0.0023\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7197\n",
      "TE(Y->X) = 0.0005\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7225\n",
      "TE(Y->X) = -0.0029\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7101\n",
      "TE(Y->X) = -0.0015\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7124\n",
      "TE(Y->X) = -0.0032\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.69\n",
      "TE(Y->X) = -0.0032\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6772\n",
      "TE(Y->X) = -0.0065\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6692\n",
      "TE(Y->X) = -0.0011\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6727\n",
      "TE(Y->X) = 0.0062\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6514\n",
      "TE(Y->X) = 0.0017\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6542\n",
      "TE(Y->X) = 0.0015\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6387\n",
      "TE(Y->X) = -0.0021\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6301\n",
      "TE(Y->X) = 0.0067\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6258\n",
      "TE(Y->X) = -0.0023\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6089\n",
      "TE(Y->X) = -0.0012\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6125\n",
      "TE(Y->X) = 0.0009\n",
      "\n",
      "### REPLICATE 2/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.4302\n",
      "TE(Y->X) = 0.0024\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.4085\n",
      "TE(Y->X) = 0.0025\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7047\n",
      "TE(Y->X) = -0.0037\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6607\n",
      "TE(Y->X) = 0.0015\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7424\n",
      "TE(Y->X) = -0.0105\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.717\n",
      "TE(Y->X) = -0.0015\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7256\n",
      "TE(Y->X) = -0.005\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7114\n",
      "TE(Y->X) = 0.0007\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6992\n",
      "TE(Y->X) = -0.0091\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6882\n",
      "TE(Y->X) = 0.0012\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6795\n",
      "TE(Y->X) = -0.0122\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.669\n",
      "TE(Y->X) = -0.0007\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6617\n",
      "TE(Y->X) = -0.0015\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6568\n",
      "TE(Y->X) = -0.0031\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6379\n",
      "TE(Y->X) = 0.0036\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6395\n",
      "TE(Y->X) = -0.0051\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6129\n",
      "TE(Y->X) = -0.0022\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.622\n",
      "TE(Y->X) = -0.0044\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.612\n",
      "TE(Y->X) = -0.0058\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.611\n",
      "TE(Y->X) = -0.0025\n",
      "\n",
      "### REPLICATE 3/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.4027\n",
      "TE(Y->X) = 0.004\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.4012\n",
      "TE(Y->X) = 0.0014\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6717\n",
      "TE(Y->X) = -0.0015\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6622\n",
      "TE(Y->X) = 0.0011\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7342\n",
      "TE(Y->X) = 0.0081\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7211\n",
      "TE(Y->X) = -0.0005\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.721\n",
      "TE(Y->X) = -0.0041\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7095\n",
      "TE(Y->X) = 0.0005\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6946\n",
      "TE(Y->X) = -0.0132\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6881\n",
      "TE(Y->X) = 0.0\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6795\n",
      "TE(Y->X) = -0.007\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.671\n",
      "TE(Y->X) = -0.0019\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6508\n",
      "TE(Y->X) = -0.0086\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6529\n",
      "TE(Y->X) = -0.0034\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.633\n",
      "TE(Y->X) = 0.0008\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6352\n",
      "TE(Y->X) = -0.0044\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6231\n",
      "TE(Y->X) = -0.0071\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6232\n",
      "TE(Y->X) = -0.0044\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.617\n",
      "TE(Y->X) = -0.012\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6109\n",
      "TE(Y->X) = -0.0054\n",
      "\n",
      "### REPLICATE 4/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.4022\n",
      "TE(Y->X) = -0.0063\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.403\n",
      "TE(Y->X) = -0.0017\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6714\n",
      "TE(Y->X) = 0.0096\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6677\n",
      "TE(Y->X) = -0.001\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7237\n",
      "TE(Y->X) = 0.0025\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7242\n",
      "TE(Y->X) = 0.0067\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7208\n",
      "TE(Y->X) = -0.0096\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7138\n",
      "TE(Y->X) = 0.0022\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6964\n",
      "TE(Y->X) = -0.0136\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6935\n",
      "TE(Y->X) = 0.0038\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6747\n",
      "TE(Y->X) = -0.0045\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.669\n",
      "TE(Y->X) = 0.0021\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6447\n",
      "TE(Y->X) = 0.0046\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6535\n",
      "TE(Y->X) = 0.0016\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.637\n",
      "TE(Y->X) = 0.0022\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6376\n",
      "TE(Y->X) = -0.0024\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6189\n",
      "TE(Y->X) = 0.0027\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6256\n",
      "TE(Y->X) = -0.0027\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6201\n",
      "TE(Y->X) = -0.0001\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6151\n",
      "TE(Y->X) = -0.003\n",
      "\n",
      "### REPLICATE 5/5 ###\n",
      "\n",
      "## Dim =  1 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.4148\n",
      "TE(Y->X) = 0.0022\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.4086\n",
      "TE(Y->X) = 0.0005\n",
      "## Dim =  2 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6777\n",
      "TE(Y->X) = 0.0028\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.664\n",
      "TE(Y->X) = 0.0003\n",
      "## Dim =  3 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.7344\n",
      "TE(Y->X) = -0.0006\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7233\n",
      "TE(Y->X) = -0.0003\n",
      "## Dim =  4 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.732\n",
      "TE(Y->X) = 0.002\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.7144\n",
      "TE(Y->X) = 0.0013\n",
      "## Dim =  5 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6977\n",
      "TE(Y->X) = -0.0013\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6889\n",
      "TE(Y->X) = -0.0006\n",
      "## Dim =  6 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6721\n",
      "TE(Y->X) = 0.0021\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6723\n",
      "TE(Y->X) = -0.002\n",
      "## Dim =  7 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6521\n",
      "TE(Y->X) = 0.0044\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6534\n",
      "TE(Y->X) = -0.0018\n",
      "## Dim =  8 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.63\n",
      "TE(Y->X) = 0.0027\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6404\n",
      "TE(Y->X) = -0.0013\n",
      "## Dim =  9 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.6194\n",
      "TE(Y->X) = -0.0044\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6321\n",
      "TE(Y->X) = -0.0019\n",
      "## Dim =  10 #\n",
      "# Sample size =  10000 #\n",
      "TE(X->Y) = 0.609\n",
      "TE(Y->X) = -0.007\n",
      "# Sample size =  100000 #\n",
      "TE(X->Y) = 0.6187\n",
      "TE(Y->X) = 0.0008\n"
     ]
    }
   ],
   "source": [
    "# Initialize the list of generators with one for each dimension\n",
    "jp_generator_lst = [MVJointProcessSimulator(n_dim=dim) 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]\n",
    "\n",
    "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_knnksg(X, Y)\n",
    "            print(f\"TE(X->Y) = {TE_X2Y}\")\n",
    "            jp_results_TE_X2Y.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_X2Y)\n",
    "            # Estimate Y -> X\n",
    "            TE_Y2X =TE_knnksg(Y, X)\n",
    "            print(f\"TE(Y->X) = {TE_Y2X}\")\n",
    "            jp_results_TE_Y2X.write(method='knnksg', n_dim=dim, sample_size=samples, value=TE_Y2X)\n",
    "\n",
    "jp_results_TE_X2Y.df.to_csv('results/knnksg/jp_results_TE_X2Y_dim.csv', index=False)\n",
    "jp_results_TE_Y2X.df.to_csv('results/knnksg/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
}
