{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "currentdir = os.path.dirname(os.path.abspath(\"__file__\"))\n",
    "parentdir = os.path.dirname(currentdir)\n",
    "sys.path.append(parentdir)\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 dataloader.TSC_data_loader import TSC_data_loader\n",
    "from classifiers.FCN_Kernel_size import FCN as Torch_FCN\n",
    "\n",
    "\n",
    "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",
    "\"ECG200\",\n",
    "\"FiftyWords\",\n",
    "]\n",
    "\n",
    "dataset_name_list = dataset_name_list\n",
    "print(dataset_name_list)\n",
    "\n",
    "dataset_path = dirname(parentdir+\"./Example_Datasets/UCRArchive_2018/\")\n",
    "archive_name = 'UCRArchive_2018'\n",
    "\n",
    "RF_size_list = [50, 100, 150, 200]\n",
    "\n",
    "for RF_size in RF_size_list:\n",
    "    father_folder = './FCN_Result_kernel_size_'+str(RF_size)+'/'\n",
    "    \n",
    "    for dataset_name in dataset_name_list:\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:0\" 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",
    "        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(2000):\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",
    "        torch_FCN.eval()\n",
    "        acc_test = eval_model(torch_FCN, test_loader)\n",
    "        sentence = str(acc_test)\n",
    "        save_to_log(sentence, dataset_name,father_folder)\n",
    "\n",
    "        torch.cuda.empty_cache()\n",
    "        print(dataset_name,acc_test)\n"
   ]
  }
 ],
 "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
