{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "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_{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": 3,
   "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_{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": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.422,mae=0.434\n",
      "4 --- ft=20: mse=0.422,mae=0.435\n",
      "4 --- ft=40: mse=0.426,mae=0.438\n",
      "4 --- ft=60: mse=0.422,mae=0.435\n",
      "==================================================\n",
      "X patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.422,mae=0.434\n",
      "4 --- ft=20: mse=0.422,mae=0.434\n",
      "4 --- ft=40: mse=0.424,mae=0.435\n",
      "4 --- ft=60: mse=0.421,mae=0.433\n",
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.419,mae=0.431\n",
      "4 --- ft=20: mse=0.42,mae=0.432\n",
      "4 --- ft=40: mse=0.419,mae=0.431\n",
      "4 --- ft=60: mse=0.418,mae=0.431\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['X']:\n",
    "    MLP_data_input_output_patchlen(data='etth1',input_='O',output_=output,patch_len=12,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='etth1',input_='O',output_=output,patch_len=12,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='etth1',input_='O',output_=output,patch_len=12,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.26,mae=0.321\n",
      "4 --- ft=20: mse=0.26,mae=0.319\n",
      "3 --- ft=40: mse=0.271,mae=0.327\n",
      "4 --- ft=60: mse=0.26,mae=0.32\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['X']:\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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.426,mae=0.441\n",
      "4 --- ft=20: mse=0.425,mae=0.439\n",
      "4 --- ft=40: mse=0.425,mae=0.439\n",
      "4 --- ft=60: mse=0.422,mae=0.437\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['X']:\n",
    "    Trans_data_input_output_patchlen(data='etth1',input_='O',output_=output,patch_len=12,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.363,mae=0.405\n",
      "4 --- ft=20: mse=0.361,mae=0.404\n",
      "4 --- ft=40: mse=0.361,mae=0.403\n",
      "4 --- ft=60: mse=0.368,mae=0.409\n",
      "==================================================\n",
      "X patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.357,mae=0.401\n",
      "4 --- ft=20: mse=0.365,mae=0.407\n",
      "4 --- ft=40: mse=0.364,mae=0.406\n",
      "4 --- ft=60: mse=0.364,mae=0.406\n",
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.355,mae=0.399\n",
      "4 --- ft=20: mse=0.362,mae=0.405\n",
      "4 --- ft=40: mse=0.368,mae=0.41\n",
      "4 --- ft=60: mse=0.369,mae=0.41\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['X']:\n",
    "    MLP_data_input_output_patchlen(data='etth2',input_='O',output_=output,patch_len=12,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='etth2',input_='O',output_=output,patch_len=12,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='etth2',input_='O',output_=output,patch_len=12,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.357,mae=0.382\n",
      "4 --- ft=20: mse=0.354,mae=0.383\n",
      "4 --- ft=40: mse=0.356,mae=0.385\n",
      "4 --- ft=60: mse=0.354,mae=0.384\n",
      "==================================================\n",
      "X patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.354,mae=0.381\n",
      "4 --- ft=20: mse=0.356,mae=0.384\n",
      "4 --- ft=40: mse=0.354,mae=0.384\n",
      "4 --- ft=60: mse=0.355,mae=0.384\n",
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.356,mae=0.382\n",
      "4 --- ft=20: mse=0.354,mae=0.383\n",
      "4 --- ft=40: mse=0.357,mae=0.384\n",
      "4 --- ft=60: mse=0.356,mae=0.384\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=12,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=12,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=12,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X 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.32\n",
      "4 --- ft=60: mse=0.255,mae=0.319\n",
      "==================================================\n",
      "X patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.258,mae=0.319\n",
      "4 --- ft=20: mse=0.258,mae=0.32\n",
      "4 --- ft=40: mse=0.259,mae=0.321\n",
      "4 --- ft=60: mse=0.258,mae=0.32\n",
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.259,mae=0.321\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.259,mae=0.321\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm2',input_='O',output_=output,patch_len=12,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm2',input_='O',output_=output,patch_len=12,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm2',input_='O',output_=output,patch_len=12,dim=128)\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
}
