{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fc3(data,input_,output_):\n",
    "    patch_len = 12\n",
    "    PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_FC3_{input_}_{output_}/based_model/max'\n",
    "    \n",
    "        \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",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.257,mae=0.319\n",
      "4 --- ft=20: mse=0.257,mae=0.32\n",
      "4 --- ft=40: mse=0.256,mae=0.318\n",
      "4 --- ft=60: mse=0.257,mae=0.32\n",
      "================================================================================\n",
      "4 --- ft=10: mse=0.253,mae=0.314\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.313\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'ettm2'\n",
    "fc3(data=DATA,input_='O',output_='X')\n",
    "print('='*80)    \n",
    "fc3(data=DATA,input_='O',output_='O')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.361,mae=0.402\n",
      "4 --- ft=20: mse=0.36,mae=0.401\n",
      "4 --- ft=40: mse=0.37,mae=0.409\n",
      "4 --- ft=60: mse=0.358,mae=0.4\n",
      "================================================================================\n",
      "4 --- ft=10: mse=0.342,mae=0.389\n",
      "4 --- ft=20: mse=0.349,mae=0.394\n",
      "4 --- ft=40: mse=0.341,mae=0.387\n",
      "4 --- ft=60: mse=0.345,mae=0.391\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'etth2'\n",
    "fc3(data=DATA,input_='O',output_='X')\n",
    "print('='*80)    \n",
    "fc3(data=DATA,input_='O',output_='O')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.356,mae=0.384\n",
      "4 --- ft=20: mse=0.352,mae=0.386\n",
      "4 --- ft=40: mse=0.353,mae=0.383\n",
      "4 --- ft=60: mse=0.352,mae=0.385\n",
      "================================================================================\n",
      "4 --- ft=10: mse=0.359,mae=0.381\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.357,mae=0.384\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'ettm1'\n",
    "fc3(data=DATA,input_='O',output_='X')\n",
    "print('='*80)    \n",
    "fc3(data=DATA,input_='O',output_='O')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 --- ft=10: mse=0.257,mae=0.319\n",
      "4 --- ft=20: mse=0.257,mae=0.32\n",
      "4 --- ft=40: mse=0.256,mae=0.318\n",
      "4 --- ft=60: mse=0.257,mae=0.32\n",
      "================================================================================\n",
      "4 --- ft=10: mse=0.257,mae=0.317\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.256,mae=0.315\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'ettm2'\n",
    "fc3(data=DATA,input_='O',output_='X')\n",
    "print('='*80)    \n",
    "fc3(data=DATA,input_='O',output_='O')"
   ]
  },
  {
   "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
}
