{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test dataset: FiftyWords\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "from os.path import dirname\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import numpy as np\n",
    "import torch.optim as optim\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.OS_CNN.OS_CNN_Structure_build import generate_layer_parameter_list\n",
    "from Classifiers.OS_CNN.log_manager import eval_condition, eval_model, save_to_log\n",
    "from Classifiers.OS_CNN.OS_CNN import OS_CNN\n",
    "\n",
    "\n",
    "# model saved in result log folder\n",
    "Result_log_folder = './Example_Results_of_OS_CNN/OS_CNN_result_iter_0/'\n",
    "dataset_path = dirname(\"./Example_Datasets/UCRArchive_2018/\")\n",
    "dataset_name = 'FiftyWords'\n",
    "\n",
    "#batch_size for test\n",
    "batch_size = 16\n",
    "print('test dataset:', dataset_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "code is running on:  cuda:0\n",
      "the size of inpute dataset is: 270\n",
      "number of class is: tensor(50, device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "# load data\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",
    "print('code is running on: ',device)    \n",
    "    \n",
    "# put data to GPU\n",
    "X_train = torch.from_numpy(X_train)\n",
    "X_train.requires_grad = False\n",
    "X_train = X_train.to(device)\n",
    "X_train = X_train.unsqueeze_(1)\n",
    "y_train = torch.from_numpy(y_train).to(device)\n",
    "\n",
    "X_test = torch.from_numpy(X_test)\n",
    "X_test.requires_grad = False\n",
    "X_test = X_test.to(device)\n",
    "X_test = X_test.unsqueeze_(1)\n",
    "y_test = torch.from_numpy(y_test).to(device)\n",
    "input_shape = X_train.shape[-1]\n",
    "n_class = max(y_train) + 1\n",
    "print('the size of inpute dataset is:',input_shape)\n",
    "print('number of class is:',n_class)\n",
    "    \n",
    "    \n",
    "#build dataloader\n",
    "train_dataset = TensorDataset(X_train, y_train)\n",
    "train_loader = DataLoader(train_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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "the shape of inpute data is: torch.Size([450, 1, 270])\n",
      "the max size of kernel is: 67\n",
      "the Network structure for FiftyWords is:\n",
      "[[(1, 1, 1), (1, 1, 2), (1, 1, 3), (1, 1, 5), (1, 1, 7), (1, 1, 11), (1, 1, 13), (1, 1, 17), (1, 1, 19), (1, 1, 23), (1, 1, 29), (1, 1, 31), (1, 1, 37), (1, 1, 41), (1, 1, 43), (1, 1, 47), (1, 1, 53), (1, 1, 59), (1, 1, 61), (1, 1, 67)], [(20, 20, 1), (20, 20, 2), (20, 20, 3), (20, 20, 5), (20, 20, 7), (20, 20, 11), (20, 20, 13), (20, 20, 17), (20, 20, 19), (20, 20, 23), (20, 20, 29), (20, 20, 31), (20, 20, 37), (20, 20, 41), (20, 20, 43), (20, 20, 47), (20, 20, 53), (20, 20, 59), (20, 20, 61), (20, 20, 67)], [(400, 20, 1), (400, 20, 2)]]\n"
     ]
    }
   ],
   "source": [
    "#net parameter\n",
    "paramenter_number_of_layer_list = [8*128, 5*128*256 + 2*256*128] \n",
    "Max_kernel_size = 89\n",
    "\n",
    "# calcualte network structure\n",
    "receptive_field_shape= min(int(X_train.shape[-1]/4),Max_kernel_size)\n",
    "print('the shape of inpute data is:',X_train.shape)\n",
    "print('the max size of kernel is:', receptive_field_shape)\n",
    "layer_parameter_list = generate_layer_parameter_list(1,receptive_field_shape,paramenter_number_of_layer_list)\n",
    "print('the Network structure for',dataset_name,'is:')\n",
    "print(layer_parameter_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "Error(s) in loading state_dict for OS_CNN:\n\tsize mismatch for net.1.weight_mask: copying a param with shape torch.Size([160, 20, 67]) from checkpoint, the shape in current model is torch.Size([400, 20, 67]).\n\tsize mismatch for net.1.conv1d.weight: copying a param with shape torch.Size([160, 20, 67]) from checkpoint, the shape in current model is torch.Size([400, 20, 67]).\n\tsize mismatch for net.1.conv1d.bias: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.weight: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.bias: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.running_mean: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.running_var: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.2.weight_mask: copying a param with shape torch.Size([40, 160, 2]) from checkpoint, the shape in current model is torch.Size([40, 400, 2]).\n\tsize mismatch for net.2.conv1d.weight: copying a param with shape torch.Size([40, 160, 2]) from checkpoint, the shape in current model is torch.Size([40, 400, 2]).",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-4-04d83c84d183>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;31m# build os-cnn net and load weight\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mtorch_FCN\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mOS_CNN\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlayer_parameter_list\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mn_class\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 6\u001b[0;31m \u001b[0mtorch_FCN\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload_state_dict\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbest_model_path\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmap_location\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      7\u001b[0m \u001b[0mtorch_FCN\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0meval\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/enter/envs/python38/lib/python3.8/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36mload_state_dict\u001b[0;34m(self, state_dict, strict)\u001b[0m\n\u001b[1;32m   1404\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1405\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0merror_msgs\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1406\u001b[0;31m             raise RuntimeError('Error(s) in loading state_dict for {}:\\n\\t{}'.format(\n\u001b[0m\u001b[1;32m   1407\u001b[0m                                self.__class__.__name__, \"\\n\\t\".join(error_msgs)))\n\u001b[1;32m   1408\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0m_IncompatibleKeys\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmissing_keys\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0munexpected_keys\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: Error(s) in loading state_dict for OS_CNN:\n\tsize mismatch for net.1.weight_mask: copying a param with shape torch.Size([160, 20, 67]) from checkpoint, the shape in current model is torch.Size([400, 20, 67]).\n\tsize mismatch for net.1.conv1d.weight: copying a param with shape torch.Size([160, 20, 67]) from checkpoint, the shape in current model is torch.Size([400, 20, 67]).\n\tsize mismatch for net.1.conv1d.bias: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.weight: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.bias: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.running_mean: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.1.bn.running_var: copying a param with shape torch.Size([160]) from checkpoint, the shape in current model is torch.Size([400]).\n\tsize mismatch for net.2.weight_mask: copying a param with shape torch.Size([40, 160, 2]) from checkpoint, the shape in current model is torch.Size([40, 400, 2]).\n\tsize mismatch for net.2.conv1d.weight: copying a param with shape torch.Size([40, 160, 2]) from checkpoint, the shape in current model is torch.Size([40, 400, 2])."
     ]
    }
   ],
   "source": [
    "# find model path\n",
    "best_model_path = Result_log_folder +dataset_name+'/'+dataset_name+'Best_model'\n",
    "\n",
    "# build os-cnn net and load weight\n",
    "torch_FCN = OS_CNN(layer_parameter_list, n_class.item(), False).to(device)\n",
    "torch_FCN.load_state_dict(torch.load(best_model_path, map_location=device))\n",
    "torch_FCN.eval()\n",
    "\n",
    "acc_test = eval_model(torch_FCN, test_loader)\n",
    " \n",
    "sentence = str(acc_test)\n",
    "torch.cuda.empty_cache()\n",
    "print(dataset_name,'test acc = ', acc_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": 2
}
