{
 "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,version):\n",
    "    print('='*50)\n",
    "    print(output_, 'patch size=',patch_len, 'dim=',dim)\n",
    "    print('='*50)\n",
    "    try:\n",
    "        if version==0:\n",
    "            PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_FC2_CL_{input_}_{output_}/based_model/max'\n",
    "        else:\n",
    "            PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_FC2_CL_v{version}_{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",
    "        \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": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "X patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.263,mae=0.323\n",
      "3 --- ft=20: mse=0.227,mae=0.299\n",
      "4 --- ft=40: mse=0.262,mae=0.322\n",
      "4 --- ft=60: mse=0.261,mae=0.323\n",
      "==================================================\n",
      "X patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.27,mae=0.328\n",
      "4 --- ft=20: mse=0.261,mae=0.321\n",
      "4 --- ft=40: mse=0.266,mae=0.325\n",
      "4 --- ft=60: mse=0.262,mae=0.323\n",
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.266,mae=0.324\n",
      "4 --- ft=20: mse=0.263,mae=0.324\n",
      "4 --- ft=40: mse=0.262,mae=0.323\n",
      "4 --- ft=60: mse=0.262,mae=0.322\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "dataset = 'ettm2'\n",
    "for output in ['X']:\n",
    "    version= 0\n",
    "    MLP_data_input_output_patchlen(data=dataset,input_='O',output_=output,patch_len=12,dim=32,version=version)\n",
    "    MLP_data_input_output_patchlen(data=dataset,input_='O',output_=output,patch_len=12,dim=64,version=version)\n",
    "    MLP_data_input_output_patchlen(data=dataset,input_='O',output_=output,patch_len=12,dim=128,version=version)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.354,mae=0.383\n",
      "3 --- ft=20: mse=0.355,mae=0.382\n",
      "4 --- ft=40: mse=0.353,mae=0.384\n",
      "4 --- ft=60: mse=0.356,mae=0.383\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.372,mae=0.394\n",
      "4 --- ft=20: mse=0.357,mae=0.386\n",
      "4 --- ft=40: mse=0.354,mae=0.385\n",
      "4 --- ft=60: mse=0.362,mae=0.39\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.355,mae=0.384\n",
      "3 --- ft=20: mse=0.332,mae=0.372\n",
      "4 --- ft=40: mse=0.356,mae=0.386\n",
      "4 --- ft=60: mse=0.356,mae=0.388\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.358,mae=0.388\n",
      "4 --- ft=20: mse=0.36,mae=0.388\n",
      "4 --- ft=40: mse=0.358,mae=0.388\n",
      "4 --- ft=60: mse=0.36,mae=0.39\n",
      "==================================================\n",
      "X patch size= 12 dim= 64\n",
      "==================================================\n",
      "==================================================\n",
      "X patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.355,mae=0.386\n",
      "4 --- ft=20: mse=0.358,mae=0.39\n",
      "4 --- ft=40: mse=0.355,mae=0.389\n",
      "4 --- ft=60: mse=0.358,mae=0.388\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    version= 1\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=12,dim=32,version=version)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=12,dim=64,version=version)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=12,dim=128,version=version)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "patchtst_sim_pretrained_D32_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_no_permute\n",
      "['tw336_ft_ep10_model1_load_ep100_acc.csv', 'tw96_ft_ep10_model1_load_ep100_acc.csv', 'tw192_ft_ep60_model1_load_ep100_acc.csv', 'tw720_ft_ep10_model1_load_ep100_acc.csv', 'tw96_ft_ep40_model1_load_ep100_acc.csv', 'tw96_ft_ep20_model1_load_ep100_acc.csv', 'tw192_ft_ep20_model1_load_ep100_acc.csv', 'tw720_ft_ep20_model1_load_ep100_acc.csv', 'tw720_ft_ep40_model1_load_ep100_acc.csv', 'tw336_ft_ep20_model1_load_ep100_acc.csv', 'tw96_ft_ep60_model1_load_ep100_acc.csv', 'tw720_ft_ep60_model1_load_ep100_acc.csv', 'tw336_ft_ep40_model1_load_ep100_acc.csv', 'tw192_ft_ep10_model1_load_ep100_acc.csv', 'tw192_ft_ep40_model1_load_ep100_acc.csv', 'tw336_ft_ep60_model1_load_ep100_acc.csv']\n",
      "4 --- ft=10: mse=0.354,mae=0.383\n",
      "4 --- ft=20: mse=0.357,mae=0.385\n",
      "4 --- ft=40: mse=0.353,mae=0.384\n",
      "4 --- ft=60: mse=0.356,mae=0.383\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "patchtst_sim_pretrained_D64_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_no_permute\n",
      "['tw336_ft_ep10_model1_load_ep100_acc.csv', 'tw96_ft_ep10_model1_load_ep100_acc.csv', 'tw192_ft_ep60_model1_load_ep100_acc.csv', 'tw720_ft_ep10_model1_load_ep100_acc.csv', 'tw96_ft_ep40_model1_load_ep100_acc.csv', 'tw96_ft_ep20_model1_load_ep100_acc.csv', 'tw192_ft_ep20_model1_load_ep100_acc.csv', 'tw720_ft_ep20_model1_load_ep100_acc.csv', 'tw720_ft_ep40_model1_load_ep100_acc.csv', 'tw336_ft_ep20_model1_load_ep100_acc.csv', 'tw96_ft_ep60_model1_load_ep100_acc.csv', 'tw720_ft_ep60_model1_load_ep100_acc.csv', 'tw336_ft_ep40_model1_load_ep100_acc.csv', 'tw192_ft_ep10_model1_load_ep100_acc.csv', 'tw192_ft_ep40_model1_load_ep100_acc.csv', 'tw336_ft_ep60_model1_load_ep100_acc.csv']\n",
      "4 --- ft=10: mse=0.357,mae=0.384\n",
      "4 --- ft=20: mse=0.357,mae=0.386\n",
      "4 --- ft=40: mse=0.354,mae=0.385\n",
      "4 --- ft=60: mse=0.362,mae=0.39\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "patchtst_sim_pretrained_D128_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_no_permute\n",
      "['tw336_ft_ep10_model1_load_ep100_acc.csv', 'tw96_ft_ep10_model1_load_ep100_acc.csv', 'tw192_ft_ep60_model1_load_ep100_acc.csv', 'tw720_ft_ep10_model1_load_ep100_acc.csv', 'tw96_ft_ep40_model1_load_ep100_acc.csv', 'tw96_ft_ep20_model1_load_ep100_acc.csv', 'tw192_ft_ep20_model1_load_ep100_acc.csv', 'tw720_ft_ep20_model1_load_ep100_acc.csv', 'tw720_ft_ep40_model1_load_ep100_acc.csv', 'tw336_ft_ep20_model1_load_ep100_acc.csv', 'tw96_ft_ep60_model1_load_ep100_acc.csv', 'tw720_ft_ep60_model1_load_ep100_acc.csv', 'tw336_ft_ep40_model1_load_ep100_acc.csv', 'tw192_ft_ep10_model1_load_ep100_acc.csv', 'tw192_ft_ep40_model1_load_ep100_acc.csv', 'tw336_ft_ep60_model1_load_ep100_acc.csv']\n",
      "4 --- ft=10: mse=0.355,mae=0.384\n",
      "4 --- ft=20: mse=0.355,mae=0.383\n",
      "4 --- ft=40: mse=0.356,mae=0.386\n",
      "4 --- ft=60: mse=0.356,mae=0.388\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "data='ettm1'\n",
    "for output in ['O']:\n",
    "    version= 2\n",
    "    MLP_data_input_output_patchlen(data=data,input_='O',output_=output,patch_len=12,dim=32,version=version)\n",
    "    MLP_data_input_output_patchlen(data=data,input_='O',output_=output,patch_len=12,dim=64,version=version)\n",
    "    MLP_data_input_output_patchlen(data=data,input_='O',output_=output,patch_len=12,dim=128,version=version)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.337,mae=0.385\n",
      "4 --- ft=20: mse=0.334,mae=0.383\n",
      "4 --- ft=40: mse=0.335,mae=0.383\n",
      "4 --- ft=60: mse=0.339,mae=0.386\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.335,mae=0.384\n",
      "4 --- ft=20: mse=0.336,mae=0.384\n",
      "4 --- ft=40: mse=0.334,mae=0.383\n",
      "4 --- ft=60: mse=0.341,mae=0.387\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.336,mae=0.384\n",
      "4 --- ft=20: mse=0.349,mae=0.393\n",
      "4 --- ft=40: mse=0.342,mae=0.389\n",
      "4 --- ft=60: mse=0.335,mae=0.383\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "data='etth2'\n",
    "for output in ['O']:\n",
    "    version= 3\n",
    "    MLP_data_input_output_patchlen(data=data,input_='O',output_=output,patch_len=12,dim=32,version=version)\n",
    "    MLP_data_input_output_patchlen(data=data,input_='O',output_=output,patch_len=12,dim=64,version=version)\n",
    "    MLP_data_input_output_patchlen(data=data,input_='O',output_=output,patch_len=12,dim=128,version=version)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 2 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.382\n",
      "4 --- ft=20: mse=0.359,mae=0.383\n",
      "4 --- ft=40: mse=0.363,mae=0.382\n",
      "4 --- ft=60: mse=0.359,mae=0.38\n",
      "==================================================\n",
      "O patch size= 2 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.38\n",
      "3 --- ft=20: mse=0.356,mae=0.378\n",
      "4 --- ft=40: mse=0.359,mae=0.383\n",
      "4 --- ft=60: mse=0.357,mae=0.382\n",
      "==================================================\n",
      "O patch size= 2 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.352,mae=0.381\n",
      "4 --- ft=20: mse=0.354,mae=0.382\n",
      "4 --- ft=40: mse=0.357,mae=0.381\n",
      "4 --- ft=60: mse=0.355,mae=0.383\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 2 dim= 32\n",
      "==================================================\n",
      "==================================================\n",
      "X patch size= 2 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.351,mae=0.382\n",
      "4 --- ft=20: mse=0.353,mae=0.386\n",
      "4 --- ft=40: mse=0.353,mae=0.386\n",
      "4 --- ft=60: mse=0.355,mae=0.391\n",
      "==================================================\n",
      "X patch size= 2 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.352,mae=0.384\n",
      "4 --- ft=20: mse=0.35,mae=0.385\n",
      "4 --- ft=40: mse=0.352,mae=0.39\n",
      "3 --- ft=60: mse=0.368,mae=0.399\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=2,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=2,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=2,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 4 dim= 32\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.249,mae=0.309\n",
      "==================================================\n",
      "O patch size= 4 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.313\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.312\n",
      "==================================================\n",
      "O patch size= 4 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.254,mae=0.313\n",
      "4 --- ft=20: mse=0.255,mae=0.313\n",
      "3 --- ft=40: mse=0.265,mae=0.32\n",
      "4 --- ft=60: mse=0.253,mae=0.312\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 4 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.258,mae=0.32\n",
      "4 --- ft=20: mse=0.258,mae=0.319\n",
      "4 --- ft=40: mse=0.26,mae=0.322\n",
      "3 --- ft=60: mse=0.287,mae=0.339\n",
      "==================================================\n",
      "X patch size= 4 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.26,mae=0.321\n",
      "4 --- ft=20: mse=0.259,mae=0.32\n",
      "4 --- ft=40: mse=0.259,mae=0.32\n",
      "4 --- ft=60: mse=0.255,mae=0.318\n",
      "==================================================\n",
      "X patch size= 4 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.263,mae=0.325\n",
      "4 --- ft=20: mse=0.263,mae=0.324\n",
      "4 --- ft=40: mse=0.261,mae=0.322\n",
      "4 --- ft=60: mse=0.258,mae=0.32\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=4,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=4,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=4,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 8 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.38\n",
      "4 --- ft=20: mse=0.357,mae=0.38\n",
      "4 --- ft=40: mse=0.359,mae=0.381\n",
      "4 --- ft=60: mse=0.36,mae=0.383\n",
      "==================================================\n",
      "O patch size= 8 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.358,mae=0.38\n",
      "4 --- ft=20: mse=0.357,mae=0.379\n",
      "4 --- ft=40: mse=0.358,mae=0.38\n",
      "4 --- ft=60: mse=0.36,mae=0.383\n",
      "==================================================\n",
      "O patch size= 8 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.38\n",
      "4 --- ft=20: mse=0.357,mae=0.381\n",
      "4 --- ft=40: mse=0.359,mae=0.382\n",
      "4 --- ft=60: mse=0.36,mae=0.382\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 8 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.354,mae=0.384\n",
      "4 --- ft=20: mse=0.354,mae=0.385\n",
      "4 --- ft=40: mse=0.355,mae=0.387\n",
      "4 --- ft=60: mse=0.353,mae=0.388\n",
      "==================================================\n",
      "X patch size= 8 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.354,mae=0.384\n",
      "4 --- ft=20: mse=0.355,mae=0.385\n",
      "4 --- ft=40: mse=0.354,mae=0.385\n",
      "4 --- ft=60: mse=0.355,mae=0.388\n",
      "==================================================\n",
      "X patch size= 8 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.355,mae=0.385\n",
      "4 --- ft=20: mse=0.353,mae=0.387\n",
      "4 --- ft=40: mse=0.353,mae=0.387\n",
      "4 --- ft=60: mse=0.355,mae=0.388\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=8,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=8,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=8,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 12 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.357,mae=0.38\n",
      "4 --- ft=20: mse=0.359,mae=0.381\n",
      "4 --- ft=40: mse=0.361,mae=0.382\n",
      "4 --- ft=60: mse=0.358,mae=0.382\n",
      "==================================================\n",
      "O patch size= 12 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.379\n",
      "4 --- ft=20: mse=0.361,mae=0.381\n",
      "4 --- ft=40: mse=0.358,mae=0.382\n",
      "4 --- ft=60: mse=0.359,mae=0.382\n",
      "==================================================\n",
      "O patch size= 12 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.358,mae=0.378\n",
      "4 --- ft=20: mse=0.36,mae=0.382\n",
      "4 --- ft=40: mse=0.357,mae=0.383\n",
      "4 --- ft=60: mse=0.36,mae=0.385\n",
      "====================================================================================================\n",
      "==================================================\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 ['O','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": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 16 dim= 32\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.376,mae=0.39\n",
      "4 --- ft=20: mse=0.358,mae=0.382\n",
      "4 --- ft=40: mse=0.359,mae=0.382\n",
      "4 --- ft=60: mse=0.355,mae=0.383\n",
      "==================================================\n",
      "O patch size= 16 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.358,mae=0.38\n",
      "4 --- ft=20: mse=0.358,mae=0.38\n",
      "4 --- ft=40: mse=0.358,mae=0.384\n",
      "4 --- ft=60: mse=0.36,mae=0.385\n",
      "==================================================\n",
      "O patch size= 16 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.36,mae=0.38\n",
      "4 --- ft=20: mse=0.359,mae=0.382\n",
      "4 --- ft=40: mse=0.359,mae=0.383\n",
      "4 --- ft=60: mse=0.358,mae=0.384\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 16 dim= 32\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.37,mae=0.393\n",
      "4 --- ft=20: mse=0.354,mae=0.383\n",
      "4 --- ft=40: mse=0.352,mae=0.384\n",
      "4 --- ft=60: mse=0.355,mae=0.385\n",
      "==================================================\n",
      "X patch size= 16 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.354,mae=0.382\n",
      "4 --- ft=20: mse=0.353,mae=0.385\n",
      "4 --- ft=40: mse=0.357,mae=0.384\n",
      "4 --- ft=60: mse=0.359,mae=0.386\n",
      "==================================================\n",
      "X patch size= 16 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.353,mae=0.381\n",
      "4 --- ft=20: mse=0.355,mae=0.383\n",
      "4 --- ft=40: mse=0.359,mae=0.386\n",
      "4 --- ft=60: mse=0.357,mae=0.383\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=16,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=16,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=16,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 24 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.355,mae=0.381\n",
      "4 --- ft=20: mse=0.358,mae=0.383\n",
      "4 --- ft=40: mse=0.355,mae=0.383\n",
      "4 --- ft=60: mse=0.359,mae=0.386\n",
      "==================================================\n",
      "O patch size= 24 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.358,mae=0.38\n",
      "4 --- ft=20: mse=0.357,mae=0.38\n",
      "4 --- ft=40: mse=0.358,mae=0.381\n",
      "4 --- ft=60: mse=0.357,mae=0.382\n",
      "==================================================\n",
      "O patch size= 24 dim= 128\n",
      "==================================================\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 24 dim= 32\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.375,mae=0.392\n",
      "4 --- ft=20: mse=0.361,mae=0.385\n",
      "4 --- ft=40: mse=0.357,mae=0.383\n",
      "4 --- ft=60: mse=0.356,mae=0.384\n",
      "==================================================\n",
      "X patch size= 24 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.355,mae=0.382\n",
      "4 --- ft=20: mse=0.356,mae=0.382\n",
      "4 --- ft=40: mse=0.356,mae=0.386\n",
      "4 --- ft=60: mse=0.355,mae=0.383\n",
      "==================================================\n",
      "X patch size= 24 dim= 128\n",
      "==================================================\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=24,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=24,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='ettm1',input_='O',output_=output,patch_len=24,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "O patch size= 32 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.336,mae=0.384\n",
      "4 --- ft=20: mse=0.336,mae=0.384\n",
      "4 --- ft=40: mse=0.336,mae=0.384\n",
      "4 --- ft=60: mse=0.336,mae=0.384\n",
      "==================================================\n",
      "O patch size= 32 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.333,mae=0.383\n",
      "4 --- ft=20: mse=0.333,mae=0.382\n",
      "4 --- ft=40: mse=0.336,mae=0.384\n",
      "4 --- ft=60: mse=0.338,mae=0.385\n",
      "==================================================\n",
      "O patch size= 32 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.339,mae=0.387\n",
      "4 --- ft=20: mse=0.339,mae=0.385\n",
      "4 --- ft=40: mse=0.333,mae=0.383\n",
      "4 --- ft=60: mse=0.335,mae=0.383\n",
      "====================================================================================================\n",
      "==================================================\n",
      "X patch size= 32 dim= 32\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.367,mae=0.407\n",
      "4 --- ft=20: mse=0.361,mae=0.403\n",
      "4 --- ft=40: mse=0.368,mae=0.407\n",
      "4 --- ft=60: mse=0.365,mae=0.405\n",
      "==================================================\n",
      "X patch size= 32 dim= 64\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.361,mae=0.403\n",
      "4 --- ft=20: mse=0.358,mae=0.401\n",
      "4 --- ft=40: mse=0.362,mae=0.404\n",
      "4 --- ft=60: mse=0.361,mae=0.404\n",
      "==================================================\n",
      "X patch size= 32 dim= 128\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.403\n",
      "4 --- ft=20: mse=0.361,mae=0.404\n",
      "4 --- ft=40: mse=0.364,mae=0.408\n",
      "3 --- ft=60: mse=0.368,mae=0.411\n",
      "====================================================================================================\n"
     ]
    }
   ],
   "source": [
    "for output in ['O','X']:\n",
    "    MLP_data_input_output_patchlen(data='etth2',input_='O',output_=output,patch_len=32,dim=32)\n",
    "    MLP_data_input_output_patchlen(data='etth2',input_='O',output_=output,patch_len=32,dim=64)\n",
    "    MLP_data_input_output_patchlen(data='etth2',input_='O',output_=output,patch_len=32,dim=128)\n",
    "    print('='*100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Transformer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Transformer_data_input_output_patchlen(data,input_,output_,patch_len):\n",
    "\n",
    "    PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_Transformer_{input_}_{output_}/based_model/max'\n",
    "    PATCH2 = [x for x in os.listdir(PATH) if f'patch{patch_len}' 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",
    "        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",
    "    print('==================================================')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Transformer_CL_data_input_output_patchlen(data,input_,output_,patch_len):\n",
    "    \n",
    "    PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_Transformer_CL_{input_}_{output_}/based_model/max'\n",
    "    PATCH2 = [x for x in os.listdir(PATH) if f'patch{patch_len}' 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",
    "        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(f'{len(ft_n)} --- ft={ft}: mse={mse.round(3)},mae={mae.round(3)}')\n",
    "    print('==================================================')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ETTh1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "No objects to concatenate",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[4], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m Transformer_data_input_output_patchlen(data\u001b[39m=\u001b[39;49m\u001b[39m'\u001b[39;49m\u001b[39metth1\u001b[39;49m\u001b[39m'\u001b[39;49m,input_\u001b[39m=\u001b[39;49m\u001b[39m'\u001b[39;49m\u001b[39mO\u001b[39;49m\u001b[39m'\u001b[39;49m,output_\u001b[39m=\u001b[39;49m\u001b[39m'\u001b[39;49m\u001b[39mO\u001b[39;49m\u001b[39m'\u001b[39;49m,patch_len\u001b[39m=\u001b[39;49m\u001b[39m1\u001b[39;49m)\n\u001b[1;32m      2\u001b[0m Transformer_data_input_output_patchlen(data\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39metth1\u001b[39m\u001b[39m'\u001b[39m,input_\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mO\u001b[39m\u001b[39m'\u001b[39m,output_\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mO\u001b[39m\u001b[39m'\u001b[39m,patch_len\u001b[39m=\u001b[39m\u001b[39m6\u001b[39m)\n\u001b[1;32m      3\u001b[0m Transformer_data_input_output_patchlen(data\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39metth1\u001b[39m\u001b[39m'\u001b[39m,input_\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mO\u001b[39m\u001b[39m'\u001b[39m,output_\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mO\u001b[39m\u001b[39m'\u001b[39m,patch_len\u001b[39m=\u001b[39m\u001b[39m12\u001b[39m)\n",
      "Cell \u001b[0;32mIn[2], line 14\u001b[0m, in \u001b[0;36mTransformer_data_input_output_patchlen\u001b[0;34m(data, input_, output_, patch_len)\u001b[0m\n\u001b[1;32m     12\u001b[0m     df \u001b[39m=\u001b[39m pd\u001b[39m.\u001b[39mread_csv(os\u001b[39m.\u001b[39mpath\u001b[39m.\u001b[39mjoin(temp,file))\n\u001b[1;32m     13\u001b[0m     df_list\u001b[39m.\u001b[39mappend(df)\n\u001b[0;32m---> 14\u001b[0m df \u001b[39m=\u001b[39m pd\u001b[39m.\u001b[39;49mconcat(df_list,axis\u001b[39m=\u001b[39;49m\u001b[39m0\u001b[39;49m)\n\u001b[1;32m     15\u001b[0m result \u001b[39m=\u001b[39m  df\u001b[39m.\u001b[39mmean(axis\u001b[39m=\u001b[39m\u001b[39m0\u001b[39m)\n\u001b[1;32m     16\u001b[0m mse \u001b[39m=\u001b[39m result[\u001b[39m'\u001b[39m\u001b[39mmse\u001b[39m\u001b[39m'\u001b[39m]\n",
      "File \u001b[0;32m~/miniconda3/envs/ssl_ts/lib/python3.10/site-packages/pandas/core/reshape/concat.py:372\u001b[0m, in \u001b[0;36mconcat\u001b[0;34m(objs, axis, join, ignore_index, keys, levels, names, verify_integrity, sort, copy)\u001b[0m\n\u001b[1;32m    369\u001b[0m \u001b[39melif\u001b[39;00m copy \u001b[39mand\u001b[39;00m using_copy_on_write():\n\u001b[1;32m    370\u001b[0m     copy \u001b[39m=\u001b[39m \u001b[39mFalse\u001b[39;00m\n\u001b[0;32m--> 372\u001b[0m op \u001b[39m=\u001b[39m _Concatenator(\n\u001b[1;32m    373\u001b[0m     objs,\n\u001b[1;32m    374\u001b[0m     axis\u001b[39m=\u001b[39;49maxis,\n\u001b[1;32m    375\u001b[0m     ignore_index\u001b[39m=\u001b[39;49mignore_index,\n\u001b[1;32m    376\u001b[0m     join\u001b[39m=\u001b[39;49mjoin,\n\u001b[1;32m    377\u001b[0m     keys\u001b[39m=\u001b[39;49mkeys,\n\u001b[1;32m    378\u001b[0m     levels\u001b[39m=\u001b[39;49mlevels,\n\u001b[1;32m    379\u001b[0m     names\u001b[39m=\u001b[39;49mnames,\n\u001b[1;32m    380\u001b[0m     verify_integrity\u001b[39m=\u001b[39;49mverify_integrity,\n\u001b[1;32m    381\u001b[0m     copy\u001b[39m=\u001b[39;49mcopy,\n\u001b[1;32m    382\u001b[0m     sort\u001b[39m=\u001b[39;49msort,\n\u001b[1;32m    383\u001b[0m )\n\u001b[1;32m    385\u001b[0m \u001b[39mreturn\u001b[39;00m op\u001b[39m.\u001b[39mget_result()\n",
      "File \u001b[0;32m~/miniconda3/envs/ssl_ts/lib/python3.10/site-packages/pandas/core/reshape/concat.py:429\u001b[0m, in \u001b[0;36m_Concatenator.__init__\u001b[0;34m(self, objs, axis, join, keys, levels, names, ignore_index, verify_integrity, copy, sort)\u001b[0m\n\u001b[1;32m    426\u001b[0m     objs \u001b[39m=\u001b[39m \u001b[39mlist\u001b[39m(objs)\n\u001b[1;32m    428\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mlen\u001b[39m(objs) \u001b[39m==\u001b[39m \u001b[39m0\u001b[39m:\n\u001b[0;32m--> 429\u001b[0m     \u001b[39mraise\u001b[39;00m \u001b[39mValueError\u001b[39;00m(\u001b[39m\"\u001b[39m\u001b[39mNo objects to concatenate\u001b[39m\u001b[39m\"\u001b[39m)\n\u001b[1;32m    431\u001b[0m \u001b[39mif\u001b[39;00m keys \u001b[39mis\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m    432\u001b[0m     objs \u001b[39m=\u001b[39m \u001b[39mlist\u001b[39m(com\u001b[39m.\u001b[39mnot_none(\u001b[39m*\u001b[39mobjs))\n",
      "\u001b[0;31mValueError\u001b[0m: No objects to concatenate"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='O',patch_len=1)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='O',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='O',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='O',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='O',patch_len=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.433,mae=0.446\n",
      "4 --- ft=20: mse=0.432,mae=0.445\n",
      "4 --- ft=40: mse=0.429,mae=0.443\n",
      "4 --- ft=60: mse=0.433,mae=0.446\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",
      "4 --- ft=10: mse=0.435,mae=0.442\n",
      "4 --- ft=20: mse=0.433,mae=0.441\n",
      "4 --- ft=40: mse=0.433,mae=0.441\n",
      "4 --- ft=60: mse=0.433,mae=0.442\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.416,mae=0.433\n",
      "4 --- ft=20: mse=0.42,mae=0.436\n",
      "4 --- ft=40: mse=0.418,mae=0.434\n",
      "4 --- ft=60: mse=0.416,mae=0.433\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='X',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='X',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='X',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='etth1',input_='O',output_='X',patch_len=24)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ETTh2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.354,mae=0.394\n",
      "4 --- ft=20: mse=0.347,mae=0.392\n",
      "4 --- ft=40: mse=0.347,mae=0.39\n",
      "4 --- ft=60: mse=0.348,mae=0.39\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.342,mae=0.388\n",
      "4 --- ft=20: mse=0.346,mae=0.391\n",
      "4 --- ft=40: mse=0.348,mae=0.393\n",
      "4 --- ft=60: mse=0.342,mae=0.387\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.361,mae=0.404\n",
      "4 --- ft=20: mse=0.346,mae=0.392\n",
      "4 --- ft=40: mse=0.347,mae=0.396\n",
      "4 --- ft=60: mse=0.343,mae=0.39\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.337,mae=0.389\n",
      "4 --- ft=20: mse=0.338,mae=0.389\n",
      "4 --- ft=40: mse=0.34,mae=0.39\n",
      "4 --- ft=60: mse=0.344,mae=0.392\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='O',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='O',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='O',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='O',patch_len=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.379,mae=0.415\n",
      "4 --- ft=20: mse=0.364,mae=0.404\n",
      "4 --- ft=40: mse=0.362,mae=0.402\n",
      "3 --- ft=60: mse=0.358,mae=0.399\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.35,mae=0.393\n",
      "4 --- ft=20: mse=0.352,mae=0.393\n",
      "4 --- ft=40: mse=0.351,mae=0.391\n",
      "4 --- ft=60: mse=0.353,mae=0.394\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.362,mae=0.399\n",
      "4 --- ft=20: mse=0.354,mae=0.394\n",
      "3 --- ft=40: mse=0.403,mae=0.422\n",
      "4 --- ft=60: mse=0.357,mae=0.397\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.395\n",
      "4 --- ft=20: mse=0.348,mae=0.388\n",
      "4 --- ft=40: mse=0.349,mae=0.39\n",
      "4 --- ft=60: mse=0.347,mae=0.388\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='X',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='X',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='X',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='etth2',input_='O',output_='X',patch_len=24)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ETTm1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.35,mae=0.382\n",
      "3 --- ft=20: mse=0.33,mae=0.371\n",
      "4 --- ft=40: mse=0.346,mae=0.383\n",
      "4 --- ft=60: mse=0.347,mae=0.381\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.35,mae=0.387\n",
      "4 --- ft=20: mse=0.351,mae=0.387\n",
      "4 --- ft=40: mse=0.35,mae=0.387\n",
      "4 --- ft=60: mse=0.349,mae=0.386\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.364,mae=0.389\n",
      "4 --- ft=20: mse=0.365,mae=0.391\n",
      "4 --- ft=40: mse=0.365,mae=0.387\n",
      "4 --- ft=60: mse=0.365,mae=0.387\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.354,mae=0.388\n",
      "4 --- ft=20: mse=0.354,mae=0.385\n",
      "4 --- ft=40: mse=0.353,mae=0.384\n",
      "4 --- ft=60: mse=0.353,mae=0.384\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='O',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='O',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='O',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='O',patch_len=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.345,mae=0.381\n",
      "2 --- ft=20: mse=0.329,mae=0.371\n",
      "4 --- ft=40: mse=0.349,mae=0.385\n",
      "3 --- ft=60: mse=0.347,mae=0.381\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.35,mae=0.389\n",
      "4 --- ft=20: mse=0.348,mae=0.385\n",
      "4 --- ft=40: mse=0.35,mae=0.386\n",
      "4 --- ft=60: mse=0.349,mae=0.388\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.343,mae=0.378\n",
      "4 --- ft=20: mse=0.341,mae=0.378\n",
      "3 --- ft=40: mse=0.321,mae=0.365\n",
      "3 --- ft=60: mse=0.32,mae=0.364\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.346,mae=0.382\n",
      "4 --- ft=20: mse=0.345,mae=0.381\n",
      "4 --- ft=40: mse=0.345,mae=0.38\n",
      "4 --- ft=60: mse=0.343,mae=0.38\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='X',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='X',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='X',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='ettm1',input_='O',output_='X',patch_len=24)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ETTm2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.255,mae=0.317\n",
      "4 --- ft=20: mse=0.256,mae=0.318\n",
      "3 --- ft=40: mse=0.284,mae=0.337\n",
      "4 --- ft=60: mse=0.255,mae=0.318\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.257,mae=0.32\n",
      "3 --- ft=20: mse=0.269,mae=0.327\n",
      "4 --- ft=40: mse=0.256,mae=0.318\n",
      "4 --- ft=60: mse=0.255,mae=0.318\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.257,mae=0.319\n",
      "4 --- ft=20: mse=0.257,mae=0.319\n",
      "4 --- ft=40: mse=0.256,mae=0.318\n",
      "4 --- ft=60: mse=0.257,mae=0.318\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.269,mae=0.328\n",
      "4 --- ft=20: mse=0.261,mae=0.321\n",
      "4 --- ft=40: mse=0.261,mae=0.323\n",
      "4 --- ft=60: mse=0.258,mae=0.32\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='O',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='O',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='O',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='O',patch_len=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3 --- ft=10: mse=0.271,mae=0.327\n",
      "4 --- ft=20: mse=0.279,mae=0.332\n",
      "2 --- ft=40: mse=0.207,mae=0.285\n",
      "4 --- ft=60: mse=0.27,mae=0.328\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.271,mae=0.329\n",
      "4 --- ft=20: mse=0.273,mae=0.33\n",
      "4 --- ft=40: mse=0.274,mae=0.331\n",
      "4 --- ft=60: mse=0.275,mae=0.331\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.263,mae=0.325\n",
      "4 --- ft=20: mse=0.264,mae=0.325\n",
      "3 --- ft=40: mse=0.229,mae=0.302\n",
      "3 --- ft=60: mse=0.228,mae=0.302\n",
      "==================================================\n",
      "3 --- ft=10: mse=0.274,mae=0.329\n",
      "4 --- ft=20: mse=0.263,mae=0.321\n",
      "3 --- ft=40: mse=0.228,mae=0.298\n",
      "4 --- ft=60: mse=0.262,mae=0.32\n",
      "==================================================\n"
     ]
    }
   ],
   "source": [
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='X',patch_len=6)\n",
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='X',patch_len=12)\n",
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='X',patch_len=18)\n",
    "Transformer_data_input_output_patchlen(data='ettm2',input_='O',output_='X',patch_len=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "import numpy as np\n",
    "\n",
    "# Sample data\n",
    "x = [1, 2, 3, 4, 5]\n",
    "y = [2, 4, 1, 3, 6]\n",
    "\n",
    "# Create a figure and axis\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "# Define a list of colors and line styles\n",
    "colors = ['red', 'blue', 'green']\n",
    "line_styles = ['-', '--', ':']\n",
    "\n",
    "# Initialize legends for color and line style\n",
    "color_legend_handles = []\n",
    "line_style_legend_handles = []\n",
    "\n",
    "# Plot the lines with different colors and line styles based on criteria\n",
    "for i, color in enumerate(colors):\n",
    "    for j, line_style in enumerate(line_styles):\n",
    "        line_label = f'Line {i * len(line_styles) + j + 1}'\n",
    "        line, = ax.plot(x, np.array(y)*(i+2*j), label=line_label, color=color, linestyle=line_style)\n",
    "\n",
    "        # Add line handles for color and line style legends\n",
    "        if i == 0:\n",
    "            line_style_legend_handles.append(Line2D([0], [0], color='black', linestyle=line_style, label=f'Line Style {j + 1}'))\n",
    "        if j == 0:\n",
    "            color_legend_handles.append(Line2D([0], [0], color=color, linestyle='-', label=f'Color {i + 1}'))\n",
    "\n",
    "# Create legends for color and line style\n",
    "color_legend = plt.legend(handles=color_legend_handles, loc='upper left', title='Legend by Color')\n",
    "line_style_legend = plt.legend(handles=line_style_legend_handles, loc='lower left', title='Legend by Line Style')\n",
    "\n",
    "# Add both legends to the plot\n",
    "ax.add_artist(color_legend)\n",
    "ax.add_artist(line_style_legend)\n",
    "\n",
    "# Add labels and title\n",
    "ax.set_xlabel('X-axis')\n",
    "ax.set_ylabel('Y-axis')\n",
    "ax.set_title('Line Plot with Different Colors and Line Styles')\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "etth1_mlp_OO_with_CL = [0.402,0.401,0.402,0.403]\n",
    "etth2_mlp_OO_with_CL = [0.335, 0.334,0.336,0.335]\n",
    "ettm1_mlp_OO_with_CL = [0.342,0.342,0.342,0.342]\n",
    "ettm2_mlp_OO_with_CL = [0.244,0.244,0.244,0.244]\n",
    "\n",
    "etth1_mlp_OO_without_CL = [0.412,0.407,0.408,0.407]\n",
    "etth2_mlp_OO_without_CL = [0.336,0.336,0.335,0.336]\n",
    "ettm1_mlp_OO_without_CL = [0.356,0.356,0.354,0.352]\n",
    "ettm2_mlp_OO_without_CL = [0.243,0.243,0.243,0.243]\n",
    "#################################################################################\n",
    "etth1_trans_OO_with_CL = [0.419, 0.423, 0.420, 0.425]\n",
    "etth2_trans_OO_with_CL = []\n",
    "ettm1_trans_OO_with_CL = []\n",
    "ettm2_trans_OO_with_CL = []\n",
    "\n",
    "etth1_trans_OO_without_CL = [0.407, 0.413, 0.410, 0.415]\n",
    "etth2_trans_OO_without_CL = [9999, 0.342, 0.346, 0.337]\n",
    "ettm1_trans_OO_without_CL = [0.346, 0.349, 0.365, 0.353]\n",
    "ettm2_trans_OO_without_CL = [0.255, 0.255, 999, 999]\n",
    "#################################################################################\n",
    "etth1_trans_OX_with_CL = [0.421, 0.430, 0.428, 0.436]\n",
    "etth2_trans_OX_with_CL = []\n",
    "ettm1_trans_OX_with_CL = []\n",
    "ettm2_trans_OX_with_CL = []\n",
    "\n",
    "etth1_trans_OX_without_CL = [0.429, 0.422, 0.433, 0.416]\n",
    "etth2_trans_OX_without_CL = [0.362, 0.350, 0.354, 0.347]\n",
    "ettm1_trans_OX_without_CL = [0.345, 0.348, 0.341, 0.343]\n",
    "ettm2_trans_OX_without_CL = [0.270, 0.271, 0.263, 0.262]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "PI_etth1 = [0.412,0.413,0.409,0.408,0.407,0.407,0.407,0.406]\n",
    "PD_etth1 = [0.423,0.421,0.420,0.420,0.422,0.419,0.420,0.418]\n",
    "\n",
    "PI_etth2 = [0.339,0.337,0.338,0.335,0.334,0.335,0.335,0.333]\n",
    "PD_etth2 = [0.355,0.355,0.359,0.359,0.357,0.356,0.359,0.358]\n",
    "\n",
    "#PI_ettm2 = [0.253,0.253,0.253,0.253,0.253,0.253,xxx,xxx]\n",
    "#PD_ettm2 = [0.261,0.257,0.258,0.254,0.255,0.256,xxx,xxx]\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.plot([1,2,4,8,12,16,24,32],PI_etth1,label='Patch Independence')\n",
    "plt.plot([1,2,4,8,12,16,24,32],PD_etth1,label='Patch Dependence')\n",
    "custom_xticks = [1,2,4,8,12,16,24,32]\n",
    "custom_yticks = [0.405,0.410,0.415,0.420,0.425]\n",
    "plt.suptitle(\"[ETTh1] Performance by Patch Length\",size=20,y=1.025)\n",
    "plt.title(\"( Avg. MSE over 4 horizons )\",size=15,pad=10)\n",
    "plt.xticks(custom_xticks)\n",
    "plt.yticks(custom_yticks)\n",
    "plt.legend()\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "plt.plot([1,2,4,8,12,16,24,32],PI_etth2,label='Patch Independence')\n",
    "plt.plot([1,2,4,8,12,16,24,32],PD_etth2,label='Patch Dependence')\n",
    "custom_xticks = [1,2,4,8,12,16,24,32]\n",
    "custom_yticks = [0.335,0.340,0.345,0.350,0.355,0.360]\n",
    "plt.suptitle(\"[ETTh2] Performance by Patch Length\",size=20,y=1.025)\n",
    "plt.title(\"( Avg. MSE over 4 horizons )\",size=15,pad=10)\n",
    "plt.xticks(custom_xticks)\n",
    "plt.yticks(custom_yticks)\n",
    "plt.legend()\n",
    "\n",
    "\n"
   ]
  }
 ],
 "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
}
