{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "593fe148-16e1-4da5-91b4-ee8506473b05",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.utils.data import Dataset\n",
    "from torch.distributions import MultivariateNormal\n",
    "import numpy as np\n",
    "from all_estimators import *\n",
    "np.random.seed(42)\n",
    "import random \n",
    "random.seed(42)\n",
    "import argparse\n",
    "from scipy import stats\n",
    "from mi_utils import *\n",
    "from estimator_lib import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "c2a091df-0625-43f3-8235-0d3aa6d41ba7",
   "metadata": {},
   "outputs": [],
   "source": [
    "params_dict = {\n",
    "  \"concat_self\": [20],\n",
    "  \"randmat\": [],\n",
    "   \"cube\": [],\n",
    "   \"concat_self_noisy\": [20,0.2],\n",
    "   \"sigmoid\": [],\n",
    "    \"scale\": [],\n",
    "}\n",
    "# estimators = [KSG_est,KSG_local_est,KSG_global_est_infnorm,revised_KSG_est]\n",
    "estimators = [mine_est,mine_est_local,mine_est_global,mine_est_global_nocorrection]\n",
    "names = ['MINE','MINE-Local','MINE-Global-Corrected','MINE-Global']\n",
    "# SNR_range = np.linspace(5,0.1,20)\n",
    "dim_range = np.arange(0,200,10)\n",
    "# names = ['KSG','KSG-Local','KSG-Global-$L_{\\infty}$','BI-KSG']\n",
    "output_list = [[] for x in estimators]\n",
    "true_mi_list = [] \n",
    "mean_list = [[] for x in dim_range]\n",
    "trials = 10\n",
    "N = 1000\n",
    "dim = 2\n",
    "transforms_x = ['concat_self_noisy']\n",
    "transforms_y = ['none']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "ea6bd437-acc7-4ceb-a76f-3942f6531225",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n"
     ]
    }
   ],
   "source": [
    "for k in range(len(dim_range)):\n",
    "    print(k)\n",
    "    output_list = [[] for x in estimators]\n",
    "    params_dict['concat_self_noisy']= [dim_range[k],0.2]\n",
    "    for i in range(trials):    \n",
    "        dataset = GaussianAdditionDataset(N, dim, 2 ,params_dict,transforms_x,transforms_y)\n",
    "        # print(\"True MI:\", dataset.true_mi)\n",
    "        # print('LNC:',estimators[-1](dataset.x,dataset.y))\n",
    "        for temp in range(len(estimators)):\n",
    "            E = estimators[temp](dataset.x,dataset.y)\n",
    "            output_list[temp].append(E)\n",
    "    \n",
    "    true_mi_list.append(dataset.true_mi)\n",
    "    \n",
    "    for temp in range(len(estimators)):\n",
    "        mean_list[k].append(np.mean(output_list[temp]))\n",
    "        # diff_arr = np.array(output_list[temp])-np.mean(output_list[temp])\n",
    "    # print(mean_list[k])\n",
    "        # uppers[k].append(np.average(np.array(output_list[temp]),weights=(diff_arr>=0).astype('float')))\n",
    "        # lowers[k].append(np.average(np.array(output_list[temp]),weights=(diff_arr<=0).astype('float')))\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "9de9d631-b57c-450c-b763-1d6d9ff7c1a4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "import matplotlib\n",
    "import scipy\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\"\n",
    "matplotlib.rcParams.update({'font.size': 17})\n",
    "\n",
    "mean_list = np.array(mean_list)\n",
    "\n",
    "for temp in range(len(estimators)):\n",
    "    filt = scipy.signal.savgol_filter(mean_list[:,temp], 10, 2)\n",
    "    plt.plot(dim_range,mean_list[:,temp],label=names[temp])\n",
    "    # ups = uppers[:,temp] - mean_list[:,temp]\n",
    "    # downs = mean_list[:,temp] - lowers[:,temp]\n",
    "    # plt.errorbar(np.log10(scale_range),mean_list[:,temp], yerr=[downs,ups], capsize=5,  ecolor = \"black\")\n",
    "    # plt.fill_between(np.log10(scale_range),lowers[:,temp],uppers[:,temp])\n",
    "plt.plot(dim_range,true_mi_list,linestyle='--',color='black',label='True MI')\n",
    "plt.legend(fontsize=14,handlelength=1,framealpha=0)\n",
    "plt.grid(linestyle='--')\n",
    "plt.xlabel('# Noise-Dimensions',fontsize=24)\n",
    "plt.ylabel('Average MI Estimates',fontsize=24)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('MINE_noise_dimension_new.png',bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9675cccd-0b67-4ce9-b710-53b8ba391ce8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.32037492, 0.27718593, 0.32457326, 0.26692341],\n",
       "       [0.401359  , 0.39604954, 0.38851777, 0.32949089],\n",
       "       [0.43766331, 0.41995806, 0.42557957, 0.39892336],\n",
       "       [0.4240395 , 0.44522429, 0.44619207, 0.39639274],\n",
       "       [0.37318656, 0.42975107, 0.4014616 , 0.38064523],\n",
       "       [0.38945666, 0.37389135, 0.40625595, 0.39524089],\n",
       "       [0.43888758, 0.42329823, 0.4279525 , 0.4105435 ],\n",
       "       [0.43149513, 0.50539668, 0.37986643, 0.40320094],\n",
       "       [0.47367049, 0.42421194, 0.43044537, 0.34754334],\n",
       "       [0.36991796, 0.45938089, 0.40764806, 0.37687842]])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4b5fd4e0-d37b-4cba-ad3f-dc0c8be05e13",
   "metadata": {},
   "outputs": [],
   "source": [
    "names = ['MINE','MINE-Local','MINE-Global-Corrected','MINE-Global']\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
