{
 "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": 2,
   "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.8],\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,30,3)\n",
    "# names = ['KSG','KSG-Local','KSG-Global-$L_{\\infty}$','BI-KSG']\n",
    "output_list = [[] for x in estimators]\n",
    "true_mi_list = [] \n",
    "dim_range = np.arange(1,30,3)\n",
    "mean_list = [[] for x in dim_range]\n",
    "bias_prop = [[] for x in dim_range]\n",
    "\n",
    "trials = 10\n",
    "N = 1000\n",
    "dim = 2\n",
    "transforms_x = ['concat_self_noisy']\n",
    "transforms_y = ['none']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "54fa6801-5b7a-4fca-b23e-bf1df65d84a4",
   "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",
    "    true_mi_list = []\n",
    "    params_dict['concat_self_noisy']= [dim_range[k],0.05]\n",
    "    for i in range(trials):\n",
    "        rho = 0.2\n",
    "        dataset = MultivariateNormalDataset(N, 2, rho,params_dict,transforms_x,transforms_y)\n",
    "        # print(\"True MI:\", dataset.true_mi)\n",
    "        true_mi_list.append(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",
    "    for temp in range(len(estimators)):\n",
    "        mean_list[k].append(np.mean(output_list[temp]))\n",
    "        diff_arr = np.array(true_mi_list) - np.mean(output_list[temp])\n",
    "        bias_prop[k].append(np.mean(diff_arr))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c30a26c8-7a10-4302-a220-b4b8e3c847b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 1,  4,  7, 10, 13, 16, 19, 22, 25, 28])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dim_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "82341d04-6117-4792-9d58-6e83cb3506df",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 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",
    "fig, axs = plt.subplots(1, 1,figsize=(5, 5))\n",
    "plt.rc('axes', labelsize=24)\n",
    "\n",
    "mean_list = np.array(mean_list)\n",
    "bias_prop = np.array(bias_prop)\n",
    "# uppers = np.array(uppers)\n",
    "# lowers = np.array(lowers)\n",
    "\n",
    "color_arr = ['#1f77b4','#ff7f0e']\n",
    "\n",
    "for temp in range(len(estimators)):\n",
    "    X = np.array(dim_range)\n",
    "    Y = bias_prop[:,temp]\n",
    "    filt = scipy.signal.savgol_filter(Y, 8, 2)\n",
    "    # filt = scipy.signal.savgol_filter(Y, 10, 3)\n",
    "    # axs[0].bar(X-0.2+ 0.2*temp,Y,width=0.2,color=color_arr[temp],label=names[temp],align='center')\n",
    "    axs.plot(X,-filt,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",
    "axs.plot(dim_range,np.zeros_like(dim_range),linestyle='--',color='black',label='Zero Bias')\n",
    "axs.legend(fontsize=14,handlelength=1,framealpha=0)\n",
    "axs.grid(linestyle='--')\n",
    "axs.set( xlabel='$d$ ')\n",
    "axs.set(ylabel='Bias')\n",
    "axs.set_xticks([1,10,20,30])\n",
    "# axs.set_yticks([0,25,50,75,100])\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "# plt.tight_layout()\n",
    "# fig.savefig('MINE_bias_with_local_and_noisecat.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
}
