{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import required packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import copy\n",
    "import numpy as np\n",
    "import networkx as nx\n",
    "# from dsd import *\n",
    "import dsd\n",
    "# from my_dsp import *\n",
    "from super_greedy_pp import *\n",
    "import utils\n",
    "from datetime import datetime\n",
    "import matplotlib.pyplot as plt \n",
    "import matplotlib\n",
    "%matplotlib inline \n",
    "import pandas as pd\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "import random\n",
    "import inspect\n",
    "\n",
    "import csv\n",
    "\n",
    "# Import seaborn\n",
    "import seaborn as sns\n",
    "\n",
    "# Apply the default theme\n",
    "sns.set_theme()\n",
    "\n",
    "plt.rcParams[\"figure.dpi\"]=100\n",
    "plt.rcParams['savefig.dpi']=300"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Create regularization path plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name = 'amazon_hpc'\n",
    "# dataset_name = 'amazon_op'\n",
    "# dataset_name = 'twitchPTBR'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "if dataset_name == 'amazon_hpc':\n",
    "    load_path = 'logs/amazon/amazon_hpc_1_log.npy'\n",
    "elif dataset_name == 'amazon_op':\n",
    "    load_path = 'logs/amazon/amazon_op_1_log.npy'\n",
    "elif dataset_name == 'twitchPTBR':\n",
    "    load_path = 'logs/twitchPTBR/twitchPTBR_1_log.npy'\n",
    "    \n",
    "variables_dict_ = np.load(load_path, allow_pickle=True)\n",
    "\n",
    "lam_vec = variables_dict_.item().get('lam')\n",
    "super_greedy_pp_R = variables_dict_.item().get('induced')\n",
    "num_of_nodes = variables_dict_.item().get('num_of_nodes')\n",
    "density_vec = variables_dict_.item().get('density')\n",
    "num_of_protected_vec = variables_dict_.item().get('num_of_protected')\n",
    "protected_portion_in_sub_vec = variables_dict_.item().get('protected_portion_in_sub')\n",
    "protected_portion_in_prot_vec = variables_dict_.item().get('protected_portion_in_prot')\n",
    "PoF_vec = variables_dict_.item().get('PoF')\n",
    "fairness_vec = variables_dict_.item().get('fairness')\n",
    "g_vec = variables_dict_.item().get('g')\n",
    "LB_UB_vec = variables_dict_.item().get('LB_UB')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x230 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(3,2.3))  \n",
    "plt.ylabel(r\"$ \\dfrac{|\\mathcal{S}\\cap\\mathcal{S}_p|}{|\\mathcal{S}|} $\")\n",
    "plt.plot(lam_vec, protected_portion_in_sub_vec)\n",
    "plt.xlabel(r\"$\\lambda$\")\n",
    "plt.ylim(0, None)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.12.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
