{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "87da8dfb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pydgn\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import os\n",
    "import json\n",
    "import os.path as osp\n",
    "import pandas as pd\n",
    "sns.color_palette(\"colorblind\", as_cmap=True)\n",
    "sns.set_palette(\"colorblind\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "89c57134",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_root = 'DATA'\n",
    "dataset_name = 'NCI1'\n",
    "exp_folder = f'GSPN_RESULTS/SUPERVISED/supervised_gspn_classification_chemical_{dataset_name}/MODEL_ASSESSMENT/'\n",
    "\n",
    "outer_fold = 1\n",
    "outer_folder = osp.join(exp_folder, f'OUTER_FOLD_{outer_fold}')\n",
    "ms_folder = osp.join(outer_folder, 'MODEL_SELECTION')\n",
    "\n",
    "# config_id = 15  # best config for the unsupervised part according to regression task\n",
    "# config_folder = osp.join(ms_folder, f'config_{config_id}')\n",
    "\n",
    "# model_config_file = osp.join(config_folder, 'config_results.json')\n",
    "# config = json.load(open(model_config_file, 'r'))['config']\n",
    "# results = json.load(open(model_config_file, 'r'))\n",
    "# print(json.dumps(results, indent=4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c81e96e6",
   "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>outer_fold</th>\n",
       "      <th>num_mixtures</th>\n",
       "      <th>num_graph_mixtures</th>\n",
       "      <th>num_layers</th>\n",
       "      <th>global_readout</th>\n",
       "      <th>avg_validation_score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "      <td>32</td>\n",
       "      <td>20</td>\n",
       "      <td>mean</td>\n",
       "      <td>74.864868</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "      <td>128</td>\n",
       "      <td>10</td>\n",
       "      <td>mean</td>\n",
       "      <td>75.675674</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "      <td>32</td>\n",
       "      <td>5</td>\n",
       "      <td>sum</td>\n",
       "      <td>78.648651</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "      <td>32</td>\n",
       "      <td>5</td>\n",
       "      <td>mean</td>\n",
       "      <td>73.243240</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>40</td>\n",
       "      <td>32</td>\n",
       "      <td>5</td>\n",
       "      <td>sum</td>\n",
       "      <td>76.486488</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>235</th>\n",
       "      <td>10</td>\n",
       "      <td>40</td>\n",
       "      <td>128</td>\n",
       "      <td>10</td>\n",
       "      <td>mean</td>\n",
       "      <td>75.135132</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>236</th>\n",
       "      <td>10</td>\n",
       "      <td>20</td>\n",
       "      <td>128</td>\n",
       "      <td>20</td>\n",
       "      <td>mean</td>\n",
       "      <td>73.243240</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>237</th>\n",
       "      <td>10</td>\n",
       "      <td>20</td>\n",
       "      <td>128</td>\n",
       "      <td>5</td>\n",
       "      <td>sum</td>\n",
       "      <td>73.783783</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>238</th>\n",
       "      <td>10</td>\n",
       "      <td>40</td>\n",
       "      <td>128</td>\n",
       "      <td>20</td>\n",
       "      <td>mean</td>\n",
       "      <td>78.378380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>239</th>\n",
       "      <td>10</td>\n",
       "      <td>40</td>\n",
       "      <td>32</td>\n",
       "      <td>20</td>\n",
       "      <td>mean</td>\n",
       "      <td>74.594597</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>240 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    outer_fold num_mixtures num_graph_mixtures num_layers global_readout  \\\n",
       "0            1           20                 32         20           mean   \n",
       "1            1           20                128         10           mean   \n",
       "2            1           20                 32          5            sum   \n",
       "3            1           20                 32          5           mean   \n",
       "4            1           40                 32          5            sum   \n",
       "..         ...          ...                ...        ...            ...   \n",
       "235         10           40                128         10           mean   \n",
       "236         10           20                128         20           mean   \n",
       "237         10           20                128          5            sum   \n",
       "238         10           40                128         20           mean   \n",
       "239         10           40                 32         20           mean   \n",
       "\n",
       "     avg_validation_score  \n",
       "0               74.864868  \n",
       "1               75.675674  \n",
       "2               78.648651  \n",
       "3               73.243240  \n",
       "4               76.486488  \n",
       "..                    ...  \n",
       "235             75.135132  \n",
       "236             73.243240  \n",
       "237             73.783783  \n",
       "238             78.378380  \n",
       "239             74.594597  \n",
       "\n",
       "[240 rows x 6 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(columns=['outer_fold', \n",
    "                          'num_mixtures',\n",
    "                          'num_graph_mixtures',\n",
    "                          'num_layers',\n",
    "                          'global_readout',\n",
    "                          'avg_validation_score'])\n",
    "\n",
    "for outer_fold in range(1, 11):\n",
    "    outer_folder = osp.join(exp_folder, f'OUTER_FOLD_{outer_fold}')\n",
    "    ms_folder = osp.join(outer_folder, 'MODEL_SELECTION')\n",
    "    for d in os.listdir(ms_folder):\n",
    "        if os.path.isfile(osp.join(ms_folder, d)):\n",
    "            continue\n",
    "\n",
    "        config_folder = osp.join(ms_folder, d)\n",
    "        model_config_file = osp.join(config_folder, 'config_results.json')\n",
    "        config = json.load(open(model_config_file, 'r'))['config']\n",
    "        results = json.load(open(model_config_file, 'r'))\n",
    "\n",
    "        num_mixtures = config['supervised_config']['num_mixtures']\n",
    "        num_graph_mixtures = config['supervised_config']['num_graph_mixtures']\n",
    "\n",
    "        num_layers = config['supervised_config']['num_layers']\n",
    "        global_readout = config['supervised_config']['global_readout']\n",
    "\n",
    "        vl_score = results['avg_validation_score']\n",
    "\n",
    "        df = df.append({'outer_fold' : outer_fold,\n",
    "                        'num_mixtures' : num_mixtures,\n",
    "                        'num_graph_mixtures' : num_graph_mixtures,\n",
    "                        'num_layers' : num_layers,\n",
    "                        'global_readout' : global_readout,\n",
    "                        'avg_validation_score' : vl_score},                       \n",
    "                        ignore_index=True)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b16c4fa8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    num_mixtures  num_graph_mixtures  num_layers global_readout  \\\n",
      "0             20                  32           5           mean   \n",
      "1             20                  32           5            sum   \n",
      "2             20                  32          10           mean   \n",
      "3             20                  32          10            sum   \n",
      "4             20                  32          20           mean   \n",
      "5             20                  32          20            sum   \n",
      "6             20                 128           5           mean   \n",
      "7             20                 128           5            sum   \n",
      "8             20                 128          10           mean   \n",
      "9             20                 128          10            sum   \n",
      "10            20                 128          20           mean   \n",
      "11            20                 128          20            sum   \n",
      "12            40                  32           5           mean   \n",
      "13            40                  32           5            sum   \n",
      "14            40                  32          10           mean   \n",
      "15            40                  32          10            sum   \n",
      "16            40                  32          20           mean   \n",
      "17            40                  32          20            sum   \n",
      "18            40                 128           5           mean   \n",
      "19            40                 128           5            sum   \n",
      "20            40                 128          10           mean   \n",
      "21            40                 128          10            sum   \n",
      "22            40                 128          20           mean   \n",
      "23            40                 128          20            sum   \n",
      "\n",
      "    avg_validation_score  \n",
      "0              71.918919  \n",
      "1              77.216216  \n",
      "2              74.216218  \n",
      "3              78.189188  \n",
      "4              75.702705  \n",
      "5              79.432433  \n",
      "6              71.540540  \n",
      "7              76.243243  \n",
      "8              73.648648  \n",
      "9              79.702702  \n",
      "10             75.756755  \n",
      "11             79.540540  \n",
      "12             71.837837  \n",
      "13             77.675675  \n",
      "14             74.891894  \n",
      "15             79.243243  \n",
      "16             75.621622  \n",
      "17             79.135136  \n",
      "18             71.918920  \n",
      "19             77.324324  \n",
      "20             75.729729  \n",
      "21             79.027026  \n",
      "22             76.945946  \n",
      "23             80.432433  \n"
     ]
    }
   ],
   "source": [
    "df_gb = df.groupby(by=['num_mixtures',\n",
    "               'num_graph_mixtures',\n",
    "               'num_layers',\n",
    "               'global_readout'], as_index=False).mean()\n",
    "print(df_gb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "11a606b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "if not os.path.exists('plots'):\n",
    "    os.makedirs('plots')\n",
    "    \n",
    "plt.rcParams.update({'font.size': 12})\n",
    "\n",
    "renamed_df = df.rename(columns={'num_graph_mixtures': r'$C_G$', 'num_mixtures': r'$C$'})\n",
    "sns.lineplot(x='num_layers', \n",
    "             y='avg_validation_score', \n",
    "             hue=r'$C_G$', \n",
    "             style=r'$C$', \n",
    "             data=renamed_df[renamed_df['global_readout'] == 'sum'],\n",
    "             palette=sns.color_palette('colorblind', n_colors=2))\n",
    "plt.xlabel('number of layers')\n",
    "plt.ylabel('validation accuracy')\n",
    "plt.tight_layout()\n",
    "plt.savefig('plots/layers_vs_perf.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "929f7bc9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
