{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f2999b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.chdir(\"..\")\n",
    "import os\n",
    "import sys\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from os.path import dirname\n",
    "import numpy as np\n",
    "import torch.optim as optim\n",
    "from sklearn.metrics import accuracy_score\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data import TensorDataset\n",
    "from utils.dataloader.TSC_data_loader import TSC_data_loader\n",
    "from Classifiers.FCN_Kernel_size import FCN as Torch_FCN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2a2e93ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "def eval_condition(iepoch):\n",
    "    if (iepoch + 1) % 500 == 0:\n",
    "        return True\n",
    "    else:\n",
    "        return False\n",
    "\n",
    "\n",
    "def eval_model(model, dataloader):\n",
    "    predict_list = np.array([])\n",
    "    label_list = np.array([])\n",
    "    for sample in dataloader:\n",
    "        y_predict = model(sample[0])\n",
    "        y_predict = y_predict.detach().cpu().numpy()\n",
    "        y_predict = np.argmax(y_predict, axis=1)\n",
    "        predict_list = np.concatenate((predict_list, y_predict), axis=0)\n",
    "        label_list = np.concatenate((label_list, sample[1].detach().cpu().numpy()), axis=0)\n",
    "    acc = accuracy_score(predict_list, label_list)\n",
    "    return acc\n",
    "\n",
    "\n",
    "def save_to_log(sentence, dataset_name,father_folder):\n",
    "    father_path = father_folder + dataset_name\n",
    "    if not os.path.exists(father_path):\n",
    "        os.makedirs(father_path)\n",
    "    path = father_path + '/' + dataset_name + '_.txt'\n",
    "    print(path)\n",
    "    with open(path, \"a\") as myfile:\n",
    "        myfile.write(sentence + '\\n')\n",
    "\n",
    "        \n",
    "dataset_name_list = [\n",
    "'SmallKitchenAppliances',   \n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e97d3767",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SmallKitchenAppliances\n",
      "720 tensor(3, device='cuda:1')\n",
      "10\n",
      "499 0.13553602993488312 0.0001\n",
      "train_acc=\t 0.928 \t test_acc=\t 0.7813333333333333\n",
      "./FCN_Result_of_various_kernel_sizes_integer/SmallKitchenAppliances/SmallKitchenAppliances_.txt\n",
      "SmallKitchenAppliances 0.7813333333333333\n",
      "SmallKitchenAppliances\n",
      "720 tensor(3, device='cuda:1')\n",
      "200\n",
      "499 0.004603853914886713 0.000125\n",
      "train_acc=\t 0.9733333333333334 \t test_acc=\t 0.6693333333333333\n",
      "./FCN_Result_of_various_kernel_sizes_integer/SmallKitchenAppliances/SmallKitchenAppliances_.txt\n",
      "SmallKitchenAppliances 0.6693333333333333\n"
     ]
    }
   ],
   "source": [
    "dataset_path = dirname(\"./Example_Datasets/UCRArchive_2018/\")\n",
    "\n",
    "RF_size_list = [10, 200]\n",
    "# \n",
    "for dataset_name in dataset_name_list:\n",
    "    for RF_size in RF_size_list:\n",
    "        father_folder = './Ablation_study/FCN_Result_of_various_kernel_sizes_integer/'\n",
    "        print(dataset_name)\n",
    "        X_train, y_train, X_test, y_test = TSC_data_loader(dataset_path, dataset_name)\n",
    "        device = torch.device(\"cuda:1\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "        X_train = torch.from_numpy(X_train)\n",
    "        X_train.requires_grad = False\n",
    "        X_train = X_train.unsqueeze_(1).to(device)\n",
    "        y_train = torch.from_numpy(y_train).to(device)\n",
    "        X_test = torch.from_numpy(X_test)\n",
    "        X_test.requires_grad = False\n",
    "        X_test = X_test.unsqueeze_(1).to(device)\n",
    "        y_test = torch.from_numpy(y_test).to(device)\n",
    "\n",
    "        input_shape = X_train.shape[-1]\n",
    "        n_class = max(y_train) + 1\n",
    "        print(input_shape, n_class)\n",
    "        #max_RF_size = int(min(200,input_shape/2))\n",
    "        #RF_size = int(16+RF_size_ratio*(max_RF_size-16))\n",
    "        \n",
    "        print(RF_size)\n",
    "        torch_FCN = Torch_FCN(input_shape, n_class.item(), RF_size).to(device)\n",
    "\n",
    "        criterion = nn.CrossEntropyLoss()\n",
    "        optimizer = optim.Adam(torch_FCN.parameters(),weight_decay = 0.001)\n",
    "        scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, 'min', factor=0.5, patience=50, min_lr=0.0001)\n",
    "        torch_FCN.train()\n",
    "\n",
    "        dataset = TensorDataset(X_train, y_train)\n",
    "        batch_size = 16\n",
    "        loader = DataLoader(dataset, batch_size=int(min(X_train.shape[0] / 10, batch_size)), shuffle=True)\n",
    "\n",
    "        test_dataset = TensorDataset(X_test, y_test)\n",
    "        test_loader = DataLoader(test_dataset, batch_size=int(min(X_train.shape[0] / 10, batch_size)), shuffle=False)\n",
    "\n",
    "        for i in range(500):\n",
    "            for sample in loader:\n",
    "                optimizer.zero_grad()\n",
    "                y_predict = torch_FCN(sample[0])\n",
    "                output = criterion(y_predict, sample[1])\n",
    "                output.backward()\n",
    "                optimizer.step()\n",
    "            scheduler.step(output)\n",
    "\n",
    "            if eval_condition(i):\n",
    "                for param_group in optimizer.param_groups:\n",
    "                    print(i, output.item(), param_group['lr'])\n",
    "                torch_FCN.eval()\n",
    "                acc_train = eval_model(torch_FCN, loader)\n",
    "                acc_test = eval_model(torch_FCN, test_loader)\n",
    "                torch_FCN.train()\n",
    "                print('train_acc=\\t', acc_train, '\\t test_acc=\\t', acc_test)\n",
    "        \n",
    "        model_save_path = father_folder+'RF_size_'+dataset_name+'_'+str(RF_size)\n",
    "        torch.save(torch_FCN.state_dict(), model_save_path)\n",
    "        \n",
    "        torch_FCN.eval()\n",
    "        acc_test = eval_model(torch_FCN, test_loader)\n",
    "        sentence = str(RF_size)+'\\t'+str(acc_test)\n",
    "        save_to_log(sentence, dataset_name,father_folder)\n",
    "\n",
    "        torch.cuda.empty_cache()\n",
    "        print(dataset_name,acc_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1fe2d4e2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
