{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "84170344",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, '../Results')\n",
    "sys.path.insert(0, '../../src')\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "import os\n",
    "from visualization_utils import perc, SetPlotRC, ApplyFont"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "870eafd0",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists(\"Figures\"):\n",
    "    os.mkdir(\"Figures\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "492d95fd",
   "metadata": {},
   "source": [
    "# Ablation : NN-Sparse Zeta Selection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "674f97af",
   "metadata": {},
   "outputs": [],
   "source": [
    "dfzeta = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_zetaV5.pkl\")\n",
    "dfzeta = dfzeta.iloc[:4*(dfzeta.shape[0]//4)]\n",
    "results = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9065dddd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Model</th>\n",
       "      <th>zeta</th>\n",
       "      <th>count</th>\n",
       "      <th>mean_sent</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.000001</td>\n",
       "      <td>50</td>\n",
       "      <td>15.747426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>50</td>\n",
       "      <td>19.141185</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.000100</td>\n",
       "      <td>50</td>\n",
       "      <td>24.702122</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.001000</td>\n",
       "      <td>50</td>\n",
       "      <td>14.778471</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Model      zeta  count  mean_sent\n",
       "0   WSM  0.000001     50  15.747426\n",
       "1   WSM  0.000010     50  19.141185\n",
       "2   WSM  0.000100     50  24.702122\n",
       "3   WSM  0.001000     50  14.778471"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "46bec25f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Font family ['Times New Roman'] not found. Falling back to DejaVu Sans.\n",
      "findfont: Font family ['Times New Roman'] not found. Falling back to DejaVu Sans.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data= []\n",
    "zeta_list = [1e-3, 1e-4, 1e-5, 1e-6]\n",
    "for zeta__ in zeta_list:\n",
    "    data.append(dfzeta.loc[dfzeta['zeta'] == zeta__]['SINR'].values.tolist())\n",
    "    \n",
    "data = np.stack(data, axis = 1)\n",
    "\n",
    "# compute the mean, 25/75 percentiles, and standard deviation\n",
    "med, perc_25, perc_75, std_data = perc(data)\n",
    "\n",
    "SINRresults = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()\n",
    "zeta = np.array(SINRresults['zeta'].values, dtype = np.float64)\n",
    "SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "SetPlotRC()\n",
    "fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "plt.semilogx(zeta, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "plt.fill_between(zeta, np.flipud(perc_25), np.flipud(perc_75), alpha=0.25, linewidth=0, color='#006BB2')\n",
    "plt.grid()\n",
    "plt.xlabel(\"zeta\")\n",
    "plt.ylabel(\"SINR\")\n",
    "\n",
    "plt.grid(linewidth=2)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.axis([1e-6 - 3e-8,1e-3 + 3e-8,10,27.4])\n",
    "plt.ylabel('SINR (dB)',fontsize=25)\n",
    "plt.xlabel(r'$1 - \\lambda_{SM}$',fontsize=25)\n",
    "ApplyFont(plt.gca())\n",
    "plt.savefig('Figures/zeta_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c65df42a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfzeta = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_zetaV1.pkl\")\n",
    "# dfzeta = dfzeta.iloc[:4*(dfzeta.shape[0]//4)]\n",
    "# results = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "49f1e980",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5aee9610",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# zeta_list = [1e-3, 1e-4, 1e-5, 1e-6]\n",
    "# for zeta__ in zeta_list:\n",
    "#     data.append(dfzeta.loc[dfzeta['zeta'] == zeta__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the mean, 25/75 percentiles, and standard deviation\n",
    "# med, perc_25, perc_75, std_data = perc(data)\n",
    "\n",
    "# SINRresults = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['zeta'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.semilogx(zeta, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(zeta, np.flipud(perc_25), np.flipud(perc_75), alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "# plt.xlabel(\"zeta\")\n",
    "# plt.ylabel(\"SINR\")\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([1e-6 - 3e-8,1e-3 + 3e-8,10,25.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$1 - \\lambda_{SM}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/zeta_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0692ee07",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfzeta = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_zetaV2.pkl\")\n",
    "# dfzeta = dfzeta.iloc[:4*(dfzeta.shape[0]//4)]\n",
    "# results = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f7db21b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a35bed84",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# zeta_list = [1e-3, 1e-4, 1e-5, 1e-6]\n",
    "# for zeta__ in zeta_list:\n",
    "#     data.append(dfzeta.loc[dfzeta['zeta'] == zeta__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the mean, 25/75 percentiles, and standard deviation\n",
    "# med, perc_25, perc_75, std_data = perc(data)\n",
    "\n",
    "# SINRresults = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['zeta'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.semilogx(zeta, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(zeta, np.flipud(perc_25), np.flipud(perc_75), alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "# plt.xlabel(\"zeta\")\n",
    "# plt.ylabel(\"SINR\")\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([1e-6 - 3e-8,1e-3 + 3e-8,10,25.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$1 - \\lambda_{SM}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/zeta_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "741e0943",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfzeta = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_zetaV3.pkl\")\n",
    "# dfzeta = dfzeta.iloc[:4*(dfzeta.shape[0]//4)]\n",
    "# results = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9473f17c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "f605478a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# zeta_list = [1e-3, 1e-4, 1e-5, 1e-6]\n",
    "# for zeta__ in zeta_list:\n",
    "#     data.append(dfzeta.loc[dfzeta['zeta'] == zeta__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the mean, 25/75 percentiles, and standard deviation\n",
    "# med, perc_25, perc_75, std_data = perc(data)\n",
    "\n",
    "# SINRresults = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['zeta'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.semilogx(zeta, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(zeta, np.flipud(perc_25), np.flipud(perc_75), alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "# plt.xlabel(\"zeta\")\n",
    "# plt.ylabel(\"SINR\")\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([1e-6 - 3e-8,1e-3 + 3e-8,10,25.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$1 - \\lambda_{SM}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/zeta_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "baee64c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfzeta = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_zetaV4.pkl\")\n",
    "# dfzeta = dfzeta.iloc[:4*(dfzeta.shape[0]//4)]\n",
    "# results = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b5f7ae71",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "7b02e7cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# zeta_list = [1e-3, 1e-4, 1e-5, 1e-6]\n",
    "# for zeta__ in zeta_list:\n",
    "#     data.append(dfzeta.loc[dfzeta['zeta'] == zeta__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the mean, 25/75 percentiles, and standard deviation\n",
    "# med, perc_25, perc_75, std_data = perc(data)\n",
    "\n",
    "# SINRresults = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['zeta'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.semilogx(zeta, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(zeta, np.flipud(perc_25), np.flipud(perc_75), alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "# plt.xlabel(\"zeta\")\n",
    "# plt.ylabel(\"SINR\")\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([1e-6 - 3e-8,1e-3 + 3e-8,10,26.9])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$1 - \\lambda_{SM}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/zeta_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "5475bbec",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfzeta = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_zetaV5.pkl\")\n",
    "# dfzeta = dfzeta.iloc[:4*(dfzeta.shape[0]//4)]\n",
    "# results = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9f43a4ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "ca2c7613",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# zeta_list = [1e-3, 1e-4, 1e-5, 1e-6]\n",
    "# for zeta__ in zeta_list:\n",
    "#     data.append(dfzeta.loc[dfzeta['zeta'] == zeta__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the mean, 25/75 percentiles, and standard deviation\n",
    "# med, perc_25, perc_75, std_data = perc(data)\n",
    "\n",
    "# SINRresults = dfzeta[['Model', 'zeta', 'SINR']].groupby(['Model', 'zeta']).agg({'zeta':'size', 'SINR':'mean'}).rename(columns={'zeta':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['zeta'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.semilogx(zeta, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(zeta, np.flipud(perc_25), np.flipud(perc_75), alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "# plt.xlabel(\"zeta\")\n",
    "# plt.ylabel(\"SINR\")\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([1e-6 - 3e-8,1e-3 + 3e-8,10,27.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$1 - \\lambda_{SM}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# plt.savefig('Figures/zeta_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d803a017",
   "metadata": {},
   "source": [
    "# Ablation : NN-Sparse Initial D1 Gain "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "31c0bd2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "dfD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_initalD1_V3.pkl\")\n",
    "dfD1 = dfD1.iloc[:4*(dfD1.shape[0]//4)]\n",
    "results = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "43034972",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Model</th>\n",
       "      <th>D1</th>\n",
       "      <th>count</th>\n",
       "      <th>mean_sent</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>WSM</td>\n",
       "      <td>4</td>\n",
       "      <td>50</td>\n",
       "      <td>24.953703</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>WSM</td>\n",
       "      <td>8</td>\n",
       "      <td>50</td>\n",
       "      <td>23.690106</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>WSM</td>\n",
       "      <td>12</td>\n",
       "      <td>50</td>\n",
       "      <td>23.346324</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>WSM</td>\n",
       "      <td>16</td>\n",
       "      <td>50</td>\n",
       "      <td>23.345519</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Model  D1  count  mean_sent\n",
       "0   WSM   4     50  24.953703\n",
       "1   WSM   8     50  23.690106\n",
       "2   WSM  12     50  23.346324\n",
       "3   WSM  16     50  23.345519"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5bbf3376",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsYAAAG7CAYAAADAPFM3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAxOAAAMTgF/d4wjAABZK0lEQVR4nO3deXxcZ3n3/881m/bV8hbbsuyszmondhKHkARCAhQSQgh7gRQIBMLyNA0PbaFPU6CUH0taeAolaaCBhvYJJRCgrKEBsjmJQ5yF7ImXOPFuS7KtXZrr98c5skayRjOSRpoz0vf9es1rzpmzzC3Jx/rqnuvct7k7IiIiIiKzXazYDRARERERiQIFYxERERERFIxFRERERAAFYxERERERQMFYRERERARQMBYRERERARSMRUREREQASBS7AVGUTCZ93rx5mFmxmyISee5OT08PAGVlZbpuRPKka0dkYgavnb179/a6e1khz61gPIq6ujqee+45Kioqit0Ukcjr6uri17/+NQAXXnihrhuRPOnaEZmYwWvnkksu2V3oc6uUQkREREQEBWMREREREUDBWEREREQEUDAWEREREQEUjEVEREREAAVjERERERFAwVhEREREBFAwFhEREREBFIxFRERERAAFYxERERERIELB2MySZna+mX3JzNabWZuZ9ZnZDjP7iZm9Lstxnufj3dP9NYmIiIhI6UgUuwEZzgVuD5d3AHcDHcDxwEXARWZ2A3Clu3vGcd8Z45zNwCsAB35f8BaLiIiIyIwRpWCcBm4Fvurud2VuMLO3At8DPgDcA3x3cJu7X57thGb2DYJg/Bt33zIFbRYRERGRGSIypRTufoe7XzYyFIfbbgFuClfzKokws3Lg7eHqtwrSSBERERGZsSITjPOwIXxekuf+bwLqgX3AbVPQHhERERGZQaJUSpHL0eHz9jz3f2/4fLO794z3zbq7u8d7iMislHmt6LoRyZ+uHZGJmcrrpSSCsZktAC4PV2/NY/8WgtpimGAZxZ133jmRw0RmNV03IhOja0ckGiJfSmFmCeBmoA54DLg+j8P+DDDgQXd/NI/3uNrMXhx8dHV1TarNIiIiIlJ6SqHH+JvA+cBe4DJ37x1rZzOLMdS7/O183sDdrwOuG1xvamryqpaTiSVSE2rw8PZAIh4jFYuRTBipeIxkPEYqYSQHX4vFSCZi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bxhlt41ZlkfbZ2HhWiciIiIiM00kg7GZfRG4GmgnCMXZxiF+hqFe46Ys+wy+fjDLdhERERGR6AVjM/sC8AmCUHyBu6/Ptq+79xPMegdBqcRoLgifHyhUG0VERERk5olUMDazzwGfJCifGDMUZ/g80AdcYWavH3G+TwBnE4xz/PXCtlZEREREZpLI3HxnZhcDnwpXnwOuMrPRdt3j7tcMrrj7U2Z2BfBt4Kdm9iCwGTgROI4gFH/I3R+bwuaLiIiISImLTDAmGIt40OrwMZotwDWZL7j7d8zsCYLe5pcTzIa3F/gv4MvurjIKERERERlTZIKxu98E3DSJ49cDlxWqPSIiIiIyu0SqxlhEREREpFgUjEVEREREUDAWEREREQEUjEVEREREAAVjERERERFAwVhEREREBFAwFhEREREBFIxFRERERAAFYxERERERQMFYRERERARQMBYRERERARSMRUREREQABWMREREREUDBWEREREQEUDAWEREREQEUjEVEREREAAVjERERERFAwVhEREREBFAwFhEREREBFIxFRERERAAFYxERERERQMFYRERERARQMBYRERERARSMRUREREQABWMREREREUDBWEREREQEUDAWEREREQEUjEVEREREAAVjERERERFAwVhEREREBFAwFhEREREBFIxFRERERIAIBWMzS5rZ+Wb2JTNbb2ZtZtZnZjvM7Cdm9rosx11rZp7jcdx0fz0iIiIiUloSxW5AhnOB28PlHcDdQAdwPHARcJGZ3QBc6e4+yvGPAA9nOXf7eBrSl4Ynd3awfF6CilR8PIeKiIiISImKUjBOA7cCX3X3uzI3mNlbge8BHwDuAb47yvG3ufu1hWjI/l748x8/gwGvXjGXS09ZSMucykKcWkREREQiKjKlFO5+h7tfNjIUh9tuAW4KV989He3pG3B6B5xfPLGb9//no3z/oW3T8bYiIiIiUiRR6jHOZUP4vGQ637Q/HVRt3LjuBczgzauOmM63FxEREZFpUkrB+OjweXuW7aea2ReARoKa4g3AT939QCHevG/Auf7uLZx2RCUtjRWFOKXIjJDu7x11WUTGpmtHZGKm8nopiWBsZguAy8PVW7PsdlH4yNRuZh9z99FqksffDpzv3/MEH1ox2r1/ItKx+dFiN0GkJOnaEYmGyNQYZ2NmCeBmoA54DLh+xC7PA38N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+BjL3xFMxV2Qthfi+zjiXOcDvwCOA94UPka6B7g42yQgIrOZgrFIdBwDZBuF4QBBL+k+4FHgLuAOd980TW0bTUFvvBuNu//IzH4KvBF4NbAWmEdQNtFJMILFYwS9X7dk+364+8NmthL4K+C1BL3QB4DnCGYB+7q7dwefNMs4/CVBScG7CXrs6xjnmLal/LMpYNsn/X3MaNNmMzsFuIIglJ9IcCPrPoJr8nvAf7h7OvtZRGYvG/umWxGZaczsL4F/YJIz35nZfxLM9rUos4c22+siIiJRp5vvROQwZva7cBzi88bYbSVBveXI8JvtdRERkUhTKYXILGBm72doMoLBOub3ZwTfu939xoxDBv9o7s9yvkqC0o/b83ldRESkFCgYi8wOZ3P4ZBkvY/jd8jfCoSGdTgA2A/dlOd/gRCQP5/m6iIhI5KnGWESGCYeqegy4yt2/Uez2iIiITBfVGIvISC8nmP3r28VuiIiIyHRSj7GIiIiICOoxFhEREREBFIxFRERERAAFYxERERERQMFYRERERARQMBYRERERARSMRUREREQABWMREREREUDBWEREREQEUDAWEREREQEUjEVEREREAPj/AeA2agvj5B1zAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data= []\n",
    "D1list = [4,8,12,16]\n",
    "for d1start__ in D1list:\n",
    "    data.append(dfD1.loc[dfD1['D1'] == d1start__]['SINR'].values.tolist())\n",
    "    \n",
    "data = np.stack(data, axis = 1)\n",
    "\n",
    "# compute the medians and 25/75 percentiles\n",
    "med, perc_25, perc_75, _ = perc(data)\n",
    "perc_25\n",
    "\n",
    "SINRresults = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()\n",
    "zeta = np.array(SINRresults['D1'].values, dtype = np.float64)\n",
    "SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "SetPlotRC()\n",
    "fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "plt.plot(D1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "plt.fill_between(D1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "plt.grid()\n",
    "\n",
    "plt.grid(linewidth=2)\n",
    "plt.xticks(D1list, fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.axis([4,16,20,27.4])\n",
    "plt.ylabel('SINR (dB)',fontsize=25)\n",
    "plt.xlabel(r'$D_{1,ii}$ Gain Initialization',fontsize=25)\n",
    "ApplyFont(plt.gca())\n",
    "plt.savefig('Figures/D1start_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "59643125",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_initalD1_V1.pkl\")\n",
    "# dfD1 = dfD1.iloc[:4*(dfD1.shape[0]//4)]\n",
    "# results = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "d48fb8f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "50e8cd53",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# D1list = [4,8,12,16]\n",
    "# for d1start__ in D1list:\n",
    "#     data.append(dfD1.loc[dfD1['D1'] == d1start__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['D1'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(D1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(D1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "# plt.xlabel(\"zeta\")\n",
    "# plt.ylabel(\"SINR\")\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([4,16,20,26.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$D_{1,ii}$ Gain Initialization',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/D1start_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "472ea22d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_initalD1_V2.pkl\")\n",
    "# dfD1 = dfD1.iloc[:4*(dfD1.shape[0]//4)]\n",
    "# results = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "623abcd4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "fce77511",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# D1list = [4,8,12,16]\n",
    "# for d1start__ in D1list:\n",
    "#     data.append(dfD1.loc[dfD1['D1'] == d1start__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['D1'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(D1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(D1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([4,16,20,27.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$D_{1,ii}$ Gain Initialization',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/D1start_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "ef17c4d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_initalD1_V3.pkl\")\n",
    "# dfD1 = dfD1.iloc[:4*(dfD1.shape[0]//4)]\n",
    "# results = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "8002f137",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "2a7d74c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# D1list = [4,8,12,16]\n",
    "# for d1start__ in D1list:\n",
    "#     data.append(dfD1.loc[dfD1['D1'] == d1start__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfD1[['Model', 'D1', 'SINR']].groupby(['Model', 'D1']).agg({'D1':'size', 'SINR':'mean'}).rename(columns={'D1':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['D1'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(D1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(D1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(D1list, fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([4,16,20,27.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$D_{1,ii}$ Gain Initialization',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# plt.savefig('Figures/D1start_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f1071325",
   "metadata": {},
   "source": [
    "# Ablation : NN-Sparse $\\mu_{D_1}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "e5955088",
   "metadata": {},
   "outputs": [],
   "source": [
    "dfmuD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_muD1_V2.pkl\")\n",
    "dfmuD1 = dfmuD1.iloc[:4*(dfmuD1.shape[0]//4)]\n",
    "\n",
    "results = dfmuD1[['Model', 'muD1', 'SINR']].groupby(['Model', 'muD1']).agg({'muD1':'size', 'SINR':'mean'}).rename(columns={'muD1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "fba1255a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Model</th>\n",
       "      <th>muD1</th>\n",
       "      <th>count</th>\n",
       "      <th>mean_sent</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>WSM</td>\n",
       "      <td>5</td>\n",
       "      <td>50</td>\n",
       "      <td>24.744364</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>WSM</td>\n",
       "      <td>10</td>\n",
       "      <td>50</td>\n",
       "      <td>24.571835</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>WSM</td>\n",
       "      <td>15</td>\n",
       "      <td>50</td>\n",
       "      <td>25.329096</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>WSM</td>\n",
       "      <td>20</td>\n",
       "      <td>50</td>\n",
       "      <td>24.190472</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Model  muD1  count  mean_sent\n",
       "0   WSM     5     50  24.744364\n",
       "1   WSM    10     50  24.571835\n",
       "2   WSM    15     50  25.329096\n",
       "3   WSM    20     50  24.190472"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "c0c994d7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7BbcT50SfsNf2KJRItFFH65UAH3miJSHsg3GZvYp4H1AL3C5u++a/YhJ6Yvubnf3vmKMTcqXO4yMp3JaejY+JThnW+I7eKwFVZandPgdzFzaOLw/PJ7KEn5FRKTSlWUwNrNPANcBfQSheEeOx7UAV4UPl1TvYim8dD9o5uhZEota1gVUpq9MqH7QlcfdGR6bNuOr8CsismyVXTA2s48DHyAIxZe5+/15HP52oBp4lhItAS1Lz/iEMz6RWz/oqcE5+wIrcQXoRZUZfqfM/o5NMDw2gSv7iohIqKyCsZl9DPggJ8sn8gnFcLKM4p/c9XEniyuV8mC2kdkDdGYddPYZ6IjqoPPk7jPW+yr8iohIrsomGJvZlcCHwofPAO+dIRR0u/v1WY7fAmwGJoBbizNKkYXLrIM+Mct+6QVVps5ARydLNzKD9XKog06lnOHxIPwOjk1MljwMjaUYGVf4FRGRhSubYAy0ZNzfHn5lsw84JRhzcrb4e+5+oJADEymFybXjx3Ovg85WupHuyFEJddCplGet91X4FRGRxVA2wdjdb2UBM73u/ofAHxZqPCKVJNc66GjEsgRnO6WUo5h10JnhN6j5Tbc9m8ipm4iIiEixlE0wFpHim8izDro6nl5EJVtNtM24oMpEOvxOu9hN4VdERMqZgrGInCLXftBmEEmNTT5+9MBxxmwoKP8QERGpMArGIjJv7jCWEYJPDI8TiWtpNxERqUzlfSWOiIiIiMgiUTAWEREREUHBWEREREQEUDAWEREREQEUjEVEREREAAVjERERERFAwVhEREREBFAwFhEREREBFIxFRERERAAFYxERERERQMFYRERERARQMBYRERERARSMRUREREQABWMREREREUDBWEREREQEUDAWEREREQEUjEVEREREAAVjERERERFAwVhEREREBFAwFhEREREBFIxFRERERAAFYxERERERQMFYRERERARQMBYRERERARSMRUREREQABWMREREREUDBWEREREQEUDAWEREREQEUjEVEREREgDIKxmYWN7NLzeyTZna/mfWa2ZiZdZnZHWb2ujmOj5jZb5rZD8zsiJmNmNlBM7vLzH5/sb4PEREREalMsVIPIMMrgTvD+13APcAAcC5wBXCFmd0MvMfdPfNAM2sE7gAuAY4DPwF6gXXAFqAB+EzxvwURERERqVTlFIxTwO3A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\n",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data= []\n",
    "muD1list = [5,10,15,20]\n",
    "for muD1__ in muD1list:\n",
    "    data.append(dfmuD1.loc[dfmuD1['muD1'] == muD1__]['SINR'].values.tolist())\n",
    "    \n",
    "data = np.stack(data, axis = 1)\n",
    "\n",
    "# compute the medians and 25/75 percentiles\n",
    "med, perc_25, perc_75, _ = perc(data)\n",
    "perc_25\n",
    "\n",
    "SINRresults = dfmuD1[['Model', 'muD1', 'SINR']].groupby(['Model', 'muD1']).agg({'muD1':'size', 'SINR':'mean'}).rename(columns={'muD1':'count','SINR':'mean_sent'}).reset_index()\n",
    "zeta = np.array(SINRresults['muD1'].values, dtype = np.float64)\n",
    "SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "SetPlotRC()\n",
    "fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "plt.plot(muD1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "plt.fill_between(muD1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "plt.grid()\n",
    "\n",
    "plt.grid(linewidth=2)\n",
    "plt.xticks(muD1list, fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.axis([4.99,20.01,20,27.4])\n",
    "plt.ylabel('SINR (dB)',fontsize=25)\n",
    "plt.xlabel(r'$\\mu_{D_{1}}$',fontsize=25)\n",
    "ApplyFont(plt.gca())\n",
    "plt.savefig('Figures/muD1_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "b678371c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfmuD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_muD1_V1.pkl\")\n",
    "# dfmuD1 = dfmuD1.iloc[:4*(dfmuD1.shape[0]//4)]\n",
    "# results = dfmuD1[['Model', 'muD1', 'SINR']].groupby(['Model', 'muD1']).agg({'muD1':'size', 'SINR':'mean'}).rename(columns={'muD1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "b3128f17",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "c5afb725",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# muD1list = [5,10,15,20]\n",
    "# for muD1__ in muD1list:\n",
    "#     data.append(dfmuD1.loc[dfmuD1['muD1'] == muD1__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfmuD1[['Model', 'muD1', 'SINR']].groupby(['Model', 'muD1']).agg({'muD1':'size', 'SINR':'mean'}).rename(columns={'muD1':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['muD1'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(muD1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(muD1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([4.99,20.01,19,26.9])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$\\mu_{D_{1}}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/muD1_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "3c3f4bc3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfmuD1 = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_muD1_V2.pkl\")\n",
    "# dfmuD1 = dfmuD1.iloc[:4*(dfmuD1.shape[0]//4)]\n",
    "\n",
    "# results = dfmuD1[['Model', 'muD1', 'SINR']].groupby(['Model', 'muD1']).agg({'muD1':'size', 'SINR':'mean'}).rename(columns={'muD1':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "90b6aab1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "833175d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# muD1list = [5,10,15,20]\n",
    "# for muD1__ in muD1list:\n",
    "#     data.append(dfmuD1.loc[dfmuD1['muD1'] == muD1__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfmuD1[['Model', 'muD1', 'SINR']].groupby(['Model', 'muD1']).agg({'muD1':'size', 'SINR':'mean'}).rename(columns={'muD1':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['muD1'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(muD1list, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(muD1list, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(muD1list, fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([4.99,20.01,20,27.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$\\mu_{D_{1}}$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# plt.savefig('Figures/muD1_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "acbb7b0d",
   "metadata": {},
   "source": [
    "# Ablation : NN-Sparse $1 - \\gamma^2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "3adf6107",
   "metadata": {},
   "outputs": [],
   "source": [
    "dfMUS = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_MUS_V2.pkl\")\n",
    "dfMUS = dfMUS.iloc[:4*(dfMUS.shape[0]//4)]\n",
    "results = dfMUS[['Model', 'MUS', 'SINR']].groupby(['Model', 'MUS']).agg({'MUS':'size', 'SINR':'mean'}).rename(columns={'MUS':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "8e633513",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Model</th>\n",
       "      <th>MUS</th>\n",
       "      <th>count</th>\n",
       "      <th>mean_sent</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.15</td>\n",
       "      <td>50</td>\n",
       "      <td>22.942421</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.20</td>\n",
       "      <td>50</td>\n",
       "      <td>24.499475</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.25</td>\n",
       "      <td>50</td>\n",
       "      <td>25.329096</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>WSM</td>\n",
       "      <td>0.30</td>\n",
       "      <td>50</td>\n",
       "      <td>24.285949</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Model   MUS  count  mean_sent\n",
       "0   WSM  0.15     50  22.942421\n",
       "1   WSM  0.20     50  24.499475\n",
       "2   WSM  0.25     50  25.329096\n",
       "3   WSM  0.30     50  24.285949"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "e314f103",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 800x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data= []\n",
    "MUSlist = [0.15, 0.20, 0.25, 0.3]\n",
    "for MUS__ in MUSlist:\n",
    "    data.append(dfMUS.loc[dfMUS['MUS'] == MUS__]['SINR'].values.tolist())\n",
    "    \n",
    "data = np.stack(data, axis = 1)\n",
    "\n",
    "# compute the medians and 25/75 percentiles\n",
    "med, perc_25, perc_75, _ = perc(data)\n",
    "perc_25\n",
    "\n",
    "SINRresults = dfMUS[['Model', 'MUS', 'SINR']].groupby(['Model', 'MUS']).agg({'MUS':'size', 'SINR':'mean'}).rename(columns={'MUS':'count','SINR':'mean_sent'}).reset_index()\n",
    "zeta = np.array(SINRresults['MUS'].values, dtype = np.float64)\n",
    "SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "SetPlotRC()\n",
    "fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "plt.plot(MUSlist, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "plt.fill_between(MUSlist, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "plt.grid()\n",
    "\n",
    "plt.grid(linewidth=2)\n",
    "plt.xticks(MUSlist, fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.axis([0.1499,0.3001,20,27.4])\n",
    "plt.ylabel('SINR (dB)',fontsize=25)\n",
    "plt.xlabel(r'Initial selection of $1 - \\gamma^2$',fontsize=25)\n",
    "\n",
    "ApplyFont(plt.gca())\n",
    "plt.savefig('Figures/MUS_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "3c443c4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfMUS = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_MUS_V1.pkl\")\n",
    "# dfMUS = dfMUS.iloc[:4*(dfMUS.shape[0]//4)]\n",
    "# results = dfMUS[['Model', 'MUS', 'SINR']].groupby(['Model', 'MUS']).agg({'MUS':'size', 'SINR':'mean'}).rename(columns={'MUS':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "549a0535",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "7c11b4a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# MUSlist = [0.15, 0.20, 0.25, 0.3]\n",
    "# for MUS__ in MUSlist:\n",
    "#     data.append(dfMUS.loc[dfMUS['MUS'] == MUS__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfMUS[['Model', 'MUS', 'SINR']].groupby(['Model', 'MUS']).agg({'MUS':'size', 'SINR':'mean'}).rename(columns={'MUS':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['MUS'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(MUSlist, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(MUSlist, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([0.1499,0.3001,19,27])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'$\\gamma$',fontsize=25)\n",
    "# ApplyFont(plt.gca())\n",
    "# # plt.savefig('Figures/MUS_ablation.pdf', format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "c8c11f11",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dfMUS = pd.read_pickle(r\"../Results/simulation_results_nnsparse_ablation_MUS_V2.pkl\")\n",
    "# dfMUS = dfMUS.iloc[:4*(dfMUS.shape[0]//4)]\n",
    "# results = dfMUS[['Model', 'MUS', 'SINR']].groupby(['Model', 'MUS']).agg({'MUS':'size', 'SINR':'mean'}).rename(columns={'MUS':'count','SINR':'mean_sent'}).reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "01ab32ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "# results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "0123b2b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data= []\n",
    "# MUSlist = [0.15, 0.20, 0.25, 0.3]\n",
    "# for MUS__ in MUSlist:\n",
    "#     data.append(dfMUS.loc[dfMUS['MUS'] == MUS__]['SINR'].values.tolist())\n",
    "    \n",
    "# data = np.stack(data, axis = 1)\n",
    "\n",
    "# # compute the medians and 25/75 percentiles\n",
    "# med, perc_25, perc_75, _ = perc(data)\n",
    "# perc_25\n",
    "\n",
    "# SINRresults = dfMUS[['Model', 'MUS', 'SINR']].groupby(['Model', 'MUS']).agg({'MUS':'size', 'SINR':'mean'}).rename(columns={'MUS':'count','SINR':'mean_sent'}).reset_index()\n",
    "# zeta = np.array(SINRresults['MUS'].values, dtype = np.float64)\n",
    "# SINR = np.array(SINRresults['mean_sent'].values, dtype = np.float64)\n",
    "\n",
    "# SetPlotRC()\n",
    "# fh2=plt.figure(figsize=(10, 6), dpi=80)\n",
    "# plt.plot(MUSlist, SINR,\"-o\", linewidth=4, markersize = 13,color='#006BB2')\n",
    "# plt.fill_between(MUSlist, perc_25, perc_75, alpha=0.25, linewidth=0, color='#006BB2')\n",
    "# plt.grid()\n",
    "\n",
    "# plt.grid(linewidth=2)\n",
    "# plt.xticks(MUSlist, fontsize=20)\n",
    "# plt.yticks(fontsize=20)\n",
    "# plt.axis([0.1499,0.3001,20,27.4])\n",
    "# plt.ylabel('SINR (dB)',fontsize=25)\n",
    "# plt.xlabel(r'Initial selection of $1 - \\gamma^2$',fontsize=25)\n",
    "\n",
    "# ApplyFont(plt.gca())\n",
    "# plt.savefig('Figures/MUS_ablation.pdf', format='pdf', bbox_inches = 'tight')"
   ]
  }
 ],
 "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.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
