{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 136,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ionJLxEZRUZGBkaNGqVNJN97770ihw+rCF566SUAUscwTYe2isjGxgYdO3YEII3GoO+wW9bW1tr9QkJCcOvWrSK3XbNmDQCp9blTp05lircs2rdvDwBIS0vDX3/9Va7H3rRpk/Zxrlat2jOngz516lSBmIjIdDD5JSKDu3jxIgICArT1vh07dsSECRNkjqp477//vrZF76233tImO0XZu3evtl60PB09elQ78oQuWVlZ2iHLnJycSlR/OmnSJABAdnY2xowZo3P0iO+//x6//fYbAGDw4MEFhl4ztvyJZv7W6LJ4/PgxPv/8c7z22msApI55a9euLbY19+rVq9qOcUx+iUxPxW12ISKTcf/+/QJDYD169AiJiYmIjo5GaGgoQkJCtC2+bdu2xdatW2FjYyNXuHrx8vLCypUrMXr0aCQkJKBdu3Z47bXX0LdvX9SqVQs5OTmIjY3FH3/8ga1btyImJgbBwcEFxhguD6GhoVi4cCHat2+PPn36oHnz5nB3d0dGRgYuX76MlStXIioqCgAwduzYErWm9+nTB0OHDsUvv/yCgwcPws/PD//973/x3HPPITExEZs2bcL3338PQKr1XbZsWbnetpKqU6cOGjdujIsXLyI0NBSjR4/Wa7/8z83c3FwkJSUhNjYWx48fx9atW7U1zSqVCt988w169epV7PE0pTtWVlbo0aNHKW8NEcmFyS8RldmKFSuwYsWKYrdxd3fHlClTMH369Apd7pDf66+/Dnt7e4wfPx4pKSlYu3Yt1q5dq3NbpVIJR0dHg8SRl5eHsLAwbQuvLoMGDcKiRYtKfOyNGzciJycHO3bswNmzZ7UtoPl5enpiz5492jpoOb322muYNWsWdu7cifT09GcOIQc8qRUuikKhQOfOnbFs2TK9vrwEBQUBALp27VrsiBBEVDGZxicQEZkMpVIJZ2dnqNVq1K5dG76+vmjfvj369u1rsKHADGn48OHo3r07Vq9ejf379+PixYtITEyEjY0NPDw80KRJE7z44osYMmRIsbOkldb06dPh5+eHkJAQREZG4s6dO9pxiD08PODn54dRo0ahd+/epTq+nZ0dtm/fjuDgYKxfvx7Hjx/HgwcP4OjoiIYNG2LAgAGYPHlygZnP5PTGG29gwYIFSEtLw86dO/Hyyy+XaH87Ozuo1Wq4urqiWbNmaN26Nfr3748GDRrotf/t27dx5MgRAMDEiRNLHD8RyU8hKmI3ZiIioiK89dZbWLVqFbp06YKDBw8a9dwff/wx5s2bh0aNGuHixYsFJu8gItPA5JeIiEzKrVu3UL9+fWRlZSEiIgL+/v5GOW9aWhrq1KmDhw8fIigoqMStzkRUMfArKxERmZSaNWtiypQpAIAFCxYY7bzffPMNHj58iNatW2PEiBFGOy8RlS/W/BIRkcmZO3eutrNbWlqaUWqSnZ2dMX/+fAwaNMhkpoQmosJY9kBEREREFoNlD0RERERkMZj8EhEREZHFYPJLRERERBaDyS8RERERWQwmv0RERERkMZj8EhEREZHFYPJLRERERBaDyS8RERERWQwmv0RERERkMZj8EhEREZHF+H+w7c097OUJSgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "do_0 = [0.346,0.344,0.342,0.348,0.348,0.351,0.348,0.348]\n",
    "do_2 = [0.348,0.341,0.339,0.345,0.345,0.338,0.338,0.338]\n",
    "custom_xticks = ['4','6','8','12','16','32','64','128']\n",
    "ax = plt.plot(custom_xticks,do_0,color='red',label='w/o Dropout')\n",
    "ax = plt.plot(custom_xticks,do_2,color='blue',label='w/ Dropout')\n",
    "#plt.xticks([4,6,8,12,16,32,64,128])\n",
    "#custom_xticks = [2,4,8,12,16,24,32]\n",
    "plt.xticks(custom_xticks,fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "plt.legend(fontsize=15)\n",
    "plt.title('Performance by dimension & dropout', size=25,pad=20)\n",
    "plt.xlabel('Dimension (D)',fontsize=20,labelpad=10)\n",
    "plt.ylabel('Avg. MSE',fontsize=20,labelpad=10)\n",
    "SAVE_PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/viz/'\n",
    "plt.savefig(os.path.join(SAVE_PATH,f'dim_dropout.pdf'), format=\"pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MLP\n",
    "- `results_with_FC2_sep.ipynb`\n",
    "- `results_with_FC2_wo_CL.ipynb`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [],
   "source": [
    "def MLP_data_input_output_patchlen(data,dim,do):\n",
    "    input_= 'O'\n",
    "    output_= 'O'\n",
    "    patch_len= 12\n",
    "    \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_{input_}_{output_}/based_model/max'\n",
    "        PATCH2 = [x for x in os.listdir(PATH) if f'patch{patch_len}_' in x]\n",
    "        if do==0.2:\n",
    "            PATCH2 = [x for x in PATCH2 if (f'_D{dim}_' in x) & ('head_drop' not in x)][0]\n",
    "        else:\n",
    "            PATCH2 = [x for x in PATCH2 if (f'_D{dim}_' in x) & (f'head_drop_{do}' 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": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'ettm2'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 16\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.408,mae=0.424\n",
      "4 --- ft=20: mse=0.411,mae=0.425\n",
      "4 --- ft=40: mse=0.409,mae=0.424\n",
      "4 --- ft=60: mse=0.409,mae=0.425\n",
      "====================================================================================================\n",
      "==================================================\n",
      "O patch size= 12 dim= 16\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.356,mae=0.4\n",
      "4 --- ft=20: mse=0.358,mae=0.402\n",
      "4 --- ft=40: mse=0.364,mae=0.406\n",
      "4 --- ft=60: mse=0.363,mae=0.404\n",
      "====================================================================================================\n",
      "==================================================\n",
      "O patch size= 12 dim= 16\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.381\n",
      "4 --- ft=20: mse=0.358,mae=0.381\n",
      "4 --- ft=40: mse=0.358,mae=0.383\n",
      "4 --- ft=60: mse=0.36,mae=0.384\n",
      "====================================================================================================\n",
      "==================================================\n",
      "O patch size= 12 dim= 16\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.259,mae=0.318\n",
      "4 --- ft=20: mse=0.26,mae=0.319\n",
      "4 --- ft=40: mse=0.258,mae=0.317\n",
      "4 --- ft=60: mse=0.264,mae=0.322\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "dataset = 'etth1'\n",
    "do_ratio = 0.2\n",
    "d = 16\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=4,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=d,do=do_ratio)\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=8,do=do_ratio)\n",
    "print('='*100)\n",
    "dataset = 'etth2'\n",
    "do_ratio = 0.0\n",
    "\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=4,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=d,do=do_ratio)\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=8,do=do_ratio)\n",
    "print('='*100)\n",
    "dataset = 'ettm1'\n",
    "do_ratio = 0.0\n",
    "\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=4,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=d,do=do_ratio)\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=8,do=do_ratio)\n",
    "print('='*100)\n",
    "dataset = 'ettm2'\n",
    "do_ratio = 0.0\n",
    "\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=4,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=d,do=do_ratio)\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=8,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 8\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.341,mae=0.389\n",
      "4 --- ft=20: mse=0.342,mae=0.39\n",
      "4 --- ft=40: mse=0.347,mae=0.391\n",
      "4 --- ft=60: mse=0.351,mae=0.395\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "dataset = 'etth2'\n",
    "do_ratio = 0.0\n",
    "\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=4,do=do_ratio)\n",
    "#MLP_data_input_output_patchlen(data=dataset,dim=6,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=8,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.26,mae=0.322\n",
      "4 --- ft=20: mse=0.258,mae=0.319\n",
      "4 --- ft=40: mse=0.258,mae=0.32\n",
      "4 --- ft=60: mse=0.257,mae=0.318\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.257,mae=0.318\n",
      "4 --- ft=20: mse=0.258,mae=0.32\n",
      "4 --- ft=40: mse=0.258,mae=0.32\n",
      "4 --- ft=60: mse=0.257,mae=0.318\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.256,mae=0.319\n",
      "4 --- ft=20: mse=0.257,mae=0.32\n",
      "4 --- ft=40: mse=0.256,mae=0.316\n",
      "4 --- ft=60: mse=0.255,mae=0.317\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "do_ratio = 0.0\n",
    "\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=32,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=64,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=128,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.312\n",
      "4 --- ft=20: mse=0.253,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.253,mae=0.312\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.312\n",
      "4 --- ft=20: mse=0.254,mae=0.313\n",
      "4 --- ft=40: mse=0.254,mae=0.313\n",
      "4 --- ft=60: mse=0.254,mae=0.314\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.255,mae=0.315\n",
      "4 --- ft=20: mse=0.254,mae=0.312\n",
      "4 --- ft=40: mse=0.254,mae=0.314\n",
      "4 --- ft=60: mse=0.254,mae=0.314\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "do_ratio = 0.1\n",
    "\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=32,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=64,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=128,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "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.314\n",
      "4 --- ft=20: mse=0.253,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.253,mae=0.312\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.253,mae=0.312\n",
      "4 --- ft=20: mse=0.254,mae=0.313\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.254,mae=0.312\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.255,mae=0.315\n",
      "4 --- ft=20: mse=0.253,mae=0.313\n",
      "4 --- ft=40: mse=0.253,mae=0.313\n",
      "4 --- ft=60: mse=0.254,mae=0.314\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "do_ratio = 0.2\n",
    "\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=32,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=64,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=128,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.313\n",
      "4 --- ft=20: mse=0.253,mae=0.311\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.253,mae=0.311\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.253,mae=0.312\n",
      "4 --- ft=20: mse=0.254,mae=0.313\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.253,mae=0.311\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.255,mae=0.315\n",
      "4 --- ft=20: mse=0.253,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.254,mae=0.314\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "do_ratio = 0.3\n",
    "\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=32,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=64,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=128,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.313\n",
      "4 --- ft=20: mse=0.252,mae=0.311\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.253,mae=0.312\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.253,mae=0.312\n",
      "4 --- ft=20: mse=0.252,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.254,mae=0.312\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.314\n",
      "4 --- ft=20: mse=0.253,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.254,mae=0.314\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "do_ratio = 0.4\n",
    "\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=32,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=64,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=128,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.313\n",
      "4 --- ft=20: mse=0.253,mae=0.313\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.252,mae=0.311\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.253,mae=0.312\n",
      "4 --- ft=20: mse=0.252,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.312\n",
      "4 --- ft=60: mse=0.253,mae=0.312\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.265,mae=0.322\n",
      "4 --- ft=20: mse=0.253,mae=0.312\n",
      "4 --- ft=40: mse=0.253,mae=0.313\n",
      "4 --- ft=60: mse=0.254,mae=0.314\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "do_ratio = 0.5\n",
    "\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=32,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=64,do=do_ratio)\n",
    "MLP_data_input_output_patchlen(data=dataset,dim=128,do=do_ratio)\n",
    "print('='*100)"
   ]
  },
  {
   "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
}
