{
 "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 tsmixer_version(data,input_,output_,version):\n",
    "    print('==================================================')\n",
    "    print(f'version = {version}')\n",
    "    print('==================================================')\n",
    "    patch_len = 12\n",
    "    if version==1:\n",
    "        PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_FC2mixer_{input_}_{output_}/based_model/max'\n",
    "    else:\n",
    "        PATH = f'/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/{data}2{data}/XY_ablation_FC2mixer_v{version}_{input_}_{output_}/based_model/max'\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": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "version = 1\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.419,mae=0.435\n",
      "4 --- ft=20: mse=0.42,mae=0.437\n",
      "4 --- ft=40: mse=0.425,mae=0.44\n",
      "4 --- ft=60: mse=0.419,mae=0.436\n",
      "==================================================\n",
      "version = 2\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.421,mae=0.436\n",
      "4 --- ft=20: mse=0.419,mae=0.435\n",
      "4 --- ft=40: mse=0.421,mae=0.437\n",
      "4 --- ft=60: mse=0.423,mae=0.438\n",
      "================================================================================\n",
      "==================================================\n",
      "version = 1\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.408,mae=0.423\n",
      "4 --- ft=20: mse=0.409,mae=0.423\n",
      "4 --- ft=40: mse=0.409,mae=0.424\n",
      "4 --- ft=60: mse=0.411,mae=0.425\n",
      "==================================================\n",
      "version = 2\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.412,mae=0.425\n",
      "4 --- ft=60: mse=0.414,mae=0.427\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'etth1'\n",
    "for version in [1,2]:\n",
    "    tsmixer_version(data=DATA,input_='O',output_='X',version=version)\n",
    "print('='*80)    \n",
    "for version in [1,2]:\n",
    "    tsmixer_version(data=DATA,input_='O',output_='O',version=version)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "version = 1\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.381,mae=0.411\n",
      "4 --- ft=20: mse=0.38,mae=0.408\n",
      "4 --- ft=40: mse=0.375,mae=0.406\n",
      "4 --- ft=60: mse=0.379,mae=0.408\n",
      "==================================================\n",
      "version = 2\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.365,mae=0.4\n",
      "4 --- ft=20: mse=0.358,mae=0.397\n",
      "4 --- ft=40: mse=0.352,mae=0.395\n",
      "4 --- ft=60: mse=0.362,mae=0.399\n",
      "================================================================================\n",
      "==================================================\n",
      "version = 1\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.333,mae=0.383\n",
      "4 --- ft=20: mse=0.34,mae=0.387\n",
      "4 --- ft=40: mse=0.336,mae=0.385\n",
      "4 --- ft=60: mse=0.339,mae=0.387\n",
      "==================================================\n",
      "version = 2\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.343,mae=0.39\n",
      "4 --- ft=20: mse=0.348,mae=0.392\n",
      "4 --- ft=40: mse=0.341,mae=0.387\n",
      "4 --- ft=60: mse=0.351,mae=0.395\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'etth2'\n",
    "for version in [1,2]:\n",
    "    tsmixer_version(data=DATA,input_='O',output_='X',version=version)\n",
    "print('='*80)    \n",
    "for version in [1,2]:\n",
    "    tsmixer_version(data=DATA,input_='O',output_='O',version=version)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.042492917847025496"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "15/353"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==================================================\n",
      "version = 1\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.349,mae=0.385\n",
      "4 --- ft=20: mse=0.349,mae=0.385\n",
      "4 --- ft=40: mse=0.351,mae=0.386\n",
      "4 --- ft=60: mse=0.351,mae=0.386\n",
      "==================================================\n",
      "version = 2\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.35,mae=0.382\n",
      "4 --- ft=20: mse=0.351,mae=0.383\n",
      "4 --- ft=40: mse=0.351,mae=0.385\n",
      "4 --- ft=60: mse=0.351,mae=0.383\n",
      "================================================================================\n",
      "==================================================\n",
      "version = 1\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.356,mae=0.38\n",
      "4 --- ft=20: mse=0.355,mae=0.382\n",
      "4 --- ft=40: mse=0.353,mae=0.383\n",
      "4 --- ft=60: mse=0.353,mae=0.383\n",
      "==================================================\n",
      "version = 2\n",
      "==================================================\n",
      "4 --- ft=10: mse=0.353,mae=0.376\n",
      "3 --- ft=20: mse=0.35,mae=0.378\n",
      "4 --- ft=40: mse=0.355,mae=0.382\n",
      "4 --- ft=60: mse=0.358,mae=0.385\n"
     ]
    }
   ],
   "source": [
    "# 기준 : max 40 epoch\n",
    "DATA = 'ettm1'\n",
    "for version in [1,2]:\n",
    "    tsmixer_version(data=DATA,input_='O',output_='X',version=version)\n",
    "print('='*80)    \n",
    "for version in [1,2]:\n",
    "    tsmixer_version(data=DATA,input_='O',output_='O',version=version)"
   ]
  },
  {
   "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
}
