{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 17,
   "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_CL_{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": 18,
   "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_CL_{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": 23,
   "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.32\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.322\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": [
    "dataset = 'ettm2'\n",
    "for output in ['X']:\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": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.403,mae=0.415\n",
      "4 --- ft=20: mse=0.413,mae=0.425\n",
      "4 --- ft=40: mse=0.414,mae=0.426\n",
      "4 --- ft=60: mse=0.414,mae=0.427\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)"
   ]
  }
 ],
 "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
}
