{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MLP\n",
    "- `results_with_FC2_sep.ipynb`\n",
    "- `results_with_FC2_wo_CL.ipynb`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def MLP_data_input_output_patchlen(data,input_,output_,patch_len,dim):\n",
    "    print('='*50)\n",
    "    print(output_, 'patch size=',patch_len, 'dim=',dim)\n",
    "    print('='*50)\n",
    "    try:\n",
    "        PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_FC2_fullmask_fullmask_{input_}_{output_}/based_model/max'\n",
    "        PATCH2 = [x for x in os.listdir(PATH) if f'patch{patch_len}_' in x]\n",
    "        PATCH2 = [x for x in PATCH2 if f'_D{dim}_' in x][0]\n",
    "        temp = os.path.join(PATH,PATCH2)\n",
    "        PATCH2 = os.listdir(temp)\n",
    "        PATCH2 = [x for x in PATCH2 if 'acc.csv' in x]\n",
    "        for ft in [10,20,40,60]:\n",
    "            ft_n = [x for x in PATCH2 if f'ft_ep{ft}' in x]\n",
    "            df_list = []\n",
    "            try:\n",
    "                for file in ft_n:\n",
    "                    df = pd.read_csv(os.path.join(temp,file))\n",
    "                    df_list.append(df)\n",
    "                df = pd.concat(df_list,axis=0)\n",
    "                result =  df.mean(axis=0)\n",
    "                mse = result['mse']\n",
    "                mae = result['mae']\n",
    "                #print(df)\n",
    "                print(f'{len(ft_n)} --- ft={ft}: mse={mse.round(3)},mae={mae.round(3)}')\n",
    "            except:\n",
    "                pass\n",
    "    except:\n",
    "        pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Trans_data_input_output_patchlen(data,input_,output_,patch_len,dim):\n",
    "    print('='*50)\n",
    "    print(output_, 'patch size=',patch_len, 'dim=',dim)\n",
    "    print('='*50)\n",
    "    try:\n",
    "        PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_Transformer_fullmask_fullmask_{input_}_{output_}/based_model/max'\n",
    "        PATCH2 = [x for x in os.listdir(PATH) if f'patch{patch_len}_' in x]\n",
    "        PATCH2 = [x for x in PATCH2 if f'_D{dim}_' in x][0]\n",
    "        temp = os.path.join(PATH,PATCH2)\n",
    "        PATCH2 = os.listdir(temp)\n",
    "        PATCH2 = [x for x in PATCH2 if 'acc.csv' in x]\n",
    "        for ft in [10,20,40,60]:\n",
    "            ft_n = [x for x in PATCH2 if f'ft_ep{ft}' in x]\n",
    "            df_list = []\n",
    "            try:\n",
    "                for file in ft_n:\n",
    "                    df = pd.read_csv(os.path.join(temp,file))\n",
    "                    df_list.append(df)\n",
    "                df = pd.concat(df_list,axis=0)\n",
    "                result =  df.mean(axis=0)\n",
    "                mse = result['mse']\n",
    "                mae = result['mae']\n",
    "                #print(df)\n",
    "                print(f'{len(ft_n)} --- ft={ft}: mse={mse.round(3)},mae={mae.round(3)}')\n",
    "            except:\n",
    "                pass\n",
    "    except:\n",
    "        pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.255,mae=0.319\n",
      "4 --- ft=20: mse=0.256,mae=0.319\n",
      "4 --- ft=40: mse=0.256,mae=0.319\n",
      "4 --- ft=60: mse=0.253,mae=0.316\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.259,mae=0.321\n",
      "4 --- ft=20: mse=0.259,mae=0.322\n",
      "4 --- ft=40: mse=0.258,mae=0.32\n",
      "4 --- ft=60: mse=0.256,mae=0.318\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.259,mae=0.321\n",
      "4 --- ft=20: mse=0.256,mae=0.318\n",
      "4 --- ft=40: mse=0.258,mae=0.319\n",
      "4 --- ft=60: mse=0.255,mae=0.317\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "dataset = 'ettm2'\n",
    "for output in ['O']:\n",
    "    MLP_data_input_output_patchlen(data=dataset,input_='O',output_=output,patch_len=12,dim=32)\n",
    "    MLP_data_input_output_patchlen(data=dataset,input_='O',output_=output,patch_len=12,dim=64)\n",
    "    MLP_data_input_output_patchlen(data=dataset,input_='O',output_=output,patch_len=12,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.257,mae=0.318\n",
      "4 --- ft=20: mse=0.257,mae=0.318\n",
      "4 --- ft=40: mse=0.257,mae=0.317\n",
      "4 --- ft=60: mse=0.257,mae=0.317\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O']:\n",
    "    Trans_data_input_output_patchlen(data='ettm2',input_='O',output_=output,patch_len=12,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "dropout0 = [0.416,0.358,0.360,0.253]\n",
    "dropout1 = [0.410,0.334,0.358,0.253]\n",
    "dropout2 = [0.407,0.334,0.357,0.253]\n",
    "dropout3 = [0.407,0.333,0.357,0.253]\n",
    "dropout4 = [0.407,0.334,0.356,0.253]\n",
    "dropout5 = [0.406,0.335,0.356,0.253]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "dropout = np.array([dropout0,dropout1,dropout2,dropout3,dropout4,dropout5])\n",
    "dropout = pd.DataFrame(dropout)\n",
    "dropout.index = ['0.0','0.1','0.2','0.3','0.4','0.5']\n",
    "dropout.columns = ['etth1','etth2','ettm1','ettm2']"
   ]
  },
  {
   "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>etth1</th>\n",
       "      <th>etth2</th>\n",
       "      <th>ettm1</th>\n",
       "      <th>ettm2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0.0</th>\n",
       "      <td>0.416</td>\n",
       "      <td>0.358</td>\n",
       "      <td>0.360</td>\n",
       "      <td>0.253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1</th>\n",
       "      <td>0.410</td>\n",
       "      <td>0.334</td>\n",
       "      <td>0.358</td>\n",
       "      <td>0.253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.2</th>\n",
       "      <td>0.407</td>\n",
       "      <td>0.334</td>\n",
       "      <td>0.357</td>\n",
       "      <td>0.253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.3</th>\n",
       "      <td>0.407</td>\n",
       "      <td>0.333</td>\n",
       "      <td>0.357</td>\n",
       "      <td>0.253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.4</th>\n",
       "      <td>0.407</td>\n",
       "      <td>0.334</td>\n",
       "      <td>0.356</td>\n",
       "      <td>0.253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <td>0.406</td>\n",
       "      <td>0.335</td>\n",
       "      <td>0.356</td>\n",
       "      <td>0.253</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     etth1  etth2  ettm1  ettm2\n",
       "0.0  0.416  0.358  0.360  0.253\n",
       "0.1  0.410  0.334  0.358  0.253\n",
       "0.2  0.407  0.334  0.357  0.253\n",
       "0.3  0.407  0.333  0.357  0.253\n",
       "0.4  0.407  0.334  0.356  0.253\n",
       "0.5  0.406  0.335  0.356  0.253"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dropout"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0    0.34675\n",
       "0.1    0.33875\n",
       "0.2    0.33775\n",
       "0.3    0.33750\n",
       "0.4    0.33750\n",
       "0.5    0.33750\n",
       "dtype: float64"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dropout.mean(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ypURExODI0eO5OuZLmN9Zmz5m2++iYkTJ2Lt2rX44osvYGFhobwvmYPVZ8+eAXg+p1PGX62myMldeVu3bgXw/MzHwYMHdZaFh4cDAN555x04OTnh3XffzfJMD/B/+012fZRRQkICBgwYgEePHmHWrFkYNGgQypcvDzs7O6hUKgwePBhr1qwxa5+8fv06hg8fDhHBwoUL0b17d5QpUwZ2dnYAgObNm+Po0aM6dTo5OWH//v04fPgwtm7diuDgYOzbtw+7d+/GggULcOjQISXQePbsGVQqFYYNG5ZlO7y8vExuszGHDx9GXFwcevToASur518RlpaWWLNmDXr27Im///4bAwYMwMaNG/HPP//g1q1bmDRpkknvwdatW6FSqbBixQqsXLlSZ5l2Juu+ffvCxsYG8+bNM/muRHPef1PLGFqemztR33nnHYSEhGDAgAGYOXOm2e3Sphtabu72f/3113j77bexZcsW7Nu3D4cPH8bx48fx+eefY926dWbdRQo8/1GuUqng5ORkVrnCiEFREVGyZEkA0Dk9b6rVq1crp+5DQ0ON5jt//jxOnjypnDXp3r07nJ2d8ddffyEhIQHXr1/HmTNn0KRJE1SpUkWnbOnSpQE8v7xmyM2bN81utzmGDBmCadOmYdeuXXBycjL5EpYxr732Gjw9PXHy5Mk8+XVuiLu7OwDg6tWrBpdrL2dq+1arRIkS6NSpE3bu3Ing4GC0adMG69evh1qtRr9+/XTyas8atW3bFl9//XVeb4JRWT3K49SpUwBg0oFZ20fGJv0ztL8dOnQIjx49Qr9+/TBnzhy95f/991+2681sx44dePr0KSZNmoQPPvjA5DpVKhVatmypfPk/fPgQH3zwAdasWYPp06dj3bp1AJ6/T1euXMF3332X71882rPO2oBZy8bGBps2bULXrl2xdetWDB8+HDdu3ICDgwMmT55scv0iohcQZ6SdSqGwfa5yY+HChfjtt9/g7e1tdNqR7NqlPVuYV+2qXr06pkyZgilTpiA5ORmLFi3CRx99hLffftusoCg1NRUJCQlwcXFRguiXGccUFRElS5ZEqVKlcP36dYOXOrKiHWuzfft2yPPB93ov7RmijHMW2djYwMfHB0lJSdi8ebMySaKheZKaN28OAPjzzz/1lsXFxenNZ5TXypYti+7du6N48eIYOnRotr/4sjtL8OzZM+UgpT2Y5bVWrVoBANatW6f3BQX833uhzZeR9j0IDAzEvn37cP/+fSWIzahdu3awtLTEtm3bDK4jry1fvtzoPtamTRsAUM6oGJqFPDNtMLFhwwa99ywtLQ0bNmzQKxMdHQ3A8KXcy5cvG5zdHHh+ltDYmIms6jx48CDu37+fxVb8nxIlSiiXXc+cOaOkd+zYEQCwefNmk+oBoDx2wdxxHtqzTXv37tU782xnZ4dt27ahUaNGWL16NQ4dOoQvv/wSr732mkl1BwcHG33/y5cvDwDKmC5zz1aYKjefq5zYvXs3PvroI5QqVQqbN29Wzh5mpt2Xt2/fjpiYmHxvV0a2traYNGkSSpcujQcPHihXB0xx4cIFAMjysUYvEwZFRUirVq2Qlpam/NI2RXh4OM6cOYPixYujU6dORvMNGjQIwPNxExkPJNov39WrV2Pt2rWwtLQ0OIC5f//+cHFxwa5du3S+qNLT0/Hxxx8bvez3ww8/wNPTM8ePLclo69atiIqKwqJFi7LNe/r0aXTp0gV79uzRGwCblJSEd999F48ePUKpUqXy7dlwbdu2Re3atXH16lXMnj1b50t/8+bN2LhxIxwcHAw+16p3796wt7fHhg0bsGzZMgCGg9UyZcpg+PDhiIyMxFtvvWXw1/mRI0cK7azm7dq1Q7Vq1XDhwgW9gbvz5s0zeAZJO/h048aNOmOKYmJiMGrUKJ0bBzJyd3fH/fv3DX5haetctWoVEhMTlfTbt2/jf//7n8H6fv75Z4NnBXbu3AlAd/zKpEmTYGdnh4kTJyqXIDN6/PgxfvzxR50fRNpgPfPEpdmpVasW2rZti0ePHqFXr156fZiQkKAT/B0+fPilemZZbj5X5rp06RLefPNNWFlZYdOmTTrj+TKrVKkSunfvjvj4eHzwwQc6++HRo0fx008/wdLSMteziW/evNngmdpTp07h/v37cHR0NOuGHe1kj/kRrBWEl/9cFym6d++OP/74A0FBQcqZmexoB1j7+Phk+ZiFWrVqwcvLC//++y/27NmDrl27AgDatGmDsmXLYteuXQCArl27KpfyMnJ2dsbPP/+MQYMGwcfHBy1btoSHhwdCQ0Px4MEDDB06FKtWrdJ7qGBUVBQuXrxocHbf/CQi2L17N3bv3o3ixYvD29sbbm5uiIqKQmhoKB4/fgw7OzusXLnS4GDjzZs3ZzkT8Pvvv68MgjZGpVJh9erVaNeuHebPn49NmzahXr16uHHjBg4fPgwrKyssXbrU4OBbe3t79OrVC4GBgVi7dq0yMN6Q7777Dv/99x/WrFmDbdu2oV69enB3d8e9e/dw+fJl3L59Gx988AG6deuWdacVAAsLCyxfvhwdOnTAlClTsGbNGnh6euLs2bO4cOECRo8ejSVLluiUadiwITp16oQ9e/agWrVqyl07wcHBcHNzQ69evbBlyxa9dfXs2RPff/89GjRogObNm8PW1hbVq1fH5MmT0bNnT3h5eSE0NBRVqlRBixYtkJycjKCgINSrVw/NmzfXe67bzz//jHHjxqFmzZqoUaMGrKyscPHiRYSHh8POzg5+fn5K3qpVq2LVqlUYOnQoevbsierVq6NGjRoQEVy/fh3nzp3D06dPMXjwYOVMROfOnWFra4tvvvkGZ8+ehbu7O1QqFSZPnozq1atn2a+BgYHo2LEjgoOD4enpiYYNG8LDwwO3b9/GsWPHkJaWhsmTJ2P37t34/fff4erqioULF+bgHXzxcvO5Mtdnn32GmJgYVKlSBT///LPBx2H07t1bOSv2yy+/oFWrVli5ciUOHDiAZs2a4eHDhwgODsazZ8/w1VdfmT32L7Pg4GB8++23KFOmDOrXrw8nJyfcuXMHISEhSE9Px9y5c8165I52hvTCeHzIkXy+5Z9eoKSkJNFoNFKzZk2T8qelpUnp0qX1JlEzZu7cuQJABg8erJM+efJkZa6MlStXZlnH7t27pWXLlmJnZyfOzs7Sq1cvuXDhgowePVoAyK5du3Tya+dayTynSVYyz1OUHUPzFKWmpsq+fftk8uTJ0rRpUylTpoxYW1uLg4OD1KpVSz744AP577//jK47u5c5c4Rcv35dxowZIx4eHmJtbS1ubm7Su3fvbGcu3759u7K+kSNHZpk3NTVVlixZIm3atBEXFxexsbGRsmXLSuvWreXzzz/Xm7gPuZizx5iczmgtInLq1Cl5/fXXxdHRURwdHaV9+/YSEhJidO6YpKQkmTFjhlStWlXUarV4eHjI//73P4mKilImVcz8mUhISJB3331XPDw8xMrKSvD/J/XUevz4sYwbN04qVKggarVaKlWqJB9//LEkJiYq25Zxcr2//vpLRo4cKV5eXuLs7CzFihWTatWqydixYyUyMtLgdl66dEnefvttqVSpkqjVatFoNFKjRg0ZMWKEbNu2TW+upr///ltatGghDg4Oyr5gymdd20dffPGFNGzYUBwcHJRtGjNmjJw+fVpEnu+bhmZmzonczmhtSFZzB5nzudLOU5Tx/TZlXdp9KatX5rZFRUXJpEmTpHLlymJjYyPOzs7SuXNn+fvvv/Nk+0+dOiWTJk2SRo0aScmSJUWtVkv58uWlZ8+eJu8bWtqJcGvXrm1WucJMJfISnfekbGlvtTx58mS2ZyIKi/T0dNSpUwf//vsv7t69mye/0IiIKH+tWbMGgwcPxo8//ohx48YVdHPyBIOiIubBgweoXLkyXn/9daMTCxaU27dvw9raWufyWmpqKmbOnInPP/8c7du3x759+wqwhUREZAoRQf369ZGQkIBz587pDX14WXFMURFTsmRJTJ48GQEBATh37hxq1qxZ0E1SHDp0CEOHDkWDBg1Qvnx5JCYmIiIiAnfu3IGrq6ve/EhERFQ4bdmyBREREVi3bl2RCYgAnimiFygyMhLz58/HoUOHcP/+fTx9+hTu7u7o3Lkzpk2blqOZVImIiPIKgyIiIiIicJ4iIiIiIgAMioiIiIgAMCgiIiIiAsCgiIiIiAgAgyIiIiIiAAyKiIiIiAAwKCIiIiICwKCIiIiICAAf82Gy9PR03LlzB46OjlCpVAXdHCIiIjKBiCA+Ph7u7u6wsMj6XBCDIhPduXMHHh4eBd0MIiIiyoGbN2+ibNmyWeZhUGQiR0dHAM871cnJqYBbQ0RERKaIi4uDh4eH8j2eFQZFJtJeMnNycmJQRERE9JIxZegLB1oTERERgUEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkWFUnJyMvz8/FCtWjXY2trC3d0dI0eOxK1bt0yuIy0tDf7+/ujevTsqVaoER0dH2NraomrVqhg/fjxu3LhhUj1Pnz5FzZo1oVKpYGtrazBPhQoVoFKpsnxVqlTJ5LYTEREVBJWISEE34mUQFxcHjUaD2NjYfH32WXJyMjp06IAjR46gdOnSaNWqFa5du4bjx4+jRIkSOHr0KCpXrpxtPQkJCXB0dISDgwPq1KkDd3d3PH36FOHh4bhx4wY0Gg3279+PBg0aZFmPv78/5syZAxGBWq1GcnKyXp6PPvoIUVFRBssfOHAA165dw7Bhw7BixQrTOoGIiCiPmPX9LWSS2NhYASCxsbH5up5Zs2YJAGnWrJnEx8cr6V999ZUAkNatW5tUT2pqqoSEhEhqaqpOelpamkybNk0ASJMmTbKs49y5c2JjYyNjx44VAKJWq83almfPnom7u7sAkD179phVloiIKC+Y8/3NM0UmehFnilJTU1GyZEnExMQgLCwM9evX11let25dnD59GqGhofD29s7xetLS0uDo6Ijk5GQkJCTA3t5eL4+IoHXr1rh06RIuXLgAV1dXo2eKjNmzZw86d+4Md3d33Lx5ExYWvFpLREQvljnf3/yWKkRCQkIQExODypUr6wVEAODj4wMA2Lp1a67Wo1KpYGFhAQsLC1hZWRnM88svvyAkJARfffUVXFxccrSeVatWAQCGDBnCgIiIiAo9flMVIhEREQBgdJyPNl2bLydEBJ9++imSkpLQvn17qNVqvTx3797F1KlT0b59ewwdOjRH63ny5Ak2bdoEADmug4iI6EUyfJqACoT2jrCyZcsaXK5NN/XOMa2PP/4Y9+/fR1xcHE6fPo0rV67A09MTixcvNpj/3XffRXJyMn766Sez1pPR5s2bER8fjzp16qBOnTo5roeIiOhFYVBUiCQkJAAAihUrZnC5duyPNp+pNmzYgCtXrij/r1WrFlavXo2KFSvq5d2yZQs2btyoTAmQU7///jsA4K233spxHURERC8SL58VItox7yqVKsvl5rp8+TJEBA8fPsSuXbugVqvh7e2td4t8fHw83n33XVStWhXTpk3L0boA4OHDh9izZw8sLCwwePDgHNdDRET0IjEoKkQcHR0BAImJiQaXJyUlAQAcHBxyVL+bmxu6dOmCffv2wd3dHePGjcPNmzeV5dOnT8etW7fw008/GRxrZKo1a9YgLS0NHTp0gLu7e47rISIiepEYFBUi5cqVAwCjM1dr07X5ckqj0aBHjx548uQJ9uzZo6Rv3boVtra2mDt3Ltq2bavzAp7Pbq39/+XLl43Wr73rjAOsiYjoZcIxRYVI3bp1AQBhYWEGl2vT82LgspubG4Dnl7oySk5OxoEDBwyWERFlmbFxTZcuXcKJEydQrFgx9O3bN9ftJCIielF4pqgQadGiBTQaDa5cuYJTp07pLf/zzz8BAD169Mj1urTBTcZHhly7dg0iYvAFAGq1Wvl/vXr1DNarPUvUp0+fHF/mIyIiKggMigoRGxsbvPvuuwCe3xafcWzR119/jdOnT6Nly5Zo1KiRkv7DDz/A09NTb2D0X3/9hZ07d+oNzk5KSsKMGTNw4MABlCpVCl27ds3TbVi9ejUA3nVGREQvH14+K2RmzpyJvXv34siRI6hatSpatWqF69ev459//kHx4sWxbNkynfxRUVG4ePEi7t69q5MeFhaGgIAAuLu7o379+tBoNLh37x7Cw8Px+PFjaDQarF+/Pk/P5hw5cgT//fcfSpUqhY4dO+ZZvURERC8Cg6JCxtbWFkFBQViwYAECAwOxefNmuLi4wNfXF3PnzoWHh4dJ9fTt2xfx8fE4dOgQTpw4gcePH8POzg5VqlTB22+/jffeew+lS5fO07ZrL50NGjQIlpaWeVo3ERFRfuMDYU30Ih4IS0RERHmLD4QlIiIiMhODIiIiIiIwKCIiIiICwKCIiIiICACDIiIiIiIADIqIiIiIADAoIiIiIgLAoIiIiIgIAIMiIiIiIgAMioiIiIgAMCgiIiIiAsCgiIiIiAgAgyIiIiIiAIBVQTeA/j+VqqBbUDBECroFREREAHimiIiIiAgAgyIiIiIiAAyKiIiIiAAwKCIiIiICwKCIiIiICACDIiIiIiIADIqIiIiIADAoIiIiIgLAoIiIiIgIAIMiIiIiIgAMioiIiIgAMCgiIiIiAsCgiIiIiAgAgyIiIiIiAAyKiIiIiAAwKCIiIiICwKCIiIiICACDIiIiIiIADIqIiIiIADAoIiIiIgLAoIiIiIgIAIMiIiIiIgAMioiIiIgAMCgiIiIiAsCgiIiIiAgAgyIiIiIiAAyKiIiIiADkMCg6ceIEunXrBhcXF9jb26Nx48YIDAw0uXxwcDAGDx6MGjVqwNnZGcWKFUP16tUxcuRIXLx40aQ6Pv/8c6hUKqhUKhw7dkxvub+/v7I888vW1tbkthIREdGrwcrcAsHBwejSpQtsbGwwcOBAaDQabNy4EUOGDMG1a9cwffr0bOvYu3cvQkJC0KRJE6Wu8+fPY+XKlQgMDMTOnTvRrl07o+XPnz+P2bNnw97eHomJiVmuy9fXFxUqVNBJs7Iye7OJiIioiFOJiJiaOS0tDZ6enrh16xaOHj2K+vXrAwDi4+PRrFkzXLx4EefOnUPVqlWzrCc5Odng2Zp9+/ahY8eOaNiwIU6cOGGw7LNnz9CsWTOoVCpUq1YNq1atwtGjR9G0aVOdfP7+/ggICEBQUBDatm1r6iYaFRcXB41Gg9jYWDg5OeW6Pj0qVd7X+TIwffcjIiIymznf32ZdPtu/fz+uXLmCwYMHKwERADg6OmLWrFlIS0vDsmXLsq3H2OWrDh06wMXFBZcvXzZa9rPPPkNERASWLl0KS0tLc5pPREREZJRZ15GCg4MBAJ07d9Zbpk07cOBAjhtz9OhRREdHo2XLlgaXnz17FgEBAZg5cya8vLxMqvPQoUM4fvw4LC0t4enpiY4dO0KtVue4jURERFQ0mRUURUZGAoDBy2MuLi5wc3NT8pgiODgYwcHBSElJQWRkJLZt2wY3Nzd88803ennT0tIwfPhw1KhRA1OnTjV5HbNnz9b5f+nSpbFixQp06tQpy3IpKSlISUlR/h8XF2fyOomIiOjlY9bls9jYWACARqMxuNzJyUnJY4rg4GAEBATg008/xYYNG+Dh4YFdu3ahYcOGennnz5+vXDaztrbOtu569ephxYoVuHbtGp48eYLIyEjMnTsXMTEx6NmzJyIiIrIsv2DBAmg0GuXl4eFh8nYRERHRy6dA5yny9/eHiCAhIQHHjx+Hp6cnWrRooXd7f0REBObNm4ePPvoIDRo0MKnu3r17Y9iwYShfvjxsbW1RpUoVzJw5E99++y2Sk5Mxb968LMtPmzYNsbGxyuvmzZs53k4iIiIq/MwKirRniIydDdKO8DaXvb09GjVqhE2bNsHT0xNjx47Fw4cPleW+vr6oXLky/P39za47M19fX1hZWeHw4cNZ5lOr1XByctJ5ERERUdFlVlCkHUtkaNxQdHQ0oqKisr0dPytWVlZo164dEhMTERoaqqRHRETgwoULsLW11ZmEccWKFQCg3KK/efPmbNdhY2MDR0dHJCUl5bidREREVPSYNdC6TZs2WLBgAXbv3o2BAwfqLNu9e7eSJzfu3LnzvGEZJlgcNWqUwbwHDx5EZGQkevbsiRIlSuhN0mhIZGQkoqOjUbdu3Vy1k4iIiIoYMUNqaqpUqlRJ1Gq1nDp1SkmPi4sTLy8vsbKykosXLyrpDx8+lPPnz8vDhw916jlw4ICkp6fr1f/333+LtbW1aDQaSUhIyLY9vr6+AkCOHj2qkx4XFycRERF6+R8/fiytWrUSAPLpp59mW39GsbGxAkBiY2PNKmey59MYvnovIiKifGTO97dZZ4qsrKywZMkSdOnSBa1atcKgQYPg5OSEjRs34urVq5g3bx6qVaum5P/hhx8QEBAAPz8/nfFAPXv2hJubGxo1agQPDw88efIEp0+fxsGDB2FtbY0lS5bA3t4+x4Heo0ePULduXTRs2BC1a9dGyZIlcfv2bezcuROPHj1Cp06dMHHixBzXT0REREWP2Q8Ba9euHUJCQuDn54f169fj6dOn8PLywty5czFkyBCT6ggICMCuXbsQEhKChw8fQqVSwcPDA6NHj8aECRNMnpjRGFdXV4wfPx7Hjh3D1q1bERMTA3t7e9SuXRtDhw7F6NGjORs2ERER6TDr2WevMj77LJ9w9yMionyUb88+IyIiIiqqGBQRERERgUEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBERERERGAHAZFJ06cQLdu3eDi4gJ7e3s0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1KmTxMTEKOnR0dHSoUMHASBDhgzJWYeYiP1mPvZZzrDfco+P+cgHDIoK57d7QTf/Je02xZMnT6RJkyYC/N/DJrX/L168uERGRurk9/PzEwDi6+trMN3d3V26d+8ugwcPlvbt24urq6sAzx82efDgQZ0yQUFBAkCcnJykffv2MnjwYOnWrZtUqFBBAIiFhYV8/fXXem0+duyYODg4CABxc3OT7t27S/fu3ZWHTVaoUEFu376dd51kAPvNfOyznGG/5R6DonzAoKhwfrsXdPNf0m7TkZSUJLNmzZLKlSuLjY2NvPbaa+Lr62vwLhRjB9yIiAj58MMPpVGjRlKyZEmxsrISR0dHqV+/vkybNk3u3LmjV9eDBw9kzpw50r59eylbtqyo1Wqxs7OTqlWrysiRIw0+sVvr8uXLMmbMGKlUqZJSrmbNmjJ16lS9h1PmF/ab+dhnOcN+yx1zvr9VIiK5vQT3KoiLi4NGo0FsbKze7J15Iq9Gz75scrn7sduIiCgr5nx/c6A1ERERERgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQEArAq6AUT04qlUBd2CgiFS0C0gosKMZ4qIiIiIwKCIiIiICACDIiIiIiIAHFNERGQSjsPKGfZbzrDfCgbPFBERERGBQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBERERERGAHAZFJ06cQLdu3eDi4gJ7e3s0btwYgYGBJpcPDg7G4MGDUaNGDTg7O6NYsWKoXr06Ro4ciYsXL+rlj4mJwfvvv49mzZqhVKlSUKvVKFOmDNq3b48NGzZARPTK+Pv7Q6VSGXzZ2trmZLOJiIioCLMyt0BwcDC6dOkCGxsbDBw4EBqNBhs3bsSQIUNw7do1TJ8+Pds69u7di5CQEDRp0kSp6/z581i5ciUCAwOxc+dOtGvXTskfFRWFpUuXomnTpujduzdcXV3x4MEDbN26FT4+PhgzZgwWL15scF2+vr6oUKGC7kZbmb3ZREREVNSJGVJTU6Vy5cqiVqslLCxMSY+LixMvLy+xsrKSS5cuZVvPkydPDKbv3btXAEjDhg110tPS0iQ1NVUvf1xcnNSsWVMAyNmzZ3WW+fn5CQAJCgoyYcuyFxsbKwAkNjY2T+rTA7yaL3ZbQXRbgbf/Zey3gm77y9hn7Df224vuN0PM+f426/LZ/v37ceXKFQwePBj169dX0h0dHTFr1iykpaVh2bJl2dZj7PJVhw4d4OLigsuXL+ukW1paGjy74+joiC5dugCAXhkiIiIic5h1HSk4OBgA0LlzZ71l2rQDBw7kuDFHjx5FdHQ0WrZsaVL+5ORk7N+/HyqVCjVr1jSY59ChQzh+/DgsLS3h6emJjh07Qq1W57iNREREVDSZFRRFRkYCAKpWraq3zMXFBW5ubkoeUwQHByM4OBgpKSmIjIzEtm3b4Obmhm+++cZg/piYGCxcuBDp6el48OABduzYgZs3b8LPz89gmwBg9uzZOv8vXbo0VqxYgU6dOmXZtpSUFKSkpCj/j4uLM3m7iIiI6CVkznW5Tp06CQCJjIw0uLxSpUpiY2Njcn3acT/aV5UqVSQ0NNRo/qtXr+rkt7a2li+++ELS09P18m7atElWrFgh165dkydPnkhkZKTMnTtX7OzsxNbWVsLDw81qm/bFMUWF6wJyQTf/Je22Am//y9hvBd32l7HP2G/stxfdb4aYM6bIrCbkdVCklZCQIMePH5cePXqIWq2W1atXZ5k/LS1Nrl69KgsWLBAbGxvp06ePwYHYhixevFgAiI+PT5b5kpOTJTY2VnndvHnT5E7NkYLeE1/ST0BBN/8l7bYCb//L2G8F3faXsc/Yb+y3F91vhuTbQGuNRgMAiI2NNbg8Li5OyWMOe3t7NGrUCJs2bYKnpyfGjh2Lhw8fGs1vaWmJChUqYOrUqZg3bx42bdqEX3/91aR1+fr6wsrKCocPH84yn1qthpOTk86LiIiIii6zgiLtuB1D44aio6MRFRVldGyPKaysrNCuXTskJiYiNDTUpDLaAd7aQeDZsbGxgaOjI5KSknLaTCIiIiqCzAqK2rRpAwDYvXu33jJtmjZPTt25cweA6RMsmps/MjIS0dHRehM6EhER0avNrKCoQ4cOqFSpEgIDAxEeHq6kx8fHY+7cubCyssLw4cOV9KioKFy4cAFRUVE69Rw8eBAiolf/7t27sWnTJmg0GjRv3lxJDw8PN3jJ7vHjx8oM2q+//rpOe06fPq2XPzo6GqNGjQIADBo0yLSNJiIioleCWbfkW1lZYcmSJejSpQtatWqFQYMGwcnJCRs3bsTVq1cxb948VKtWTcn/ww8/ICAgAH5+fvD391fSe/bsCTc3NzRq1AgeHh548uQJTp8+jYMHD8La2hpLliyBvb29kn/58uVYsmQJ2rVrh/Lly8Pe3h7Xr1/H9u3bkZCQgH79+mHw4MFK/kePHqFu3bpo2LAhateujZIlS+L27dvYuXMnHj16hE6dOmHixIm56DYiIiIqasx+CFi7du0QEhICPz8/rF+/Hk+fPoWXlxfmzp2LIUOGmFRHQEAAdu3ahZCQEDx8+BAqlQoeHh4YPXo0JkyYAC8vL538Pj4+iI2NxbFjx3Dw4EEkJSXB1dUVLVu2xLBhwzBw4ECoVColv6urK8aPH49jx45h69atiImJgb29PWrXro2hQ4di9OjRsLS0NHfTiYiIqAhTiaHrWKRHe2ddbGxs/tyJliGoe6Xkcvdjt+UM+8187LOcYb/lDPst75jz/W3WmCIiIiKioopBEREREREYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAWBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAchgUnThxAt26dYOLiwvs7e3RuHFjBAYGmlw+ODgYgwcPRo0aNeDs7IxixYqhevXqGDlyJC5evKiXPyYmBu+//z6aNWuGUqVKQa1Wo0yZMmjfvj02bNgAETG4nri4OHz44YcoX7481Go1ypcvjw8//BBxcXE52WwiIiIqwlRiLKIwIjg4GF26dIGNjQ0GDhwIjUaDjRs34urVq/jkk08wffr0bOuYOXMmVq5ciSZNmqBMmTKwsbHB+fPnsXPnTlhZWWHnzp1o166dkv/y5cuoV68emjZtiipVqsDV1RUPHjzA1q1b8eDBA4wZMwaLFy/WWUdiYiJatmyJ8PBwdOrUCQ0aNEBERAR27dqFevXqISQkBPb29iZvd1xcHDQaDWJjY+Hk5GR6h5lKpcr7Ol8G5u1+ethtOcN+Mx/7LGfYbznDfss7Zn1/ixlSU1OlcuXKolarJSwsTEmPi4sTLy8vsbKykkuXLmVbz5MnTwym7927VwBIw4YNddLT0tIkNTVVL39cXJzUrFlTAMjZs2d1ls2ePVsAyJQpUwymz549O9t2ZhQbGysAJDY21qxyJnu+L7x6L3ZbQXRbgbf/Zey3gm77y9hn7Df224vuN0PM+f426/LZ/v37ceXKFQwePBj169dX0h0dHTFr1iykpaVh2bJl2dZja2trML1Dhw5wcXHB5cuXddItLS1hZWWll9/R0RFdunQBAJ0yIoIlS5bAwcEBs2fP1ikzbdo0uLi44LfffoOIZNtWIiIiejWYFRQFBwcDADp37qy3TJt24MCBHDfm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o1SpUujfv7/OMu0s/cePH0fbtm3h4OCAbdu25bLlBetF7W8WFhaoXLkyHjx4gLt37770l20ZFBUR2tuXw8LCDC7XptepU+eF1lXYvUrbmlfyo8/u3LmDTp064d69e/jggw/g5+eX+4YWMi9yX3NzcwMAPHz4MNd1FbS87rd79+7h3r17BpdFR0fjwIED0Gg0OWhp4fIi97fo6GgAReSM+oufGonyQ0pKimg0mmwn6jp+/Hi2dd25c0csLCzExsZG7t+/r7NMO3mjhYWF3L17N8/aX1Dyst8yK6qTN+Z1nz1+/Fhq1aolAGTEiBGSnp6e100uFPJzX8usTZs2AkD++OOPXNdV0F5EvxXFyRtf1P529uxZUalUUqxYMUlJSclVXYUBg6IiRPscqebNm+vMZKud0r1ly5Y6+b///nupXr26TJ06Va+uIUOGCADp16+fzqME3n//fQEgQ4cOzb8NecHyst8yKqpBkUje9VliYqI0bdpUAMiAAQMkLS3thbS/oORVv23ZskV27NihF0AmJibK9OnTBYCUKlVK59EOL7P8+oxqFcWgSCTv+m3Xrl0GZ76OiIiQGjVqCAB5//3382cjXjBePitCZs6cib179+LIkSOoWrUqWrVqhevXr+Off/5B8eLFsWzZMp38UVFRuHjxIu7evatX18KFC3Hs2DFs2LABnp6eaNiwIf7991+cPXsWlStXxjfffPOiNivf5WW/LVmyBEuWLAEApKSkAACuX7+Opk2bKnl+/PFHoxOqvSzyqs9mzJiBY8eOwdLSElZWVkbnOlm+fHl+bcoLlVf9FhYWhoCAALi7u6N+/frQaDS4d+8ewsPD8fjxY2g0Gqxfv75oXM5A3n5GXyV51W9Hjx5FQEAAypcvj8qVK6NEiRK4evUqwsLCkJaWhjZt2mDBggUvctPyT0FHZZS3kpKSZNasWVK5cmWxsbGR1157TXx9feXGjRt6ef38/JSnHhvy+PFjee+998TDw0NsbGzEw8ND3n33XXn06FE+b8WLl1f9pl2W1SsoKCj/N+gFyIs+8/X1zba/itphKi/6LSIiQj788ENp1KiRlCxZUqysrMTR0VHq168v06ZNKzJPLM8oL49tmRXVM0UiedNvR44ckZEjR0rt2rWlePHiYmVlJa6urtK2bVv59ddfi9QZXpUIJ2IhIiIi4jxFRERERGBQRERERASAQRERERERAAZFRERERAAYFBEREREBYFBEREREBIBBEREREREABkVEREREABgUEREREQFgUEREREQEgEEREREREQAGRUREREQAGBQRERERAQD+H0XqShfHYLHCAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "custom_yticks = [0.33,0.335,0.340,0.345]\n",
    "custom_xticks = ['0.0','0.1','0.2','0.3','0.4','0.5']\n",
    "bar_colors = ['red'] + ['blue'] * (len(custom_xticks) - 1)\n",
    "#plt.bar(['0.0','0.1','0.2','0.3','0.4','0.5'],dropout.mean(axis=1).values)\n",
    "plt.ylim(0.33,0.349)\n",
    "\n",
    "\n",
    "# Create the bar plot with custom colors\n",
    "thres=0.4\n",
    "plt.bar(custom_xticks, dropout.mean(axis=1).values, color=bar_colors)\n",
    "plt.text(0-thres,0.3475,'0.347',size=15)\n",
    "plt.text(1-thres,0.3395,'0.339',size=15)\n",
    "plt.text(2-thres,0.3385,'0.338',size=15)\n",
    "plt.text(3-thres,0.3385,'0.338',size=15)\n",
    "plt.text(4-thres,0.3385,'0.338',size=15)\n",
    "plt.text(5-thres,0.3385,'0.338',size=15)\n",
    "plt.suptitle('Performance by Dropout Ratio',size=20,y=1.03)\n",
    "plt.title('( Avg. MSE over 4 dataset & 4 horizons )',size=15,pad=10)\n",
    "plt.yticks(custom_yticks,fontsize=14)\n",
    "plt.xticks(custom_xticks,fontsize=15)\n",
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/viz'\n",
    "plt.savefig(os.path.join(PATH,'dropout_ratio.pdf'), format=\"pdf\", bbox_inches=\"tight\")\n",
    "#plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 1000x300 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJOCAYAAAAqFJGJAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABz6UlEQVR4nO3deVyVZf7/8fcBZBGBQBHcJUtxZRRK0ZoEhbRwpCzNUiG1bFxGNJtvVo5bEy1WtrhkX5VMU2OCrHELU1NC00gUJjKn0VADTUfBFRTu3x/+ON+OLAI3Qujr+Xicx6Nzneu+Ptd9ONJ5c92LxTAMQwAAAABggl1tTwAAAABA3UewAAAAAGAawQIAAACAaQQLAAAAAKYRLAAAAACYRrAAAAAAYBrBAgAAAIBpBAsAAAAAphEsAAAAAJhGsABw3ezbt0+jRo1SmzZt5OLiIhcXF91+++0aM2aMvv3229qeXo2Ijo5W69atr9mvd+/eslgs1ke9evXUunVrjRo1Sj///PP1n2g5KroPpZk/f77i4uKqdT5X27p1qywWi7Zu3WptW7dunWbMmFFqf4vFovHjx5uqeezYMT377LPq3LmzGjRoIGdnZ91+++2aOHGiDhw4YGrssnz//feaMWOGDh06dF3GNysvL09///vfFRQUJHd3dzk5Oal169YaOXKkvvvuu0qPV9rPFcDvm0NtTwDAjem9997T+PHj1a5dO02cOFEdO3aUxWJRZmamVq5cqTvuuEP//ve/1aZNm9qe6u/GrbfeqhUrVkiSCgoKlJGRoZkzZyopKUk//PCD6tevX8szrLz58+erUaNGio6Ovm41unXrph07dqhDhw7WtnXr1mnevHllhgszdu3apYiICBmGofHjxys4OFiOjo7av3+/li9frjvvvFOnTp2q9rrff/+9Zs6cqd69e1c56F0vP/30k8LDw3X8+HE99dRTmjlzpho0aKBDhw7p448/VmBgoE6fPi0PD4/aniqA64hgAaDaff311xo7dqzuv/9+/eMf/5Cjo6P1tdDQUI0bN07x8fFycXEpd5zz58/XyS/TVeXi4qIePXpYn//xj3+Us7OzRo0apeTkZIWHh5uucenSJVksFjk43Di//t3d3W3et+spLy9PAwcOlLOzs1JSUtS8eXPra71799aYMWP0j3/8o0bm8ntRWFioBx54QCdOnNCOHTvUqVMn62v33HOPoqKitH79etWrV68WZ3nz/T4BagOHQgGodi+99JLs7e313nvv2YSK33r44YfVtGlT6/Po6Gg1aNBA6enpCg8Pl5ubm/r06SNJ+u9//6uxY8eqWbNmcnR01K233qrnn39e+fn51u0PHToki8VS6mE3FovF5i/XM2bMkMVi0Z49e/Tggw/K3d1dHh4eGjZsmH799dcS269evVrBwcFydXVVgwYNdO+992rPnj0l+sXFxaldu3ZycnJS+/bttWzZsoq+ZWUq/gvvb7+U/fvf/9bjjz+u22+/XfXr11ezZs00YMAApaen22xbfCjJhx9+qKefflrNmjWTk5OT/v3vfysuLk4Wi0VJSUl6/PHH5eXlJVdXVw0YMED/+c9/rjmvixcvaurUqfLz85Ojo6OaNWumcePG6fTp09Y+rVu31r/+9S999dVX1kO8yvtL+8MPP6yOHTvatA0YMEAWi0Xx8fHWtu+++04Wi0Wff/65zX4WHzITHR2tefPmSZLN4WVXH0L04Ycfqn379qpfv74CAgL0z3/+85r7/f777ysnJ0evvvqqTaj4rYceesj6371791bv3r1L9Cnt8LIFCxYoICBADRo0kJubm/z9/fXcc89JuvLZevjhhyVJISEh1n367ed9yZIlCggIkLOzs7y8vPTAAw8oMzOzRN0GDRrohx9+0L333itXV1c1adJEL7/8siRp586duuuuu+Tq6qq2bdvqgw8+uOZ78umnnyo9PV1Tp061CRW/1b9/f5sv9cnJyerTp4/c3NxUv3599ezZU2vXrr1mLUn67LPPFBwcrPr168vNzU1hYWHasWOHTZ/if+PfffedHnroIXl6elpXR//zn//okUceUdOmTeXk5CQfHx/16dNHaWlpFaoPoGwECwDVqrCwUFu2bFFQUJCaNGlSqW0LCgr0pz/9SaGhoVqzZo1mzpypixcvKiQkRMuWLdPkyZO1du1aDRs2TK+++qoefPBBU3N94IEHdNttt+kf//iHZsyYoU8//VT33nuvLl26ZO3z0ksvaejQoerQoYM+/vhjffjhhzpz5ozuvvtuff/999Z+cXFxevzxx9W+fXt98skneuGFFzR79mxt3ry5UnO6fPmyLl++rPPnz2vXrl2aNWuWbr31VvXs2dPa55dfflHDhg318ssva8OGDZo3b54cHBzUvXt3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s7PT//7v/8pisUiSli5dqltuuUVbt25VeHi4XFxclJ+fb1M3KytLt99+u+666y5ZLBa1atWqut8aALhhsWIBAKh2hmFYv9Bv2bJFYWFhatasmdzc3DRixAidPHlS586dK3eMPXv2aODAgWrVqpXc3NzUu3dvSVe+/EvSn//8Z61atUp/+MMf9Ne//lUpKSnWbVNTU/Xvf/9bbm5uatCggRo0aCAvLy9dvHhRP/30U5k1o6OjlZaWpnbt2ukvf/mLvvjiC5PvBADcPAgWAIBql5mZKT8/P/3888+677771KlTJ33yySdKTU3VvHnzJEmXLl0qc/tz584pPDxcDRo00PLly7V7924lJiZKunKIlCT1799fP//8s2JiYvTLL7+oT58+1sOoioqKFBgYqLS0NJvHjz/+qEcffbTMut26ddPBgwc1e/ZsXbhwQYMHD9ZDDz1UXW8LANzQOBQKAFCtNm/erPT0dE2aNEnffvutLl++rNdff112dlf+lvXxxx/b9Hd0dFRhYaFN2w8//KATJ07o5ZdfVosWLSRJ3377bYla3t7eio6OVnR0tO6++24988wzmjNnjrp166bVq1ercePGcnd3L3WepdWVJHd3dw0ZMkRDhgzRQw89pH79+um///2vvLy8qvR+AMDNghULAECV5efnKycnR0ePHtV3332nl156SQMHDlRERIRGjBihNm3a6PLly3rnnXf0n//8Rx9++KEWLlxoM0br1q119uxZffnllzpx4oTOnz+vli1bytHR0brdZ599ptmzZ9ts97e//U1r1qzRv//9b/3rX//SP//5T7Vv316S9Nhjj6lRo0YaOHCgtm/froMHD+qrr77SxIkTdeTIEWvdffv2af/+/Tpx4oQuXbqkN998U6tWrdIPP/ygH3/8UfHx8fL19a2V+2wAQF1DsAAAVNmGDRvUpEkTtW7dWv369dOWLVv09ttva82aNbK3t9cf/vAHvfHGG3rllVfUqVMnrVixosTlW3v27KmnnnpKQ4YMkbe3t1599VV5e3srLi5O8fHx6tChg15++WXNmTPHZjtHR0dNnTpVXbp00R//+EfZ29tr1apVkqT69etr27ZtatmypR588EG1b99eI0eO1IULF6wrGE888YTatWunoKAgeXt76+uvv1aDBg30yiuvKCgoSHfccYcOHTqkdevWWVdbAABlsxiGYdT2JAAAAADUbfwJBgAAAIBpBAsAAAAAphEsAAAAAJhGsAAAAABgGsECAAAAgGkECwAAAACmESwAAAAAmEawAAAAAGAawQIAAACAaQQLAAAAAKYRLAAAAACYRrAAAAAAYNr/A9534jO/8J9zAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "plt.figure(figsize=(10,3))\n",
    "# Sample data (replace with your DataFrame)\n",
    "data = {\n",
    "    'dataset_A': [10, 15, 20],\n",
    "    'dataset_B': [5, 8, 12]\n",
    "}\n",
    "\n",
    "dropout_ratios = [0.1, 0.2, 0.3]\n",
    "\n",
    "df = pd.DataFrame(data, columns=['dataset_A', 'dataset_B'], index=dropout_ratios)\n",
    "df = dropout.copy()\n",
    "# Grouped barplot\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "\n",
    "# Define colors\n",
    "colors = ['blue', 'blue']\n",
    "\n",
    "# Width of each bar (make it narrower)\n",
    "bar_width = 0.1  # Adjust this value to make bars narrower\n",
    "\n",
    "for i, dropout_ratio in enumerate(df.index):\n",
    "    x = np.arange(len(df.columns))\n",
    "\n",
    "    # Set the color for the first bar to red, others to blue\n",
    "    bar_colors = [colors[0] if j == 0 else colors[1] for j in range(len(df.columns))]\n",
    "\n",
    "    ax.bar(x + i * (bar_width+0.1) , df.loc[dropout_ratio], bar_width, label=f'Dropout {dropout_ratio}', color=bar_colors)\n",
    "\n",
    "# Add labels, title, and legend\n",
    "ax.set_xlabel('Datasets')\n",
    "ax.set_ylabel('Values')\n",
    "ax.set_title('Grouped Barplot with Custom Colors')\n",
    "ax.set_xticks(np.arange(len(df.columns)) + bar_width / 2)\n",
    "ax.set_xticklabels(df.columns)\n",
    "ax.legend()\n",
    "ax.set_ylim(0.22,0.42)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "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
}
