{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "data_dir = '../data/paper_final_results'\n",
    "os.listdir(data_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [],
   "source": [
    "def process_res_dict(path, seed, algo, model, what='test'):\n",
    "    with open(os.path.join(path, f'Test features - {what} accuracy_metrics.txt'), 'r') as f:\n",
    "        res_dict = {}\n",
    "        for l in f:\n",
    "            l = l.split(': ')\n",
    "            key = l[0]\n",
    "            val = l[1].replace('(', '').replace(')', '').split(', ')[0]\n",
    "\n",
    "            res_dict[key] = float(val)\n",
    "            \n",
    "        res_dict['seed'] = seed\n",
    "        res_dict['algo'] = algo\n",
    "        res_dict['model'] = model\n",
    "    \n",
    "    return res_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [],
   "source": [
    "import glob\n",
    "\n",
    "what = 'test'\n",
    "res_df = []\n",
    "\n",
    "for train_seed in range(1, 4):\n",
    "    for samples in [608, 1000, 2500, 5000, 10000]:\n",
    "        for seed in range(10):\n",
    "            for algo in ['accuracy', 'io_model', 'arch2vec_orig']:\n",
    "                for model in ['model_dense', 'model_orig', 'model_ref']:\n",
    "                    if 'ref' in model and 'acc' in algo:\n",
    "                        continue\n",
    "                    if algo == 'arch2vec_orig':\n",
    "                        if train_seed != 1 or 'ref' not in model:\n",
    "                            continue\n",
    "                        a2v_name = 'features-original_training_arch2vec_epochs-8.pt'\n",
    "                        p = os.path.join(data_dir,\n",
    "                                         f'{algo}_seeds',\n",
    "                                         f'seed_{train_seed}', 'regr',\n",
    "                                         f'rf_tune_{samples}_{seed + 1}_train_{a2v_name}')\n",
    "                    else:\n",
    "                        p = os.path.join(data_dir,\n",
    "                                         f'{algo}_seeds',\n",
    "                                         f'seed_{train_seed}', 'regr',\n",
    "                                         f'rf_tune_{samples}_{seed + 1}_train_embedding_{model}_epoch-9.pt')\n",
    "\n",
    "                    res = process_res_dict(p, seed, algo, model, what=what)\n",
    "                    res['samples'] = samples\n",
    "                    res['train_seed'] = train_seed\n",
    "                    res_df.append(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "\n",
    "res_df = pd.DataFrame(res_df)\n",
    "results_table = res_df[['model', 'algo', 'RMSE', 'Pearson\\'s r']].groupby(\n",
    "    ['algo', 'model']).std().round(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "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>RMSE</th>\n",
       "      <th>Pearson's r</th>\n",
       "      <th>seed</th>\n",
       "      <th>algo</th>\n",
       "      <th>model</th>\n",
       "      <th>samples</th>\n",
       "      <th>train_seed</th>\n",
       "      <th>Used model</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.017068</td>\n",
       "      <td>0.632822</td>\n",
       "      <td>0</td>\n",
       "      <td>accuracy</td>\n",
       "      <td>model_dense</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>Accuracy Model 1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.017259</td>\n",
       "      <td>0.673271</td>\n",
       "      <td>0</td>\n",
       "      <td>accuracy</td>\n",
       "      <td>model_orig</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>Accuracy Model 2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.016963</td>\n",
       "      <td>0.667180</td>\n",
       "      <td>0</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_dense</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>IO Model 1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.017517</td>\n",
       "      <td>0.686060</td>\n",
       "      <td>0</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_orig</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>IO Model 2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.018357</td>\n",
       "      <td>0.673996</td>\n",
       "      <td>0</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>795</th>\n",
       "      <td>0.018768</td>\n",
       "      <td>0.761229</td>\n",
       "      <td>9</td>\n",
       "      <td>accuracy</td>\n",
       "      <td>model_dense</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>Accuracy Model 1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>796</th>\n",
       "      <td>0.022250</td>\n",
       "      <td>0.673712</td>\n",
       "      <td>9</td>\n",
       "      <td>accuracy</td>\n",
       "      <td>model_orig</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>Accuracy Model 2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>797</th>\n",
       "      <td>0.020858</td>\n",
       "      <td>0.714704</td>\n",
       "      <td>9</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_dense</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>IO Model 1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>798</th>\n",
       "      <td>0.022808</td>\n",
       "      <td>0.678182</td>\n",
       "      <td>9</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_orig</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>IO Model 2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>799</th>\n",
       "      <td>0.021980</td>\n",
       "      <td>0.690917</td>\n",
       "      <td>9</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>arch2vec</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>800 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "         RMSE  Pearson's r  seed      algo        model  samples  train_seed  \\\n",
       "0    0.017068     0.632822     0  accuracy  model_dense      608           1   \n",
       "1    0.017259     0.673271     0  accuracy   model_orig      608           1   \n",
       "2    0.016963     0.667180     0  io_model  model_dense      608           1   \n",
       "3    0.017517     0.686060     0  io_model   model_orig      608           1   \n",
       "4    0.018357     0.673996     0  io_model    model_ref      608           1   \n",
       "..        ...          ...   ...       ...          ...      ...         ...   \n",
       "795  0.018768     0.761229     9  accuracy  model_dense    10000           3   \n",
       "796  0.022250     0.673712     9  accuracy   model_orig    10000           3   \n",
       "797  0.020858     0.714704     9  io_model  model_dense    10000           3   \n",
       "798  0.022808     0.678182     9  io_model   model_orig    10000           3   \n",
       "799  0.021980     0.690917     9  io_model    model_ref    10000           3   \n",
       "\n",
       "           Used model  \n",
       "0    Accuracy Model 1  \n",
       "1    Accuracy Model 2  \n",
       "2          IO Model 1  \n",
       "3          IO Model 2  \n",
       "4            arch2vec  \n",
       "..                ...  \n",
       "795  Accuracy Model 1  \n",
       "796  Accuracy Model 2  \n",
       "797        IO Model 1  \n",
       "798        IO Model 2  \n",
       "799          arch2vec  \n",
       "\n",
       "[800 rows x 8 columns]"
      ]
     },
     "execution_count": 138,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "values_map = {\n",
    "    'accuracy': {\n",
    "        'model_dense': 'Accuracy Model 1',\n",
    "        'model_orig': 'Accuracy Model 2'\n",
    "    },\n",
    "    'io_model': {\n",
    "        'model_dense': 'IO Model 1',\n",
    "        'model_orig': 'IO Model 2',\n",
    "        'model_ref': 'arch2vec'\n",
    "    },\n",
    "    'arch2vec_orig': {\n",
    "        'model_ref': 'arch2vec original'\n",
    "    }\n",
    "}\n",
    "\n",
    "res_df['Used model'] = \"\"\n",
    "for i in range(len(res_df)):\n",
    "    row = res_df.iloc[i]\n",
    "    res_df.loc[row.name, 'Used model'] = values_map[row['algo']][row['model']]\n",
    "res_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [],
   "source": [
    "orig_res_df = res_df.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "ts = 3\n",
    "res_df = orig_res_df[orig_res_df['samples'].isin([608, 2500, 10000]) & ((orig_res_df['train_seed'] == ts) | (orig_res_df['algo'] == 'arch2vec_orig'))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "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>RMSE</th>\n",
       "      <th>Pearson's r</th>\n",
       "      <th>seed</th>\n",
       "      <th>algo</th>\n",
       "      <th>model</th>\n",
       "      <th>samples</th>\n",
       "      <th>train_seed</th>\n",
       "      <th>Used model</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.018474</td>\n",
       "      <td>0.609542</td>\n",
       "      <td>0</td>\n",
       "      <td>arch2vec_orig</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec original</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.017912</td>\n",
       "      <td>0.627930</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec_orig</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec original</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.018753</td>\n",
       "      <td>0.600953</td>\n",
       "      <td>2</td>\n",
       "      <td>arch2vec_orig</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec original</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.018599</td>\n",
       "      <td>0.612789</td>\n",
       "      <td>3</td>\n",
       "      <td>arch2vec_orig</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec original</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>0.018566</td>\n",
       "      <td>0.601324</td>\n",
       "      <td>4</td>\n",
       "      <td>arch2vec_orig</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>608</td>\n",
       "      <td>1</td>\n",
       "      <td>arch2vec original</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>795</th>\n",
       "      <td>0.018768</td>\n",
       "      <td>0.761229</td>\n",
       "      <td>9</td>\n",
       "      <td>accuracy</td>\n",
       "      <td>model_dense</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>Accuracy Model 1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>796</th>\n",
       "      <td>0.022250</td>\n",
       "      <td>0.673712</td>\n",
       "      <td>9</td>\n",
       "      <td>accuracy</td>\n",
       "      <td>model_orig</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>Accuracy Model 2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>797</th>\n",
       "      <td>0.020858</td>\n",
       "      <td>0.714704</td>\n",
       "      <td>9</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_dense</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>IO Model 1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>798</th>\n",
       "      <td>0.022808</td>\n",
       "      <td>0.678182</td>\n",
       "      <td>9</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_orig</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>IO Model 2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>799</th>\n",
       "      <td>0.021980</td>\n",
       "      <td>0.690917</td>\n",
       "      <td>9</td>\n",
       "      <td>io_model</td>\n",
       "      <td>model_ref</td>\n",
       "      <td>10000</td>\n",
       "      <td>3</td>\n",
       "      <td>arch2vec</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>180 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "         RMSE  Pearson's r  seed           algo        model  samples  \\\n",
       "5    0.018474     0.609542     0  arch2vec_orig    model_ref      608   \n",
       "11   0.017912     0.627930     1  arch2vec_orig    model_ref      608   \n",
       "17   0.018753     0.600953     2  arch2vec_orig    model_ref      608   \n",
       "23   0.018599     0.612789     3  arch2vec_orig    model_ref      608   \n",
       "29   0.018566     0.601324     4  arch2vec_orig    model_ref      608   \n",
       "..        ...          ...   ...            ...          ...      ...   \n",
       "795  0.018768     0.761229     9       accuracy  model_dense    10000   \n",
       "796  0.022250     0.673712     9       accuracy   model_orig    10000   \n",
       "797  0.020858     0.714704     9       io_model  model_dense    10000   \n",
       "798  0.022808     0.678182     9       io_model   model_orig    10000   \n",
       "799  0.021980     0.690917     9       io_model    model_ref    10000   \n",
       "\n",
       "     train_seed         Used model  \n",
       "5             1  arch2vec original  \n",
       "11            1  arch2vec original  \n",
       "17            1  arch2vec original  \n",
       "23            1  arch2vec original  \n",
       "29            1  arch2vec original  \n",
       "..          ...                ...  \n",
       "795           3   Accuracy Model 1  \n",
       "796           3   Accuracy Model 2  \n",
       "797           3         IO Model 1  \n",
       "798           3         IO Model 2  \n",
       "799           3           arch2vec  \n",
       "\n",
       "[180 rows x 8 columns]"
      ]
     },
     "execution_count": 145,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj4AAAGJCAYAAACKFTn8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABqdklEQVR4nO3dd3RU1drH8e/MJCFATCOUhCq+CpGOdIh0CBAICkgXL01AEfSqBLxSVQyiFCmiIoiiXgRpoQgoIsUugkpvCSWhpFECJJk57x+R0VwSMoFU5vdZi7Uy5+yzz3NOhskze++zt8kwDAMRERERJ2DO7wBERERE8ooSHxEREXEaSnxERETEaSjxEREREaehxEdERESchhIfERERcRpKfETEYWFhYcyYMSO/w8i2KlWqEBkZmS/nPnbsGKGhodSpU4clS5bkyjneeecdXnrppVypOy988cUX9O7dO7/DECfhkt8BiBRErVq14sKFC1gsFooWLcrDDz/Myy+/TPHixfM7NIdUqVKFgwcP5ncYArz//vs0bNiQ1atXZ7i/f//+dOnShR49etz2OYYNG3bbx4o4G7X4iGTinXfeYffu3axcuZI//viD+fPn52j9qampOVpfTivo8eWH27knZ86c4f7778/Tc4pI5pT4iGShdOnSBAUFcfjwYQB+++03evXqRb169ejSpQs//PCDveyKFSvo0KEDderUoXXr1nz22Wf2fT/88AMPP/ww7777Lk2bNmXs2LHExcXx5JNPUq9ePRo0aECfPn2w2WwAHD16lP79+1OvXj06derEV199Za8rLCyMSZMmMXToUOrUqUOPHj2IiorKMP4vvviC1q1bU6dOHVq1asWaNWsyLPf222/zzDPP8Pzzz1O3bl1WrlyZYbn4+Hj+9a9/UadOHfr168fp06cBmDRpEq+//nq6ssOGDWPx4sUZ1lOlShU+/fRT2rVrR7169Zg0aRI3JpJ/++23ef755+1lT506RZUqVexJQP/+/ZkxYwa9evWiTp06DBs2jPj4eP79739Tt25dunXrxqlTp9Kdb9u2bbRu3ZqGDRsSHh5uv88Ay5cvp0OHDtSvX59BgwbZr+lGnEuXLqVdu3a0a9cuw2v56quv6NSpE/Xq1aN///4cPXoUgMcff5wffviByZMnU6dOHY4fP57uuBkzZvDzzz/b90+ePDnTc77y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RL9+/6Jbt5vL1qvXgLVrVwEQG3uB777bSd269alQoSLXr19nz57dAGzduoXLl9Pm1alQoSLu7u72RBHSuq6uXLl8yzgSExMYPfopunV7jJCQrlnGnR1q8REREXHAunVraNeuQ7pt1avXxGazsXv3L4wfP4W33gqnf//HMJsttG3bnn79nmDkyOeYPftN+vfvicVioU6duowe/QJdunTlP/8ZQ79+PShfvgIPPlgtkzNDo0ZN2LRpA717P4qXlze1a9dh3760pKlu3Xr07/8Eo0ePwGQy4+bmSnj4DIoUKYLZbKZDh058//0u/u//7s/yGk0mU6aPjY8e/TxvvPEaAwb0wjAMhg172v7U18SJr/Lmm69jMpmoVasOpUunLSnl4uJCePgMZs9+k08//Qir1Yavry+TJ79+yzg+/vhDTp6MYvXqL1i9Oq1lq0ePXlkOinaEychoMSwndCczN0+dOonDURdyZQLD+yv4MXbshBytV0SksIiJiaRMmYr21wVhHp/CZvToEXTp8miOdhcVJP/7HikQMzeLiIjkhLs1OckNBw7sY/z4sTzwQBVatGiV3+EUGEp8RERE7kJVqz7IsmWr8zuMAkeDm0VERMRpKPERERERp6HER0RERJyGEh8RERFxGkp8REREHNS9e2eOHTtif71mzUr69XuMvn2706vXoyxZ8gE2my3DYxcuXECzZvXYtWuHfVtSUhJt2wYxaFD/bMeyfv1a/vOfF7Mst3DhAubMmZnhvk8++YjevR8lKKg+O3duz3YMhZGe6hIRkULjzdcmcSk+NsfrvcenBP8el7050zZuXMeyZZ8yffpsypQpw8WLFxk37nlsNhtPPDE4w2MeeKAqGzZE0KRJMyBtluPy5StmWDYv1KlTl+bNWzJ16uR8iyGvKfEREZFC41J8LJ0yblC5I+tuI5lauPBd/v3vMZQpkzZLsaenJ88/P5ZBg/rRp8/juLm53XRMnToP8d13O7h48SKenp5s2BBBx44hbNjw95IOGzZE8OmnH2EymQgIKMeLL47Dx8eXlJQUZsyYxq+//oyXlzf3318lXd0ff7yYbdu+xmq14udXijFjXrIvXJqZwMDMZ4u+W6mrS0REJJuSkq4QHX2aatVqpNteqdK9uLi4cOpUVIbHmUwmWrdux1dfbeL06VNcu3aNypX/z77/2LEjvPPOHN56ay4f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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj4AAAFSCAYAAADy7NUQAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABdfUlEQVR4nO3de3yO9R/H8dd972BmbbMtbGakg+RQWL8ic8phY2wSckykg0PRCaucIoeSKEKJig5Ec14oMomSopKcLcxp2z2HYbsPvz+WO2ube2PnvZ+Ph8dj93V9r+/1ue/d7vuz79Fgs9lsiIiIiJQCxsIOQERERKSgKPERERGRUkOJj4iIiJQaSnxERESk1FDiIyIiIqWGEh8REREpNZT4iJQi77zzDi+88EJhh5FrLVq0YMuWLYVy7zNnztCjRw/q1avHxIkT8+Uey5cvp2/fvvlSd0HYtm0bTZo0KewwRHJEiY9IPmnRogV169alXr16PPDAAwwfPpwLFy7Yzw8fPpwaNWqwfv36DNe9/vrr1KhRg6VLlwKQmprKxIkTadKkCfXq1aNFixaMHz8+y/tc+Td27NiCeZKlwBdffEH58uXZsWMHw4cPz3R++PDhTJ069Ybu0aFDBz788MMbqkNEcsa5sAMQKclmzZpFo0aNOH36NP369WPOnDkMHTrUfr5atWosW7aMli1bAmA2m1mzZg1BQUH2MnPmzOH3339n8eLFVKhQgWPHjrF9+/Ys7yPXZjabcXbO3cfe8ePHufXWWzEYDAV2TxHJP2rxESkAN998M40bN+bPP//McLxFixb8/PPPJCcnAxAbG0uNGjXw8/Ozl/ntt99o2bIlFStWxGAwEBgYSGRk5HXHkpqaypAhQ6hXrx4dO3Zkz549AHzwwQcMHjw4Q9lx48Yxbty4LOtp0aIFc+fOpX379jRo0IAhQ4Zw+fJlAJYuXUq3bt0ylK9RowZHjhwB0ltJRo8ezeOPP069evV45JFHOH36NOPHj+fee+8lNDSU3bt3Z7j+t99+o23bttx7772MGDHCfi+ADRs2EBERQXBwMI888oj9OV2Jc86cObRv35577rkHs9mc6bns2LGDTp060aBBAzp16sSOHTvscUZHRzN37lzq1auXqbvtiy++YMWKFfbzTz31VLb3nDNnDi1btqRevXq0bduWdevW2ev57+tVo0YNPvvsM1q3bk1wcDBjxowhu0X2d+3axUMPPUT9+vVp1KgREyZMsJ975plneOCBB2jQoAE9evRg37599nO5/R20aNGC2bNnZ/s7uNrJkycZPHgw999/Py1atODjjz/OUbwiBUGJj0gBOHHiBLGxsRlacgBcXV158MEHWbVqFQDR0dGZkpq7776b+fPns3DhQv76669svwBz6ptvviE0NJQff/yR8PBwBgwYQFpaGh06dCA2NpazZ88C6S0Vq1atumaStWbNGj744AO++eYb/vrrL3v3XE6sWbOGIUOGsHXrVlxdXenatSu1atVi69attGnTJtMX4pUEY926dRw6dIiZM2cCsHv3bqKiohg7dizbtm2ja9euDBgwgNTUVPu1q1atYs6cOWzfvj1T64vJZOLJJ5+kV69ebNu2jccee4wnn3ySpKQkJk6cSPv27enXrx+//PJLpla1rl27Zjg/a9asbO9ZpUoVFi5cyM8//8ygQYN48cUXOXXqVLavz8aNG/nyyy9Zvnw5a9asITY2Nsty48ePp3fv3uzYsYN169YRFhZmP9ekSRO+/vprfvjhB+66665M47vy6ndwNavVytNPP02NGjXYtGkTH330ER999JE9/mvFK1IQlPiI5KOBAwdSr149mjZtio+PD88880ymMhERESxbtoyzZ8/y008/2bu9rnjyySfp378/K1asoFOnToSEhPDVV19luk9wcLD936JFi7KNqVatWoSGhuLi4sJjjz1GamoqO3fupEKFCgQHBxMTEwOktz6VL1+e2rVrZ1tXr169qFixIt7e3jRv3jxTi9a1tGrVitq1a1OmTBlatWpFmTJliIyMxMnJibZt22aqq0ePHvj7++Pt7c3TTz9tTxa/+OILunbtyt13342TkxMdO3bExcWFX3/9NUOc/v7+uLm5ZYpj48aNVK1alcjISJydnQkPD6d69eps2LAhx88lK/+9Z1hYGBUrVsRoNNK2bVuqVq3Krl27sr2+f//+eHp6EhAQwH333ZehFetqzs7OxMXFkZiYSLly5bjnnnvs5x5++GE8PDxwdXVl8ODB7Nmzh3PnztnP59Xv4Gq//fYbiYmJDBo0CFdXV6pUqUKXLl1YvXq1w3hFCoI6nkXy0YwZM2jUqBE//vgjzz//PElJSXh6emYoExwcTGJiIu+99x7NmjXL9OXs5OREjx496NGjB5cu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REoNJT4iIiJSaijxERERkVJDiY+IiIiUGkp8REREpNRQ4iMiIiKlhhIfERERKTWU+IiIiEipocRHRERESg0lPiIiIlJqKPERERGRUkOJj4iIiJQaSnxERESk1DDYbDZbYQdRFCQknMdq1UshciM2b/6O2NiNmY4fOXIYgKpVq2U4HhLSjMaNm+Z3WCJSihiNBnx9PbI971yAsYhIKeXt7V3YIYiIAGrxsVOLj4iISPHnqMVHY3xERESk1FDiIyIiIqWGEh8REREpNZT4iIiISKmhxEdERERKDSU+IiIiUmoo8REREZFSQ4mPiIiIlBpKfERERKTU0JYV/zAaDYUdgoiIiNwgR9/n2rJCRERESg11dYmIiEipocRHRERESg0lPiIiIlJqKPERERGRUkOJj4iIiJQaSnxERESk1FDiIyIiIqWGEh8REREpNZT4iIiISKmhxEdy5fLly4waNYrWrVvTvn17Xn31VQAOHTpE165dadOmDV27duXw4cP2azZs2EBkZCQRERF06NCBtWvXFlL0UpIkJSXRv39/2rRpQ/v27Rk0aBCJiYkA1KhRg/bt2xMREUFERAR//fWX/bpvv/2W0NBQWrVqxZAhQ7h48WKOzolcy6RJk2jRogU1atRg79699uPX+mzMj3OSAzaRXHjttdds48ePt1mtVpvNZrOdPn3aZrPZbL169bJFR0fbbDabLTo62tarVy+bzWazWa1WW3BwsO2vv/6y2Ww2259//mm75557bBaLpRCil5IkKSnJtnXrVvvjiRMn2kaMGGGz2Wy2O+64w3b+/PlM15w/f97WqFEj26FDh2w2m80WFRVle+eddxyeE3Hkp59+sh0/ftzWvHlz++edzZb9Z2N+nRPH1OIjOXbhwgWio6N59tlnMRjSN4Hz8/MjISGB3bt3Ex4eDkB4eDi7d++2//VtNBo5d+4cAOfOnaNChQoYjXrryY3x9vbmvvvusz++5557OH78+DWv2bRpE7Vr16ZatWoAPPLII6xZs8bhORFHgoOD8ff3z3DsWp+N+XFOcka7s0uO/f3333h7e/Puu++ybds2ypUrx7PPPoubmxsVK1bEyckJACcnJypUqEB8fDw+Pj68/fbbDBgwAHd3dy5cuMCcOXMK+ZlISWO1Wvnss89o0aKF/VivXr2wWCw0adKEwYMH4+rqSnx8PAEBAfYyAQEB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\n",
      "text/plain": [
       "<Figure size 648x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "sns.set()\n",
    "\n",
    "save_dir = '.'\n",
    "\n",
    "plt.figure(figsize=(9,6))\n",
    "plt.title('Pearson\\'s r by number of train samples')\n",
    "sns.boxplot(data=res_df, x='samples', y='Pearson\\'s r', hue='Used model')\n",
    "plt.savefig(f'{save_dir}/pearson.png')\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(9,6))\n",
    "plt.title('RMSE by number of train samples')\n",
    "sns.boxplot(data=res_df, x='samples', y='RMSE', hue='Used model')\n",
    "plt.savefig(f'{save_dir}/rmse.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "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></th>\n",
       "      <th>RMSE</th>\n",
       "      <th>Pearson's r</th>\n",
       "      <th>seed</th>\n",
       "      <th>train_seed</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Used model</th>\n",
       "      <th>samples</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Accuracy Model 1</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0177</td>\n",
       "      <td>0.7581</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Accuracy Model 2</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0211</td>\n",
       "      <td>0.6862</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>IO Model 1</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0191</td>\n",
       "      <td>0.7323</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>IO Model 2</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0214</td>\n",
       "      <td>0.6897</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>arch2vec</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0209</td>\n",
       "      <td>0.7010</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>arch2vec original</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0201</td>\n",
       "      <td>0.6879</td>\n",
       "      <td>4.5</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             RMSE  Pearson's r  seed  train_seed\n",
       "Used model        samples                                       \n",
       "Accuracy Model 1  10000    0.0177       0.7581   4.5         3.0\n",
       "Accuracy Model 2  10000    0.0211       0.6862   4.5         3.0\n",
       "IO Model 1        10000    0.0191       0.7323   4.5         3.0\n",
       "IO Model 2        10000    0.0214       0.6897   4.5         3.0\n",
       "arch2vec          10000    0.0209       0.7010   4.5         3.0\n",
       "arch2vec original 10000    0.0201       0.6879   4.5         1.0"
      ]
     },
     "execution_count": 147,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_df[res_df['samples'] == 10000].groupby(['Used model', 'samples']).mean().round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "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></th>\n",
       "      <th>RMSE</th>\n",
       "      <th>Pearson's r</th>\n",
       "      <th>seed</th>\n",
       "      <th>train_seed</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Used model</th>\n",
       "      <th>samples</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Accuracy Model 1</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0006</td>\n",
       "      <td>0.0053</td>\n",
       "      <td>1.8766</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Accuracy Model 2</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0010</td>\n",
       "      <td>0.0100</td>\n",
       "      <td>1.8766</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>IO Model 1</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0008</td>\n",
       "      <td>0.0089</td>\n",
       "      <td>1.8766</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>IO Model 2</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0077</td>\n",
       "      <td>1.8766</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>arch2vec</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0079</td>\n",
       "      <td>1.8766</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>arch2vec original</th>\n",
       "      <th>10000</th>\n",
       "      <td>0.0009</td>\n",
       "      <td>0.0094</td>\n",
       "      <td>1.8766</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             RMSE  Pearson's r    seed  train_seed\n",
       "Used model        samples                                         \n",
       "Accuracy Model 1  10000    0.0006       0.0053  1.8766         0.0\n",
       "Accuracy Model 2  10000    0.0010       0.0100  1.8766         0.0\n",
       "IO Model 1        10000    0.0008       0.0089  1.8766         0.0\n",
       "IO Model 2        10000    0.0009       0.0077  1.8766         0.0\n",
       "arch2vec          10000    0.0009       0.0079  1.8766         0.0\n",
       "arch2vec original 10000    0.0009       0.0094  1.8766         0.0"
      ]
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "(1.96 / np.sqrt(10) * res_df[res_df['samples'] == 10000].groupby(['Used model', 'samples']).std()).round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pyt_conda",
   "language": "python",
   "name": "pyt_conda"
  },
  "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"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
