{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 1. Predict UNMASKED"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## (1) patch len 12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim_half_v3_mean_R/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain150_mask0.5_model1_no_permute'\n",
    "os.chdir(PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.376443 0.401322\n",
      "0.423505 0.42566\n",
      "0.452322 0.467532\n",
      "0.43754 0.439511\n",
      "0.434\n",
      "0.422\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results20:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## (2) patch len 18"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim_half_v3_mean_R/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch18_stride18_epochs-pretrain100_mask0.5_model1_no_permute'\n",
    "os.chdir(PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.37737 0.40171\n",
      "0.402\n",
      "0.377\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results10:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.380254 0.402408\n",
      "0.402\n",
      "0.38\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results20:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "nan\n",
      "nan\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/seunghan9613/miniconda3/envs/ssl_ts/lib/python3.10/site-packages/numpy/core/fromnumeric.py:3432: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/seunghan9613/miniconda3/envs/ssl_ts/lib/python3.10/site-packages/numpy/core/_methods.py:190: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results40:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results60:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Predict MASKED"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## (1) patch len 12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim_half_v3_mean/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_no_permute'\n",
    "os.chdir(PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.385479 0.408127\n",
      "0.478794 0.483276\n",
      "0.432411 0.442319\n",
      "0.419046 0.428181\n",
      "0.44\n",
      "0.429\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results40:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## (2) patch len 18"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim_half_v3_mean/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch18_stride18_epochs-pretrain100_mask0.5_model1_no_permute'\n",
    "os.chdir(PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.384366 0.407924\n",
      "0.408\n",
      "0.384\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results10:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.391815 0.408082\n",
      "0.408\n",
      "0.392\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results20:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.383974 0.404265\n",
      "0.404\n",
      "0.384\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results40:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "nan\n",
      "nan\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/seunghan9613/miniconda3/envs/ssl_ts/lib/python3.10/site-packages/numpy/core/fromnumeric.py:3432: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/seunghan9613/miniconda3/envs/ssl_ts/lib/python3.10/site-packages/numpy/core/_methods.py:190: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    }
   ],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "#results40 = [x for x in results if 'ep40_model' in x]\n",
    "results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results60:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 3. Predict BOTH"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## (1) patch len 12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim_half_v3_mean_Y_both/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch12_stride12_epochs-pretrain100_mask0.5_model1_no_permute'\n",
    "os.chdir(PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results40:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## (2) patch len 18"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = '/home/seunghan9613/PatchTST_sim/PatchTST_self_supervised/saved_models/etth12etth1/masked_patchtst_sim_half_v3_mean_Y_both/based_model/max/patchtst_sim_pretrained_H16_D128_F512_cw512_patch18_stride18_epochs-pretrain100_mask0.5_model1_no_permute'\n",
    "os.chdir(PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "results = [x for x in os.listdir() if 'load_ep100' in x]\n",
    "results = [x for x in results if 'acc.csv' in x]\n",
    "#results10 = [x for x in results if 'ep10_model' in x]\n",
    "#results20 = [x for x in results if 'ep20_model' in x]\n",
    "results40 = [x for x in results if 'ep40_model' in x]\n",
    "#results60 = [x for x in results if 'ep60_model' in x]\n",
    "\n",
    "mse_list = []\n",
    "mae_list = []\n",
    "for i in results40:\n",
    "    mse = pd.read_csv(i).values[0][0]\n",
    "    mae = pd.read_csv(i).values[0][1]\n",
    "    mse_list.append(mse)\n",
    "    mae_list.append(mae)\n",
    "    print(mse,mae)\n",
    "print(np.mean(mae_list).round(3))\n",
    "print(np.mean(mse_list).round(3))\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
}
