{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['ettm12ettm1']"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#datasets = ['etth1','etth2','ettm1','ettm2']\n",
    "datasets = ['ettm1']\n",
    "datasets = [i+'2'+i for i in datasets]\n",
    "datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "DATA = datasets[0]\n",
    "DATA_PATH = f'../saved_models/{DATA}/masked_patchtst_sim/based_model/max' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_result(data, type_='max'):\n",
    "    load_epoch = 100\n",
    "    finetune_epoch = 20\n",
    "    target_list = [96,192,336,720]\n",
    "\n",
    "    DATA_PATH = f'../saved_models/{data}/masked_patchtst_sim/based_model/{type_}' \n",
    "    settings = os.listdir(DATA_PATH)\n",
    "    \n",
    "    n_done = 0\n",
    "    n_undone = 0\n",
    "    \n",
    "    result_dict = dict()\n",
    "    for target in target_list:\n",
    "        result_dict[target] = dict()\n",
    "        for setting in settings:\n",
    "            try:\n",
    "                FILE_PATH = os.path.join(DATA_PATH, setting, f'tw{target}_ft_ep{finetune_epoch}_model1_load_ep{load_epoch}_acc.csv')\n",
    "                result = pd.read_csv(FILE_PATH)\n",
    "                mse = result['mse'][0]\n",
    "                mae = result['mae'][0]\n",
    "                result_dict[target][setting] = [mse,mae]\n",
    "                n_done +=1\n",
    "            except:\n",
    "                #print(os.path.join(setting))\n",
    "                n_undone +=1\n",
    "        result_dict[target] = dict(sorted(result_dict[target].items(), key=lambda x: x[1][0]))    \n",
    "    print(n_done/(n_done+n_undone))\n",
    "    return result_dict\n",
    "            \n",
    "def get_target_best(result_dict, target_len):\n",
    "    assert target_len in [96,192,336,720]\n",
    "    data_target = result_dict[target_len]\n",
    "    best_settings = list(data_target.keys())[0]\n",
    "    best_mse = list(data_target.values())[0][0]\n",
    "    best_mae = list(data_target.values())[0][1]\n",
    "    return best_mse, best_mae, best_settings\n",
    "        "
   ]
  },
  {
   "attachments": {
    "image-2.png": {
     "image/png": "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"
    }
   },
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "![image-2.png](attachment:image-2.png)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "etth12etth1\n",
      "1.0\n",
      "0.37 0.4 patchtst_sim_pretrained_H4_D32_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.403 0.422 patchtst_sim_pretrained_H4_D16_F64_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.422 0.439 patchtst_sim_pretrained_H32_D128_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.455 0.471 patchtst_sim_pretrained_H8_D32_F64_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "==================================================\n",
      "etth22etth2\n",
      "1.0\n",
      "0.277 0.343 patchtst_sim_pretrained_H16_D64_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.337 0.387 patchtst_sim_pretrained_H16_D64_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.36 0.404 patchtst_sim_pretrained_H16_D64_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.391 0.433 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.3_model1_P0.5\n",
      "==================================================\n",
      "ettm12ettm1\n",
      "1.0\n",
      "0.284 0.344 patchtst_sim_pretrained_H16_D256_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.326 0.372 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.3_model1\n",
      "0.351 0.387 patchtst_sim_pretrained_H16_D256_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1\n",
      "0.395 0.415 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_mask-schedule0.2\n",
      "==================================================\n",
      "ettm22ettm2\n",
      "1.0\n",
      "0.168 0.259 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_mask-schedule0.1\n",
      "0.223 0.297 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_mask-schedule0.1\n",
      "0.273 0.331 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_mask-schedule0.2\n",
      "0.36 0.386 patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_mask-schedule0.2\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "datasets = ['etth1','etth2','ettm1','ettm2']\n",
    "datasets = [i+'2'+i for i in datasets]\n",
    "\n",
    "total_result = dict()\n",
    "for data in datasets:\n",
    "    print(data)\n",
    "    result_dict = get_result(data)\n",
    "    for target_len in [96,192,336,720]:\n",
    "        best_mse, best_mae, best_settings = get_target_best(result_dict, target_len)\n",
    "        print(best_mse.round(3), best_mae.round(3), best_settings)\n",
    "    print('='*50)\n",
    "    total_result[data] = result_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "import re\n",
    "\n",
    "df = pd.DataFrame()\n",
    "results = []\n",
    "for data in ['etth1','etth2','ettm1','ettm2']:\n",
    "    dataset = f'{data}2{data}'\n",
    "    for pred_len in [96,192,336,720]:\n",
    "        for i,v in total_result[dataset][pred_len].items():\n",
    "            if i.endswith('model1') & ('mask0.4' in i):\n",
    "                h_value = int(re.search(r'H(\\d+)', i).group(1))\n",
    "                d_value = int(re.search(r'D(\\d+)', i).group(1))\n",
    "                f_value = int(re.search(r'F(\\d+)', i).group(1))\n",
    "                results.append([h_value,d_value,f_value,data, pred_len, v[0],v[1]])\n",
    "\n",
    "df = pd.DataFrame(results)\n",
    "df.columns = ['H','D','F','data','pred_len','mse','mae']                "
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "결론 : etth1 : 16-128-256"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "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></th>\n",
       "      <th>mse</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>H</th>\n",
       "      <th>D</th>\n",
       "      <th>F</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">16</th>\n",
       "      <th>64</th>\n",
       "      <td>0.272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.269</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.263</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.262</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.266</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.270</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.266</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.266</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.260</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">16</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.259</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.265</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.264</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.261</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.265</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.284</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.269</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              mse\n",
       "H  D   F         \n",
       "4  16  64   0.272\n",
       "       128  0.269\n",
       "       256  0.272\n",
       "   32  64   0.263\n",
       "       128  0.262\n",
       "       256  0.266\n",
       "8  32  64   0.270\n",
       "       128  0.266\n",
       "   64  128  0.266\n",
       "       256  0.260\n",
       "16 64  128  0.272\n",
       "       256  0.259\n",
       "   128 256  0.265\n",
       "       512  0.264\n",
       "   256 512  0.261\n",
       "32 128 256  0.265\n",
       "       512  0.284\n",
       "   256 512  0.269"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame(df[df['data'] == 'ettm2'].groupby(['H','D','F'])['mse'].mean()).sort_index(level=0).round(3)\n",
    "# etth1 : \n",
    "# (1) 4-32-256\n",
    "# (2)16-128-256"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "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></th>\n",
       "      <th>mse</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>H</th>\n",
       "      <th>D</th>\n",
       "      <th>F</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">16</th>\n",
       "      <th>64</th>\n",
       "      <td>0.356774</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.367942</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.371444</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.371331</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.356994</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.373292</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.364928</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.369675</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.358391</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.368895</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">16</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.346274</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.375611</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.345067</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.358859</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.364641</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.353620</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.353801</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.363742</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 mse\n",
       "H  D   F            \n",
       "4  16  64   0.356774\n",
       "       128  0.367942\n",
       "       256  0.371444\n",
       "   32  64   0.371331\n",
       "       128  0.356994\n",
       "       256  0.373292\n",
       "8  32  64   0.364928\n",
       "       128  0.369675\n",
       "   64  128  0.358391\n",
       "       256  0.368895\n",
       "16 64  128  0.346274\n",
       "       256  0.375611\n",
       "   128 256  0.345067\n",
       "       512  0.358859\n",
       "   256 512  0.364641\n",
       "32 128 256  0.353620\n",
       "       512  0.353801\n",
       "   256 512  0.363742"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame(df[df['data'] == 'etth2'].groupby(['H','D','F'])['mse'].mean())\n",
    "# etth2 : \n",
    "# (1)16-128-256\n",
    "# (2)16-64-128"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "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></th>\n",
       "      <th>mse</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>H</th>\n",
       "      <th>D</th>\n",
       "      <th>F</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">16</th>\n",
       "      <th>64</th>\n",
       "      <td>0.357783</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.353772</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.357825</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.354769</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.352102</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.351800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.367977</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.348314</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.348368</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.346534</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">16</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.350888</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.348063</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.352736</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.345336</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.341181</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.351393</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.352367</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.348636</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 mse\n",
       "H  D   F            \n",
       "4  16  64   0.357783\n",
       "       128  0.353772\n",
       "       256  0.357825\n",
       "   32  64   0.354769\n",
       "       128  0.352102\n",
       "       256  0.351800\n",
       "8  32  64   0.367977\n",
       "       128  0.348314\n",
       "   64  128  0.348368\n",
       "       256  0.346534\n",
       "16 64  128  0.350888\n",
       "       256  0.348063\n",
       "   128 256  0.352736\n",
       "       512  0.345336\n",
       "   256 512  0.341181\n",
       "32 128 256  0.351393\n",
       "       512  0.352367\n",
       "   256 512  0.348636"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame(df[df['data'] == 'ettm1'].groupby(['H','D','F'])['mse'].mean())\n",
    "# ettm1 : \n",
    "# (1)16-256-512\n",
    "# (2)16-128-512"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "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></th>\n",
       "      <th>mse</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>H</th>\n",
       "      <th>D</th>\n",
       "      <th>F</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">16</th>\n",
       "      <th>64</th>\n",
       "      <td>0.272486</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.268587</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.271506</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.262736</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.262088</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.266402</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">32</th>\n",
       "      <th>64</th>\n",
       "      <td>0.269514</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>0.266281</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.266185</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.260441</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">16</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">64</th>\n",
       "      <th>128</th>\n",
       "      <td>0.271817</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.259393</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.264780</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.263575</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.261319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">32</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">128</th>\n",
       "      <th>256</th>\n",
       "      <td>0.265231</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>0.283996</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <th>512</th>\n",
       "      <td>0.269430</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 mse\n",
       "H  D   F            \n",
       "4  16  64   0.272486\n",
       "       128  0.268587\n",
       "       256  0.271506\n",
       "   32  64   0.262736\n",
       "       128  0.262088\n",
       "       256  0.266402\n",
       "8  32  64   0.269514\n",
       "       128  0.266281\n",
       "   64  128  0.266185\n",
       "       256  0.260441\n",
       "16 64  128  0.271817\n",
       "       256  0.259393\n",
       "   128 256  0.264780\n",
       "       512  0.263575\n",
       "   256 512  0.261319\n",
       "32 128 256  0.265231\n",
       "       512  0.283996\n",
       "   256 512  0.269430"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame(df[df['data'] == 'ettm2'].groupby(['H','D','F'])['mse'].mean())\n",
    "# ettm2 : \n",
    "# (1)16-64-256\n",
    "# (2)8-64-256\n",
    "# (3)4-32-64\n",
    "# (4)4-32-128\n",
    "# (5)16-129-512"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "patchtst_sim_pretrained_H8_D32_F64_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.455192, 0.47092]\n",
      "patchtst_sim_pretrained_H8_D64_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.455839, 0.474236]\n",
      "patchtst_sim_pretrained_H8_D32_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.457963, 0.473415]\n",
      "patchtst_sim_pretrained_H4_D32_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.460437, 0.474965]\n",
      "patchtst_sim_pretrained_H32_D256_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.464053, 0.485177]\n",
      "patchtst_sim_pretrained_H4_D32_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.468212, 0.473793]\n",
      "patchtst_sim_pretrained_H4_D16_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.470767, 0.481647]\n",
      "patchtst_sim_pretrained_H4_D16_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.475825, 0.485349]\n",
      "patchtst_sim_pretrained_H16_D256_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.484956, 0.497213]\n",
      "patchtst_sim_pretrained_H4_D32_F64_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.486063, 0.48404]\n",
      "patchtst_sim_pretrained_H16_D64_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.490647, 0.495229]\n",
      "patchtst_sim_pretrained_H8_D64_F128_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.491768, 0.491648]\n",
      "patchtst_sim_pretrained_H32_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.495185, 0.501881]\n",
      "patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.509426, 0.494507]\n",
      "patchtst_sim_pretrained_H32_D128_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.512091, 0.509945]\n",
      "patchtst_sim_pretrained_H16_D128_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.527447, 0.517105]\n",
      "patchtst_sim_pretrained_H16_D64_F256_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.530626, 0.506133]\n",
      "patchtst_sim_pretrained_H4_D16_F64_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1 [0.53578, 0.521858]\n"
     ]
    }
   ],
   "source": [
    "dataset = 'etth1'\n",
    "dataset = f'{dataset}2{dataset}'\n",
    "length = 720\n",
    "\n",
    "for k,v in total_result[dataset][length].items():\n",
    "    #print(k.split('pretrain100_')[1].replace('_model1','').rjust(55),v)\n",
    "    #=================================================#\n",
    "    if k.endswith('mask0.4_model1'):\n",
    "        print(k,v)\n",
    "    #=================================================#    \n",
    "    #print(k,v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import fnmatch\n",
    "\n",
    "def find_files(directory, pattern):\n",
    "    matches = []\n",
    "    for root, dirnames, filenames in os.walk(directory):\n",
    "        for filename in fnmatch.filter(filenames, pattern):\n",
    "            print(filename)\n",
    "            matches.append(os.path.join(root, filename))\n",
    "    return matches\n",
    "\n",
    "dataset = 'etth1'\n",
    "pattern = '*MASK_END*/*acc.csv'\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.4_model1_MASK_END\n",
      "/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_MASK_END\n",
      "/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.3_model1_MASK_END\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "def find_folders_with_keyword(root_folder, keyword, keywords_list):\n",
    "    matching_folders = []\n",
    "\n",
    "    for root, dirs, files in os.walk(root_folder):\n",
    "        for folder in dirs:\n",
    "            if 'H16_D128_F512' in folder:                \n",
    "                if keyword is None:\n",
    "                    if folder.endswith('_model1'):\n",
    "                        matching_folders.append(os.path.join(root, folder))\n",
    "                    \n",
    "                elif keyword in folder:\n",
    "                    is_in = 0\n",
    "                    for k in list(set(keywords_list)-set([keyword])):\n",
    "                        if k in folder:\n",
    "                            is_in +=1\n",
    "                    if is_in == 0:\n",
    "                        \n",
    "                        matching_folders.append(os.path.join(root, folder))\n",
    "                \n",
    "\n",
    "    return matching_folders\n",
    "\n",
    "dataset = 'etth1'\n",
    "root_folder = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{dataset}2{dataset}'\n",
    "keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']\n",
    "\n",
    "keyword = keywords_list[1]\n",
    "result = find_folders_with_keyword(root_folder, keyword, keywords_list)\n",
    "for r in result:\n",
    "    print(r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_list = ['etth1','etth2','ettm1','ettm2']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def get_data_df(data='etth1', keyword='mask-schedule', pred_length_list=[96,192,336,720]):\n",
    "    root_folder = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}'\n",
    "    keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']    \n",
    "    result = find_folders_with_keyword(root_folder, keyword, keywords_list)\n",
    "    df = pd.DataFrame()\n",
    "    for r in result:\n",
    "        col = r.split('pretrain100_')[1].replace('_model1','')\n",
    "        df[col] = np.nan\n",
    "        for idx,pred_l in enumerate(pred_length_list):\n",
    "            result = pd.read_csv(os.path.join(r,f'tw{pred_l}_ft_ep20_model1_load_ep100_acc.csv'))\n",
    "            df.loc[idx,col] = result['mse'].values[0]\n",
    "    df.index = pred_length_list\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_result_keyword(keyword='mask-schedule'):\n",
    "    df_etth1 = get_data_df(data='etth1', keyword=keyword, pred_length_list=[96,192,336,720])\n",
    "    df_etth2 = get_data_df(data='etth2', keyword=keyword, pred_length_list=[96,192,336,720])\n",
    "    df_ettm1 = get_data_df(data='ettm1', keyword=keyword, pred_length_list=[96,192,336,720])\n",
    "    df_ettm2 = get_data_df(data='ettm2', keyword=keyword, pred_length_list=[96,192,336,720])\n",
    "    result_df = pd.concat([df_etth1,df_etth2,df_ettm1,df_ettm2], axis=0)\n",
    "    print('OVERALL')    \n",
    "    print(result_df.mean(axis=0).sort_values())\n",
    "    print('-'*50)\n",
    "    for i in [96,192,336,720]:\n",
    "        print(f'===pred length ={i}')    \n",
    "        print(result_df.loc[i].mean().sort_values())\n",
    "        print('-'*50)\n",
    "    return result_df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OVERALL\n",
      "mask0.4    0.351701\n",
      "mask0.5    0.353582\n",
      "mask0.3    0.353826\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =96\n",
      "mask0.3    0.284057\n",
      "mask0.4    0.292079\n",
      "mask0.5    0.295885\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =192\n",
      "mask0.4    0.332042\n",
      "mask0.3    0.334697\n",
      "mask0.5    0.339402\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =336\n",
      "mask0.4    0.363379\n",
      "mask0.3    0.367915\n",
      "mask0.5    0.368056\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =720\n",
      "mask0.5    0.410984\n",
      "mask0.4    0.419304\n",
      "mask0.3    0.428634\n",
      "dtype: float64\n",
      "--------------------------------------------------\n"
     ]
    },
    {
     "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>mask0.3</th>\n",
       "      <th>mask0.5</th>\n",
       "      <th>mask0.4</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.387018</td>\n",
       "      <td>0.377367</td>\n",
       "      <td>0.384863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.433002</td>\n",
       "      <td>0.407819</td>\n",
       "      <td>0.415162</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.460197</td>\n",
       "      <td>0.436162</td>\n",
       "      <td>0.446684</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.541272</td>\n",
       "      <td>0.462635</td>\n",
       "      <td>0.509426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.289311</td>\n",
       "      <td>0.303236</td>\n",
       "      <td>0.314169</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.352374</td>\n",
       "      <td>0.371211</td>\n",
       "      <td>0.349617</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.370297</td>\n",
       "      <td>0.373515</td>\n",
       "      <td>0.370805</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.400957</td>\n",
       "      <td>0.395232</td>\n",
       "      <td>0.400847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.289627</td>\n",
       "      <td>0.288981</td>\n",
       "      <td>0.288867</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.326312</td>\n",
       "      <td>0.341184</td>\n",
       "      <td>0.334277</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.355216</td>\n",
       "      <td>0.362713</td>\n",
       "      <td>0.354845</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.404648</td>\n",
       "      <td>0.410562</td>\n",
       "      <td>0.403354</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.170273</td>\n",
       "      <td>0.213956</td>\n",
       "      <td>0.180416</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.227099</td>\n",
       "      <td>0.237393</td>\n",
       "      <td>0.229113</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.285951</td>\n",
       "      <td>0.299835</td>\n",
       "      <td>0.281182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.367658</td>\n",
       "      <td>0.375506</td>\n",
       "      <td>0.363588</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      mask0.3   mask0.5   mask0.4\n",
       "96   0.387018  0.377367  0.384863\n",
       "192  0.433002  0.407819  0.415162\n",
       "336  0.460197  0.436162  0.446684\n",
       "720  0.541272  0.462635  0.509426\n",
       "96   0.289311  0.303236  0.314169\n",
       "192  0.352374  0.371211  0.349617\n",
       "336  0.370297  0.373515  0.370805\n",
       "720  0.400957  0.395232  0.400847\n",
       "96   0.289627  0.288981  0.288867\n",
       "192  0.326312  0.341184  0.334277\n",
       "336  0.355216  0.362713  0.354845\n",
       "720  0.404648  0.410562  0.403354\n",
       "96   0.170273  0.213956  0.180416\n",
       "192  0.227099  0.237393  0.229113\n",
       "336  0.285951  0.299835  0.281182\n",
       "720  0.367658  0.375506  0.363588"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pred_length = [96,192,336,720]\n",
    "result_df = get_result_keyword(keyword=None)\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OVERALL\n",
      "mask0.5_mask-schedule0.1    0.349581\n",
      "mask0.4_mask-schedule0.2    0.349811\n",
      "mask0.5_mask-schedule0.2    0.351565\n",
      "mask0.4_mask-schedule0.1    0.353896\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =96\n",
      "mask0.4_mask-schedule0.1    0.286919\n",
      "mask0.5_mask-schedule0.2    0.287432\n",
      "mask0.4_mask-schedule0.2    0.287868\n",
      "mask0.5_mask-schedule0.1    0.287978\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =192\n",
      "mask0.5_mask-schedule0.1    0.331444\n",
      "mask0.4_mask-schedule0.1    0.336923\n",
      "mask0.5_mask-schedule0.2    0.337265\n",
      "mask0.4_mask-schedule0.2    0.338629\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =336\n",
      "mask0.5_mask-schedule0.2    0.360040\n",
      "mask0.4_mask-schedule0.2    0.360824\n",
      "mask0.5_mask-schedule0.1    0.365739\n",
      "mask0.4_mask-schedule0.1    0.366353\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =720\n",
      "mask0.4_mask-schedule0.2    0.411924\n",
      "mask0.5_mask-schedule0.1    0.413165\n",
      "mask0.5_mask-schedule0.2    0.421524\n",
      "mask0.4_mask-schedule0.1    0.425390\n",
      "dtype: float64\n",
      "--------------------------------------------------\n"
     ]
    },
    {
     "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>mask0.4_mask-schedule0.2</th>\n",
       "      <th>mask0.5_mask-schedule0.1</th>\n",
       "      <th>mask0.5_mask-schedule0.2</th>\n",
       "      <th>mask0.4_mask-schedule0.1</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.384790</td>\n",
       "      <td>0.384036</td>\n",
       "      <td>0.386195</td>\n",
       "      <td>0.385854</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.428505</td>\n",
       "      <td>0.411701</td>\n",
       "      <td>0.435280</td>\n",
       "      <td>0.436045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.435404</td>\n",
       "      <td>0.451815</td>\n",
       "      <td>0.439610</td>\n",
       "      <td>0.448847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.483630</td>\n",
       "      <td>0.483680</td>\n",
       "      <td>0.522032</td>\n",
       "      <td>0.499003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.302648</td>\n",
       "      <td>0.313119</td>\n",
       "      <td>0.303616</td>\n",
       "      <td>0.302116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.367239</td>\n",
       "      <td>0.358246</td>\n",
       "      <td>0.353807</td>\n",
       "      <td>0.359158</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.368519</td>\n",
       "      <td>0.381558</td>\n",
       "      <td>0.371180</td>\n",
       "      <td>0.380192</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.394221</td>\n",
       "      <td>0.400118</td>\n",
       "      <td>0.408825</td>\n",
       "      <td>0.431808</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.292342</td>\n",
       "      <td>0.286610</td>\n",
       "      <td>0.285482</td>\n",
       "      <td>0.284845</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.328809</td>\n",
       "      <td>0.333291</td>\n",
       "      <td>0.334031</td>\n",
       "      <td>0.328702</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.358987</td>\n",
       "      <td>0.355437</td>\n",
       "      <td>0.356171</td>\n",
       "      <td>0.354948</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.402364</td>\n",
       "      <td>0.405441</td>\n",
       "      <td>0.395285</td>\n",
       "      <td>0.397949</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.171694</td>\n",
       "      <td>0.168148</td>\n",
       "      <td>0.174434</td>\n",
       "      <td>0.174862</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.229963</td>\n",
       "      <td>0.222536</td>\n",
       "      <td>0.225941</td>\n",
       "      <td>0.223785</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.280386</td>\n",
       "      <td>0.274147</td>\n",
       "      <td>0.273199</td>\n",
       "      <td>0.281424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.367480</td>\n",
       "      <td>0.363421</td>\n",
       "      <td>0.359955</td>\n",
       "      <td>0.372799</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     mask0.4_mask-schedule0.2  mask0.5_mask-schedule0.1   \n",
       "96                   0.384790                  0.384036  \\\n",
       "192                  0.428505                  0.411701   \n",
       "336                  0.435404                  0.451815   \n",
       "720                  0.483630                  0.483680   \n",
       "96                   0.302648                  0.313119   \n",
       "192                  0.367239                  0.358246   \n",
       "336                  0.368519                  0.381558   \n",
       "720                  0.394221                  0.400118   \n",
       "96                   0.292342                  0.286610   \n",
       "192                  0.328809                  0.333291   \n",
       "336                  0.358987                  0.355437   \n",
       "720                  0.402364                  0.405441   \n",
       "96                   0.171694                  0.168148   \n",
       "192                  0.229963                  0.222536   \n",
       "336                  0.280386                  0.274147   \n",
       "720                  0.367480                  0.363421   \n",
       "\n",
       "     mask0.5_mask-schedule0.2  mask0.4_mask-schedule0.1  \n",
       "96                   0.386195                  0.385854  \n",
       "192                  0.435280                  0.436045  \n",
       "336                  0.439610                  0.448847  \n",
       "720                  0.522032                  0.499003  \n",
       "96                   0.303616                  0.302116  \n",
       "192                  0.353807                  0.359158  \n",
       "336                  0.371180                  0.380192  \n",
       "720                  0.408825                  0.431808  \n",
       "96                   0.285482                  0.284845  \n",
       "192                  0.334031                  0.328702  \n",
       "336                  0.356171                  0.354948  \n",
       "720                  0.395285                  0.397949  \n",
       "96                   0.174434                  0.174862  \n",
       "192                  0.225941                  0.223785  \n",
       "336                  0.273199                  0.281424  \n",
       "720                  0.359955                  0.372799  "
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pred_length = [96,192,336,720]\n",
    "#keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']\n",
    "result_df = get_result_keyword(keyword='mask-schedule')\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OVERALL\n",
      "mask0.3_mse_gaussian_5.0     0.350596\n",
      "mask0.5_mse_gaussian_5.0     0.358861\n",
      "mask0.4_mse_gaussian_5.0     0.359401\n",
      "mask0.5_mse_gaussian_10.0    0.362251\n",
      "mask0.3_mse_gaussian_10.0    0.365140\n",
      "mask0.4_mse_gaussian_10.0    0.366750\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =96\n",
      "mask0.3_mse_gaussian_5.0     0.287092\n",
      "mask0.5_mse_gaussian_5.0     0.289959\n",
      "mask0.5_mse_gaussian_10.0    0.293979\n",
      "mask0.4_mse_gaussian_5.0     0.298075\n",
      "mask0.3_mse_gaussian_10.0    0.299260\n",
      "mask0.4_mse_gaussian_10.0    0.299650\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =192\n",
      "mask0.3_mse_gaussian_5.0     0.340011\n",
      "mask0.5_mse_gaussian_10.0    0.346232\n",
      "mask0.4_mse_gaussian_5.0     0.348343\n",
      "mask0.5_mse_gaussian_5.0     0.351547\n",
      "mask0.4_mse_gaussian_10.0    0.353033\n",
      "mask0.3_mse_gaussian_10.0    0.354620\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =336\n",
      "mask0.3_mse_gaussian_5.0     0.367587\n",
      "mask0.5_mse_gaussian_5.0     0.368962\n",
      "mask0.4_mse_gaussian_5.0     0.373692\n",
      "mask0.5_mse_gaussian_10.0    0.379438\n",
      "mask0.4_mse_gaussian_10.0    0.382319\n",
      "mask0.3_mse_gaussian_10.0    0.382365\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =720\n",
      "mask0.3_mse_gaussian_5.0     0.407695\n",
      "mask0.4_mse_gaussian_5.0     0.417494\n",
      "mask0.3_mse_gaussian_10.0    0.424317\n",
      "mask0.5_mse_gaussian_5.0     0.424975\n",
      "mask0.5_mse_gaussian_10.0    0.429357\n",
      "mask0.4_mse_gaussian_10.0    0.431998\n",
      "dtype: float64\n",
      "--------------------------------------------------\n"
     ]
    },
    {
     "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>mask0.4_mse_gaussian_5.0</th>\n",
       "      <th>mask0.3_mse_gaussian_5.0</th>\n",
       "      <th>mask0.4_mse_gaussian_10.0</th>\n",
       "      <th>mask0.5_mse_gaussian_10.0</th>\n",
       "      <th>mask0.5_mse_gaussian_5.0</th>\n",
       "      <th>mask0.3_mse_gaussian_10.0</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.376049</td>\n",
       "      <td>0.373170</td>\n",
       "      <td>0.379503</td>\n",
       "      <td>0.384321</td>\n",
       "      <td>0.381997</td>\n",
       "      <td>0.373616</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.432817</td>\n",
       "      <td>0.407320</td>\n",
       "      <td>0.442580</td>\n",
       "      <td>0.420655</td>\n",
       "      <td>0.426859</td>\n",
       "      <td>0.424760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.443953</td>\n",
       "      <td>0.439269</td>\n",
       "      <td>0.468491</td>\n",
       "      <td>0.471493</td>\n",
       "      <td>0.421980</td>\n",
       "      <td>0.462787</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.476772</td>\n",
       "      <td>0.458302</td>\n",
       "      <td>0.517995</td>\n",
       "      <td>0.494126</td>\n",
       "      <td>0.508492</td>\n",
       "      <td>0.473948</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.299702</td>\n",
       "      <td>0.286414</td>\n",
       "      <td>0.305045</td>\n",
       "      <td>0.293264</td>\n",
       "      <td>0.296223</td>\n",
       "      <td>0.304631</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.359072</td>\n",
       "      <td>0.351243</td>\n",
       "      <td>0.362959</td>\n",
       "      <td>0.373224</td>\n",
       "      <td>0.376220</td>\n",
       "      <td>0.372347</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.377945</td>\n",
       "      <td>0.381475</td>\n",
       "      <td>0.383704</td>\n",
       "      <td>0.381165</td>\n",
       "      <td>0.378996</td>\n",
       "      <td>0.374122</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.395453</td>\n",
       "      <td>0.391736</td>\n",
       "      <td>0.410945</td>\n",
       "      <td>0.410938</td>\n",
       "      <td>0.398588</td>\n",
       "      <td>0.419543</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.294473</td>\n",
       "      <td>0.306522</td>\n",
       "      <td>0.306744</td>\n",
       "      <td>0.294706</td>\n",
       "      <td>0.295726</td>\n",
       "      <td>0.330580</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.338861</td>\n",
       "      <td>0.343037</td>\n",
       "      <td>0.346632</td>\n",
       "      <td>0.337982</td>\n",
       "      <td>0.339950</td>\n",
       "      <td>0.372446</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.366254</td>\n",
       "      <td>0.362470</td>\n",
       "      <td>0.371886</td>\n",
       "      <td>0.367613</td>\n",
       "      <td>0.359840</td>\n",
       "      <td>0.393240</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.404412</td>\n",
       "      <td>0.409931</td>\n",
       "      <td>0.412301</td>\n",
       "      <td>0.406195</td>\n",
       "      <td>0.405436</td>\n",
       "      <td>0.427940</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.222077</td>\n",
       "      <td>0.182263</td>\n",
       "      <td>0.207308</td>\n",
       "      <td>0.203624</td>\n",
       "      <td>0.185889</td>\n",
       "      <td>0.188212</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.262620</td>\n",
       "      <td>0.258442</td>\n",
       "      <td>0.259961</td>\n",
       "      <td>0.253066</td>\n",
       "      <td>0.263160</td>\n",
       "      <td>0.248926</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.306615</td>\n",
       "      <td>0.287133</td>\n",
       "      <td>0.305197</td>\n",
       "      <td>0.297481</td>\n",
       "      <td>0.315031</td>\n",
       "      <td>0.299313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.393338</td>\n",
       "      <td>0.370810</td>\n",
       "      <td>0.386751</td>\n",
       "      <td>0.406170</td>\n",
       "      <td>0.387383</td>\n",
       "      <td>0.375837</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     mask0.4_mse_gaussian_5.0  mask0.3_mse_gaussian_5.0   \n",
       "96                   0.376049                  0.373170  \\\n",
       "192                  0.432817                  0.407320   \n",
       "336                  0.443953                  0.439269   \n",
       "720                  0.476772                  0.458302   \n",
       "96                   0.299702                  0.286414   \n",
       "192                  0.359072                  0.351243   \n",
       "336                  0.377945                  0.381475   \n",
       "720                  0.395453                  0.391736   \n",
       "96                   0.294473                  0.306522   \n",
       "192                  0.338861                  0.343037   \n",
       "336                  0.366254                  0.362470   \n",
       "720                  0.404412                  0.409931   \n",
       "96                   0.222077                  0.182263   \n",
       "192                  0.262620                  0.258442   \n",
       "336                  0.306615                  0.287133   \n",
       "720                  0.393338                  0.370810   \n",
       "\n",
       "     mask0.4_mse_gaussian_10.0  mask0.5_mse_gaussian_10.0   \n",
       "96                    0.379503                   0.384321  \\\n",
       "192                   0.442580                   0.420655   \n",
       "336                   0.468491                   0.471493   \n",
       "720                   0.517995                   0.494126   \n",
       "96                    0.305045                   0.293264   \n",
       "192                   0.362959                   0.373224   \n",
       "336                   0.383704                   0.381165   \n",
       "720                   0.410945                   0.410938   \n",
       "96                    0.306744                   0.294706   \n",
       "192                   0.346632                   0.337982   \n",
       "336                   0.371886                   0.367613   \n",
       "720                   0.412301                   0.406195   \n",
       "96                    0.207308                   0.203624   \n",
       "192                   0.259961                   0.253066   \n",
       "336                   0.305197                   0.297481   \n",
       "720                   0.386751                   0.406170   \n",
       "\n",
       "     mask0.5_mse_gaussian_5.0  mask0.3_mse_gaussian_10.0  \n",
       "96                   0.381997                   0.373616  \n",
       "192                  0.426859                   0.424760  \n",
       "336                  0.421980                   0.462787  \n",
       "720                  0.508492                   0.473948  \n",
       "96                   0.296223                   0.304631  \n",
       "192                  0.376220                   0.372347  \n",
       "336                  0.378996                   0.374122  \n",
       "720                  0.398588                   0.419543  \n",
       "96                   0.295726                   0.330580  \n",
       "192                  0.339950                   0.372446  \n",
       "336                  0.359840                   0.393240  \n",
       "720                  0.405436                   0.427940  \n",
       "96                   0.185889                   0.188212  \n",
       "192                  0.263160                   0.248926  \n",
       "336                  0.315031                   0.299313  \n",
       "720                  0.387383                   0.375837  "
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']\n",
    "result_df = get_result_keyword(keyword='mse_gaussian')\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OVERALL\n",
      "mask0.3_MASK_END    0.350426\n",
      "mask0.4_MASK_END    0.357702\n",
      "mask0.5_MASK_END    0.361507\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =96\n",
      "mask0.4_MASK_END    0.285479\n",
      "mask0.3_MASK_END    0.286117\n",
      "mask0.5_MASK_END    0.291806\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =192\n",
      "mask0.4_MASK_END    0.333174\n",
      "mask0.3_MASK_END    0.333541\n",
      "mask0.5_MASK_END    0.352260\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =336\n",
      "mask0.3_MASK_END    0.365108\n",
      "mask0.4_MASK_END    0.370503\n",
      "mask0.5_MASK_END    0.375150\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =720\n",
      "mask0.3_MASK_END    0.416940\n",
      "mask0.5_MASK_END    0.426813\n",
      "mask0.4_MASK_END    0.441652\n",
      "dtype: float64\n",
      "--------------------------------------------------\n"
     ]
    },
    {
     "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>mask0.4_MASK_END</th>\n",
       "      <th>mask0.5_MASK_END</th>\n",
       "      <th>mask0.3_MASK_END</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.377920</td>\n",
       "      <td>0.388654</td>\n",
       "      <td>0.386809</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.414004</td>\n",
       "      <td>0.428453</td>\n",
       "      <td>0.419379</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.463393</td>\n",
       "      <td>0.440608</td>\n",
       "      <td>0.435657</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.586099</td>\n",
       "      <td>0.487521</td>\n",
       "      <td>0.490577</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.297853</td>\n",
       "      <td>0.303707</td>\n",
       "      <td>0.292294</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.358158</td>\n",
       "      <td>0.401552</td>\n",
       "      <td>0.353049</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.380560</td>\n",
       "      <td>0.403168</td>\n",
       "      <td>0.389355</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.410233</td>\n",
       "      <td>0.412639</td>\n",
       "      <td>0.409192</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.291523</td>\n",
       "      <td>0.299627</td>\n",
       "      <td>0.293852</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.331741</td>\n",
       "      <td>0.343830</td>\n",
       "      <td>0.331865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.356746</td>\n",
       "      <td>0.368488</td>\n",
       "      <td>0.358206</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.403320</td>\n",
       "      <td>0.427028</td>\n",
       "      <td>0.402566</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.174620</td>\n",
       "      <td>0.175237</td>\n",
       "      <td>0.171512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.228791</td>\n",
       "      <td>0.235207</td>\n",
       "      <td>0.229869</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.281314</td>\n",
       "      <td>0.288338</td>\n",
       "      <td>0.277212</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.366955</td>\n",
       "      <td>0.380063</td>\n",
       "      <td>0.365424</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     mask0.4_MASK_END  mask0.5_MASK_END  mask0.3_MASK_END\n",
       "96           0.377920          0.388654          0.386809\n",
       "192          0.414004          0.428453          0.419379\n",
       "336          0.463393          0.440608          0.435657\n",
       "720          0.586099          0.487521          0.490577\n",
       "96           0.297853          0.303707          0.292294\n",
       "192          0.358158          0.401552          0.353049\n",
       "336          0.380560          0.403168          0.389355\n",
       "720          0.410233          0.412639          0.409192\n",
       "96           0.291523          0.299627          0.293852\n",
       "192          0.331741          0.343830          0.331865\n",
       "336          0.356746          0.368488          0.358206\n",
       "720          0.403320          0.427028          0.402566\n",
       "96           0.174620          0.175237          0.171512\n",
       "192          0.228791          0.235207          0.229869\n",
       "336          0.281314          0.288338          0.277212\n",
       "720          0.366955          0.380063          0.365424"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']\n",
    "result_df = get_result_keyword(keyword='MASK_END')\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OVERALL\n",
      "mask0.4_P0.5    0.346823\n",
      "mask0.3_P0.5    0.347852\n",
      "mask0.5_P1.0    0.351330\n",
      "mask0.5_P0.5    0.352022\n",
      "mask0.3_P1.0    0.352262\n",
      "mask0.4_P1.0    0.357918\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =96\n",
      "mask0.4_P0.5    0.283547\n",
      "mask0.3_P0.5    0.288430\n",
      "mask0.5_P0.5    0.288457\n",
      "mask0.5_P1.0    0.288566\n",
      "mask0.3_P1.0    0.292127\n",
      "mask0.4_P1.0    0.296631\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =192\n",
      "mask0.3_P1.0    0.330492\n",
      "mask0.3_P0.5    0.332102\n",
      "mask0.5_P1.0    0.334049\n",
      "mask0.4_P0.5    0.335115\n",
      "mask0.4_P1.0    0.342810\n",
      "mask0.5_P0.5    0.343637\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =336\n",
      "mask0.4_P0.5    0.358931\n",
      "mask0.3_P0.5    0.362310\n",
      "mask0.5_P1.0    0.366759\n",
      "mask0.5_P0.5    0.367082\n",
      "mask0.3_P1.0    0.371445\n",
      "mask0.4_P1.0    0.371592\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =720\n",
      "mask0.3_P0.5    0.408564\n",
      "mask0.5_P0.5    0.408910\n",
      "mask0.4_P0.5    0.409697\n",
      "mask0.3_P1.0    0.414984\n",
      "mask0.5_P1.0    0.415949\n",
      "mask0.4_P1.0    0.420641\n",
      "dtype: float64\n",
      "--------------------------------------------------\n"
     ]
    },
    {
     "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>mask0.4_P1.0</th>\n",
       "      <th>mask0.3_P1.0</th>\n",
       "      <th>mask0.5_P1.0</th>\n",
       "      <th>mask0.4_P0.5</th>\n",
       "      <th>mask0.3_P0.5</th>\n",
       "      <th>mask0.5_P0.5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.387977</td>\n",
       "      <td>0.385649</td>\n",
       "      <td>0.383013</td>\n",
       "      <td>0.381040</td>\n",
       "      <td>0.390405</td>\n",
       "      <td>0.404535</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.423599</td>\n",
       "      <td>0.415788</td>\n",
       "      <td>0.420193</td>\n",
       "      <td>0.415890</td>\n",
       "      <td>0.413327</td>\n",
       "      <td>0.420396</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.460139</td>\n",
       "      <td>0.462411</td>\n",
       "      <td>0.451758</td>\n",
       "      <td>0.427630</td>\n",
       "      <td>0.438120</td>\n",
       "      <td>0.449150</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.497545</td>\n",
       "      <td>0.488928</td>\n",
       "      <td>0.501920</td>\n",
       "      <td>0.469823</td>\n",
       "      <td>0.462707</td>\n",
       "      <td>0.457576</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.307985</td>\n",
       "      <td>0.306750</td>\n",
       "      <td>0.310644</td>\n",
       "      <td>0.284757</td>\n",
       "      <td>0.303994</td>\n",
       "      <td>0.277953</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.347002</td>\n",
       "      <td>0.345672</td>\n",
       "      <td>0.351378</td>\n",
       "      <td>0.345447</td>\n",
       "      <td>0.346953</td>\n",
       "      <td>0.339948</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.365663</td>\n",
       "      <td>0.386517</td>\n",
       "      <td>0.376869</td>\n",
       "      <td>0.366474</td>\n",
       "      <td>0.373882</td>\n",
       "      <td>0.364921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.400531</td>\n",
       "      <td>0.397623</td>\n",
       "      <td>0.392212</td>\n",
       "      <td>0.398603</td>\n",
       "      <td>0.391183</td>\n",
       "      <td>0.392971</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.291515</td>\n",
       "      <td>0.287913</td>\n",
       "      <td>0.289079</td>\n",
       "      <td>0.298560</td>\n",
       "      <td>0.287966</td>\n",
       "      <td>0.287443</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.336320</td>\n",
       "      <td>0.334511</td>\n",
       "      <td>0.332486</td>\n",
       "      <td>0.338825</td>\n",
       "      <td>0.335239</td>\n",
       "      <td>0.334505</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.361261</td>\n",
       "      <td>0.359739</td>\n",
       "      <td>0.359560</td>\n",
       "      <td>0.360062</td>\n",
       "      <td>0.356298</td>\n",
       "      <td>0.364194</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.405975</td>\n",
       "      <td>0.410993</td>\n",
       "      <td>0.403744</td>\n",
       "      <td>0.403688</td>\n",
       "      <td>0.399416</td>\n",
       "      <td>0.410393</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.199049</td>\n",
       "      <td>0.188197</td>\n",
       "      <td>0.171527</td>\n",
       "      <td>0.169833</td>\n",
       "      <td>0.171356</td>\n",
       "      <td>0.183899</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.264318</td>\n",
       "      <td>0.225997</td>\n",
       "      <td>0.232137</td>\n",
       "      <td>0.240300</td>\n",
       "      <td>0.232889</td>\n",
       "      <td>0.279701</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.299304</td>\n",
       "      <td>0.277113</td>\n",
       "      <td>0.278847</td>\n",
       "      <td>0.281558</td>\n",
       "      <td>0.280939</td>\n",
       "      <td>0.290063</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.378512</td>\n",
       "      <td>0.362394</td>\n",
       "      <td>0.365920</td>\n",
       "      <td>0.366672</td>\n",
       "      <td>0.380952</td>\n",
       "      <td>0.374701</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     mask0.4_P1.0  mask0.3_P1.0  mask0.5_P1.0  mask0.4_P0.5  mask0.3_P0.5   \n",
       "96       0.387977      0.385649      0.383013      0.381040      0.390405  \\\n",
       "192      0.423599      0.415788      0.420193      0.415890      0.413327   \n",
       "336      0.460139      0.462411      0.451758      0.427630      0.438120   \n",
       "720      0.497545      0.488928      0.501920      0.469823      0.462707   \n",
       "96       0.307985      0.306750      0.310644      0.284757      0.303994   \n",
       "192      0.347002      0.345672      0.351378      0.345447      0.346953   \n",
       "336      0.365663      0.386517      0.376869      0.366474      0.373882   \n",
       "720      0.400531      0.397623      0.392212      0.398603      0.391183   \n",
       "96       0.291515      0.287913      0.289079      0.298560      0.287966   \n",
       "192      0.336320      0.334511      0.332486      0.338825      0.335239   \n",
       "336      0.361261      0.359739      0.359560      0.360062      0.356298   \n",
       "720      0.405975      0.410993      0.403744      0.403688      0.399416   \n",
       "96       0.199049      0.188197      0.171527      0.169833      0.171356   \n",
       "192      0.264318      0.225997      0.232137      0.240300      0.232889   \n",
       "336      0.299304      0.277113      0.278847      0.281558      0.280939   \n",
       "720      0.378512      0.362394      0.365920      0.366672      0.380952   \n",
       "\n",
       "     mask0.5_P0.5  \n",
       "96       0.404535  \n",
       "192      0.420396  \n",
       "336      0.449150  \n",
       "720      0.457576  \n",
       "96       0.277953  \n",
       "192      0.339948  \n",
       "336      0.364921  \n",
       "720      0.392971  \n",
       "96       0.287443  \n",
       "192      0.334505  \n",
       "336      0.364194  \n",
       "720      0.410393  \n",
       "96       0.183899  \n",
       "192      0.279701  \n",
       "336      0.290063  \n",
       "720      0.374701  "
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']\n",
    "result_df = get_result_keyword(keyword='_P')\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OVERALL\n",
      "mask0.5_tau_temp1.0     0.366350\n",
      "mask0.3_tau_temp10.0    0.367492\n",
      "mask0.3_tau_temp1.0     0.367679\n",
      "mask0.5_tau_temp10.0    0.371378\n",
      "mask0.5_tau_temp5.0     0.371957\n",
      "mask0.4_tau_temp5.0     0.374167\n",
      "mask0.4_tau_temp1.0     0.383948\n",
      "mask0.3_tau_temp5.0     0.385711\n",
      "mask0.4_tau_temp10.0    0.394452\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =96\n",
      "mask0.4_tau_temp5.0     0.301243\n",
      "mask0.3_tau_temp10.0    0.303702\n",
      "mask0.5_tau_temp5.0     0.303716\n",
      "mask0.5_tau_temp1.0     0.303945\n",
      "mask0.5_tau_temp10.0    0.304714\n",
      "mask0.3_tau_temp1.0     0.308086\n",
      "mask0.4_tau_temp1.0     0.316407\n",
      "mask0.3_tau_temp5.0     0.321037\n",
      "mask0.4_tau_temp10.0    0.342347\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =192\n",
      "mask0.3_tau_temp10.0    0.351569\n",
      "mask0.3_tau_temp1.0     0.352304\n",
      "mask0.4_tau_temp5.0     0.352688\n",
      "mask0.5_tau_temp1.0     0.353025\n",
      "mask0.4_tau_temp1.0     0.354315\n",
      "mask0.5_tau_temp5.0     0.357250\n",
      "mask0.3_tau_temp5.0     0.358727\n",
      "mask0.5_tau_temp10.0    0.361314\n",
      "mask0.4_tau_temp10.0    0.370666\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =336\n",
      "mask0.5_tau_temp1.0     0.374106\n",
      "mask0.3_tau_temp10.0    0.374549\n",
      "mask0.5_tau_temp10.0    0.380764\n",
      "mask0.3_tau_temp1.0     0.381163\n",
      "mask0.5_tau_temp5.0     0.394501\n",
      "mask0.4_tau_temp5.0     0.396536\n",
      "mask0.3_tau_temp5.0     0.403275\n",
      "mask0.4_tau_temp1.0     0.403872\n",
      "mask0.4_tau_temp10.0    0.409295\n",
      "dtype: float64\n",
      "--------------------------------------------------\n",
      "===pred length =720\n",
      "mask0.3_tau_temp1.0     0.429162\n",
      "mask0.5_tau_temp5.0     0.432361\n",
      "mask0.5_tau_temp1.0     0.434325\n",
      "mask0.5_tau_temp10.0    0.438719\n",
      "mask0.3_tau_temp10.0    0.440146\n",
      "mask0.4_tau_temp5.0     0.446199\n",
      "mask0.4_tau_temp10.0    0.455499\n",
      "mask0.3_tau_temp5.0     0.459806\n",
      "mask0.4_tau_temp1.0     0.461199\n",
      "dtype: float64\n",
      "--------------------------------------------------\n"
     ]
    },
    {
     "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>mask0.5_tau_temp10.0</th>\n",
       "      <th>mask0.4_tau_temp5.0</th>\n",
       "      <th>mask0.4_tau_temp1.0</th>\n",
       "      <th>mask0.3_tau_temp10.0</th>\n",
       "      <th>mask0.3_tau_temp5.0</th>\n",
       "      <th>mask0.5_tau_temp1.0</th>\n",
       "      <th>mask0.5_tau_temp5.0</th>\n",
       "      <th>mask0.4_tau_temp10.0</th>\n",
       "      <th>mask0.3_tau_temp1.0</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.399292</td>\n",
       "      <td>0.401116</td>\n",
       "      <td>0.458824</td>\n",
       "      <td>0.390189</td>\n",
       "      <td>0.503177</td>\n",
       "      <td>0.430860</td>\n",
       "      <td>0.405618</td>\n",
       "      <td>0.554888</td>\n",
       "      <td>0.422565</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.424727</td>\n",
       "      <td>0.428256</td>\n",
       "      <td>0.459745</td>\n",
       "      <td>0.412663</td>\n",
       "      <td>0.481743</td>\n",
       "      <td>0.450451</td>\n",
       "      <td>0.426645</td>\n",
       "      <td>0.497086</td>\n",
       "      <td>0.434619</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.437583</td>\n",
       "      <td>0.474356</td>\n",
       "      <td>0.577418</td>\n",
       "      <td>0.425401</td>\n",
       "      <td>0.564100</td>\n",
       "      <td>0.469361</td>\n",
       "      <td>0.452999</td>\n",
       "      <td>0.538494</td>\n",
       "      <td>0.453075</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.544592</td>\n",
       "      <td>0.544615</td>\n",
       "      <td>0.641187</td>\n",
       "      <td>0.546129</td>\n",
       "      <td>0.600815</td>\n",
       "      <td>0.509775</td>\n",
       "      <td>0.513364</td>\n",
       "      <td>0.600530</td>\n",
       "      <td>0.506272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.341830</td>\n",
       "      <td>0.336241</td>\n",
       "      <td>0.329362</td>\n",
       "      <td>0.347303</td>\n",
       "      <td>0.314119</td>\n",
       "      <td>0.315206</td>\n",
       "      <td>0.330614</td>\n",
       "      <td>0.323156</td>\n",
       "      <td>0.319542</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.408890</td>\n",
       "      <td>0.399910</td>\n",
       "      <td>0.374717</td>\n",
       "      <td>0.399214</td>\n",
       "      <td>0.375059</td>\n",
       "      <td>0.386561</td>\n",
       "      <td>0.408400</td>\n",
       "      <td>0.390431</td>\n",
       "      <td>0.385406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.415903</td>\n",
       "      <td>0.428847</td>\n",
       "      <td>0.376369</td>\n",
       "      <td>0.388678</td>\n",
       "      <td>0.392814</td>\n",
       "      <td>0.380890</td>\n",
       "      <td>0.429420</td>\n",
       "      <td>0.416053</td>\n",
       "      <td>0.400472</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.419690</td>\n",
       "      <td>0.432896</td>\n",
       "      <td>0.418463</td>\n",
       "      <td>0.424402</td>\n",
       "      <td>0.455839</td>\n",
       "      <td>0.444766</td>\n",
       "      <td>0.429734</td>\n",
       "      <td>0.436022</td>\n",
       "      <td>0.418223</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.303746</td>\n",
       "      <td>0.290610</td>\n",
       "      <td>0.301194</td>\n",
       "      <td>0.299949</td>\n",
       "      <td>0.295966</td>\n",
       "      <td>0.293705</td>\n",
       "      <td>0.301463</td>\n",
       "      <td>0.317701</td>\n",
       "      <td>0.306874</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.358411</td>\n",
       "      <td>0.340750</td>\n",
       "      <td>0.345916</td>\n",
       "      <td>0.340971</td>\n",
       "      <td>0.343714</td>\n",
       "      <td>0.338627</td>\n",
       "      <td>0.348828</td>\n",
       "      <td>0.339045</td>\n",
       "      <td>0.345550</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.377441</td>\n",
       "      <td>0.370927</td>\n",
       "      <td>0.374820</td>\n",
       "      <td>0.370055</td>\n",
       "      <td>0.370225</td>\n",
       "      <td>0.367214</td>\n",
       "      <td>0.382056</td>\n",
       "      <td>0.376669</td>\n",
       "      <td>0.384224</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.419341</td>\n",
       "      <td>0.420567</td>\n",
       "      <td>0.419586</td>\n",
       "      <td>0.416578</td>\n",
       "      <td>0.412109</td>\n",
       "      <td>0.413271</td>\n",
       "      <td>0.413101</td>\n",
       "      <td>0.412306</td>\n",
       "      <td>0.423151</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.173986</td>\n",
       "      <td>0.177003</td>\n",
       "      <td>0.176247</td>\n",
       "      <td>0.177367</td>\n",
       "      <td>0.170884</td>\n",
       "      <td>0.176008</td>\n",
       "      <td>0.177168</td>\n",
       "      <td>0.173644</td>\n",
       "      <td>0.183365</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.253227</td>\n",
       "      <td>0.241837</td>\n",
       "      <td>0.236882</td>\n",
       "      <td>0.253428</td>\n",
       "      <td>0.234392</td>\n",
       "      <td>0.236462</td>\n",
       "      <td>0.245126</td>\n",
       "      <td>0.256101</td>\n",
       "      <td>0.243640</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.292131</td>\n",
       "      <td>0.312014</td>\n",
       "      <td>0.286880</td>\n",
       "      <td>0.314064</td>\n",
       "      <td>0.285960</td>\n",
       "      <td>0.278959</td>\n",
       "      <td>0.313530</td>\n",
       "      <td>0.305964</td>\n",
       "      <td>0.286882</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.371253</td>\n",
       "      <td>0.386720</td>\n",
       "      <td>0.365560</td>\n",
       "      <td>0.373476</td>\n",
       "      <td>0.370462</td>\n",
       "      <td>0.369489</td>\n",
       "      <td>0.373245</td>\n",
       "      <td>0.373138</td>\n",
       "      <td>0.369002</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     mask0.5_tau_temp10.0  mask0.4_tau_temp5.0  mask0.4_tau_temp1.0   \n",
       "96               0.399292             0.401116             0.458824  \\\n",
       "192              0.424727             0.428256             0.459745   \n",
       "336              0.437583             0.474356             0.577418   \n",
       "720              0.544592             0.544615             0.641187   \n",
       "96               0.341830             0.336241             0.329362   \n",
       "192              0.408890             0.399910             0.374717   \n",
       "336              0.415903             0.428847             0.376369   \n",
       "720              0.419690             0.432896             0.418463   \n",
       "96               0.303746             0.290610             0.301194   \n",
       "192              0.358411             0.340750             0.345916   \n",
       "336              0.377441             0.370927             0.374820   \n",
       "720              0.419341             0.420567             0.419586   \n",
       "96               0.173986             0.177003             0.176247   \n",
       "192              0.253227             0.241837             0.236882   \n",
       "336              0.292131             0.312014             0.286880   \n",
       "720              0.371253             0.386720             0.365560   \n",
       "\n",
       "     mask0.3_tau_temp10.0  mask0.3_tau_temp5.0  mask0.5_tau_temp1.0   \n",
       "96               0.390189             0.503177             0.430860  \\\n",
       "192              0.412663             0.481743             0.450451   \n",
       "336              0.425401             0.564100             0.469361   \n",
       "720              0.546129             0.600815             0.509775   \n",
       "96               0.347303             0.314119             0.315206   \n",
       "192              0.399214             0.375059             0.386561   \n",
       "336              0.388678             0.392814             0.380890   \n",
       "720              0.424402             0.455839             0.444766   \n",
       "96               0.299949             0.295966             0.293705   \n",
       "192              0.340971             0.343714             0.338627   \n",
       "336              0.370055             0.370225             0.367214   \n",
       "720              0.416578             0.412109             0.413271   \n",
       "96               0.177367             0.170884             0.176008   \n",
       "192              0.253428             0.234392             0.236462   \n",
       "336              0.314064             0.285960             0.278959   \n",
       "720              0.373476             0.370462             0.369489   \n",
       "\n",
       "     mask0.5_tau_temp5.0  mask0.4_tau_temp10.0  mask0.3_tau_temp1.0  \n",
       "96              0.405618              0.554888             0.422565  \n",
       "192             0.426645              0.497086             0.434619  \n",
       "336             0.452999              0.538494             0.453075  \n",
       "720             0.513364              0.600530             0.506272  \n",
       "96              0.330614              0.323156             0.319542  \n",
       "192             0.408400              0.390431             0.385406  \n",
       "336             0.429420              0.416053             0.400472  \n",
       "720             0.429734              0.436022             0.418223  \n",
       "96              0.301463              0.317701             0.306874  \n",
       "192             0.348828              0.339045             0.345550  \n",
       "336             0.382056              0.376669             0.384224  \n",
       "720             0.413101              0.412306             0.423151  \n",
       "96              0.177168              0.173644             0.183365  \n",
       "192             0.245126              0.256101             0.243640  \n",
       "336             0.313530              0.305964             0.286882  \n",
       "720             0.373245              0.373138             0.369002  "
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "keywords_list = ['mask-schedule', 'MASK_END','_P','mae_gaussian','mse_gaussian','tau_']\n",
    "result_df = get_result_keyword(keyword='tau_')\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [],
   "source": [
    "d_list = ['etth1','etth2','ettm1','ettm2']\n",
    "df = pd.DataFrame()\n",
    "for m in [0.3,0.4,0.5]:\n",
    "    out_list = []\n",
    "    for d in d_list:\n",
    "        path = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{d}2{d}/masked_patchtst_sim/based_model/max/'\n",
    "        path += f'patchtst_sim_pretrained_cw512_patch12_stride12_epochs-pretrain100_mask{m}_model1'\n",
    "        t_list = [96,192,336,720]\n",
    "\n",
    "        for t in t_list:\n",
    "            fn = f'tw{t}_ft_ep20_model1_load_ep100_acc.csv'\n",
    "            fn = pd.read_csv(os.path.join(path,fn))\n",
    "            val = fn['mse'].values[0]\n",
    "            out_list.append(val)\n",
    "            #print(fn['mse'].values[0])\n",
    "        #print('='*20)\n",
    "    df[f'mask{m}'] = out_list\n",
    "df.index = [96,192,336,720] * 4\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "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>mask0.3</th>\n",
       "      <th>mask0.4</th>\n",
       "      <th>mask0.5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.371981</td>\n",
       "      <td>0.368143</td>\n",
       "      <td>0.366947</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.401590</td>\n",
       "      <td>0.399535</td>\n",
       "      <td>0.402896</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.412077</td>\n",
       "      <td>0.409732</td>\n",
       "      <td>0.415595</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.466674</td>\n",
       "      <td>0.470059</td>\n",
       "      <td>0.458930</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.271895</td>\n",
       "      <td>0.279295</td>\n",
       "      <td>0.274848</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.332500</td>\n",
       "      <td>0.338392</td>\n",
       "      <td>0.335309</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.356743</td>\n",
       "      <td>0.363853</td>\n",
       "      <td>0.361398</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.390867</td>\n",
       "      <td>0.380702</td>\n",
       "      <td>0.385100</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.293792</td>\n",
       "      <td>0.289398</td>\n",
       "      <td>0.289076</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.339246</td>\n",
       "      <td>0.333579</td>\n",
       "      <td>0.333297</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.364053</td>\n",
       "      <td>0.354176</td>\n",
       "      <td>0.361117</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.403726</td>\n",
       "      <td>0.400898</td>\n",
       "      <td>0.400717</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.180343</td>\n",
       "      <td>0.168635</td>\n",
       "      <td>0.171089</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>0.224371</td>\n",
       "      <td>0.232236</td>\n",
       "      <td>0.226757</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>336</th>\n",
       "      <td>0.272972</td>\n",
       "      <td>0.277392</td>\n",
       "      <td>0.279642</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>720</th>\n",
       "      <td>0.366683</td>\n",
       "      <td>0.359772</td>\n",
       "      <td>0.362217</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      mask0.3   mask0.4   mask0.5\n",
       "96   0.371981  0.368143  0.366947\n",
       "192  0.401590  0.399535  0.402896\n",
       "336  0.412077  0.409732  0.415595\n",
       "720  0.466674  0.470059  0.458930\n",
       "96   0.271895  0.279295  0.274848\n",
       "192  0.332500  0.338392  0.335309\n",
       "336  0.356743  0.363853  0.361398\n",
       "720  0.390867  0.380702  0.385100\n",
       "96   0.293792  0.289398  0.289076\n",
       "192  0.339246  0.333579  0.333297\n",
       "336  0.364053  0.354176  0.361117\n",
       "720  0.403726  0.400898  0.400717\n",
       "96   0.180343  0.168635  0.171089\n",
       "192  0.224371  0.232236  0.226757\n",
       "336  0.272972  0.277392  0.279642\n",
       "720  0.366683  0.359772  0.362217"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ssl_ts",
   "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.10.11"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
