{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Using a handcrafted data to demonstrate Fixed kerenl size and Gloable average pooling will cause positional information loss.\n",
    "\n",
    "# The problem will cause a model cannot convergence \n",
    "\n",
    "# In here we use FCN to demonstrate this, but it is easy to expend to other similar structure."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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",
    "from utils.log_manager import eval_condition, eval_model\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.FCN import FCN as Torch_FCN\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# building a handcrafted data\n",
    "# the only difference between class1 and class2 is the relative position of sub-sequece"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# buidling hand craft datast\n",
    "def generate_signal(signal_size,lenght_per_cycle):\n",
    "    zhouqi_1 = signal_size/lenght_per_cycle;\n",
    "    x = np.asarray(range(signal_size));\n",
    "    X = (zhouqi_1*2*np.pi*x)/signal_size;\n",
    "    \n",
    "    signal = np.sin(X);\n",
    "    \n",
    "    return signal\n",
    "\n",
    "\n",
    "# give parameter of handcraft singal\n",
    "singal_length = 30\n",
    "length_of_sub_sequence_1 = singal_length\n",
    "length_of_sub_sequence_2 = singal_length\n",
    "distance_between_two_sub_sequence =70\n",
    "distance_to_edge= 30\n",
    "first_sub_squence_start_index = distance_to_edge\n",
    "second_sub_squence_start_index = distance_to_edge+distance_between_two_sub_sequence+singal_length\n",
    "total_length = distance_to_edge*distance_to_edge+singal_length*2+distance_between_two_sub_sequence\n",
    "\n",
    "# first sub-sequence  is square\n",
    "sub_sequence_1 = np.ones(length_of_sub_sequence_1)\n",
    "# second sub-sequence is sin\n",
    "sub_sequence_2 = generate_signal(length_of_sub_sequence_2,singal_length*2)\n",
    "\n",
    "\n",
    "singal_class_1 = np.zeros(distance_to_edge*2+length_of_sub_sequence_1+length_of_sub_sequence_2+distance_between_two_sub_sequence)\n",
    "singal_class_2 = np.zeros(distance_to_edge*2+length_of_sub_sequence_1+length_of_sub_sequence_2+distance_between_two_sub_sequence)\n",
    "\n",
    "singal_class_1[first_sub_squence_start_index:first_sub_squence_start_index+singal_length] = sub_sequence_1\n",
    "singal_class_1[second_sub_squence_start_index:second_sub_squence_start_index++singal_length] = sub_sequence_2\n",
    "\n",
    "singal_class_2[first_sub_squence_start_index:first_sub_squence_start_index+singal_length] = sub_sequence_2\n",
    "singal_class_2[second_sub_squence_start_index:second_sub_squence_start_index++singal_length] = sub_sequence_1\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(singal_class_1,label='class1')\n",
    "plt.plot(singal_class_2,label='class2')\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# a handCrafted data to dataset\n",
    "# you could set noise to the handcraft data by searching:\n",
    "# \"nosie_weight =\" the default is zero\n",
    "# number_of_each_class means the how many data a class has"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(32, 190)\n",
      "[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAD4CAYAAAD8Zh1EAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjAsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+17YcXAAAgAElEQVR4nO2de7hcdXnvP+/Mvl+Sfc2F7MAOCphASAiRVFFsRVugFSpoD4gKRyqtpyg9Xs5Dq8dS7GNLrT3VllOVgw+Vh0qhx3pSQWnrpT1HRQmCSAgJIQSyQ8hl37Lvt/mdP9b6zZ49e9bMmpk1a9aavJ/n2c/sWbNm1m/WzHznne/vfd+fGGNQFEVR4k+i2gNQFEVRgkEFXVEUpUZQQVcURakRVNAVRVFqBBV0RVGUGqGuWgfu6ekx/f391Tq8oihKLHniiSdOGGN6c91WNUHv7+9n165d1Tq8oihKLBGRl7xuU8tFURSlRlBBVxRFqRFU0BVFUWqEqnnoipKLubk5BgYGmJ6ervZQqkpTUxN9fX3U19dXeyhKjFBBVyLFwMAA7e3t9Pf3IyLVHk5VMMYwODjIwMAAGzZsqPZwlBhR0HIRka+KyDERecbjdhGRL4rIfhF5WkS2BT9M5VRhenqa7u7uU1bMAUSE7u7uU/5XilI8fjz0e4HL8tx+OXCW+3cz8LflD0s5lTmVxdyi50AphYKWizHmP0SkP88uVwFfM04f3sdEpENE1hpjjgQ0xprCGMO9PzrI8MRsRR4/kZpn0/Fv8WrbJk60nh3446/rbOY/vf70wB9XCRFjYNc9MHa0Ig+fMoY9r47R09bI6vbG4A/QvgZef1Pwj1sDBOGhrwMOZVwfcLctE3QRuRkniuf0009NUXh5aJI//udnAQg6COuXI3yx7q/ZnDjInEnyxYWr+ZuF3wSCOZBtnf8b559Ga+OpM/1y++2309bWxsc//vFAHu8DH/gA3/rWt1i1ahXPPJPTyaws40fh4Y+5V4J9E9rVFTa6/xgJ+ijuA2+8EtpyFkue0oT6qTTGfAX4CsD27dtPyZU15hacp/3X113AO7acFtwDGwP3/CqcGIHLv0z9vu/wsd0P8bH3vxvO/rVADvHV//cid3zrWeZTp+RLFxg33ngjt9xyC+9///urM4CFOefyqrvggvcG+tDv/V+P8fShUf77Ozbx2AuDfOPJw9z1nm38+vlrgznAE/fCP98KqflgHq/GCCIP/TCwPuN6n7tNyYFdISoRdHj+wvdg4Kfwtj+CLdfC1XdDxxnwgz9dDK3LJOEOudZXufra177G+eefz5YtW3jf+9635La7776b17/+9WzZsoVrrrmGyclJAB566CHOO+88tmzZwiWXXALA7t27ueiii9i6dSvnn38+zz//PACXXHIJXV1d4T6pTEzKuZRgy1B++uIQP9w/yK1vO4vf2r6ez717C6/pbeUL391HKqggwI7ZPgdlCUFE6DuBW0TkAWAHMKr+uTf2fZ0IUs+NgR/8Gazog61uxJWsh0s+Djs/DM//K5z9q2UfJuEOOqwA/Y//eTfPvnIy0MfcdNoK/ugd53revnv3bv7kT/6EH/3oR/T09DA0NMQXv/jF9O1XX301H/zgBwH41Kc+xT333MOHP/xh7rjjDh599FHWrVvHyMgIAF/60pe49dZbuf7665mdnWVhYSHQ51IyFRL0L3x3Hz1tjVy/4wwAkgnhI5eexa0PPMV3dr/KFZsDiNJV0PPiJ23x68CPgXNEZEBEbhKR3xWR33V3eQQ4AOwH7gb+S8VGWwOk3Og20CyGgV1OdP7m/wp1DYvbt1wHK0+HH/91IIexY07VcIT+ve99j3e/+9309PQALIukn3nmGd785jezefNm7r//fnbv3g3AxRdfzI033sjdd9+dFu43vOENfPazn+XOO+/kpZdeorm5Odwn40UFBH3PkZP8cP8gv3PJmTQ3JNPbf+P80zizt5W7/++BYA6kgp4XP1ku1xW43QC/F9iIapyFlLVcAnzQ574FiTrY/O6l25P1sPld8MMvwNQwNHeWdRg75sB+PhcgXyRdLW688Ua++c1vsmXLFu69915+8IMfAE40/pOf/ISHH36YCy+8kCeeeIL3vOc97Nixg4cffpgrrriCL3/5y7z1rW+t7hOAigj6v+w+igi8c9u6JduTCeGdW9fx+X/dx7GxaVa1N5V3oLSgR+TXTsTQXi4hY9KWS4CKvu9ROOON0LRy+W3nXO68+fd/t+zDJCRcy6UavPWtb+Whhx5icHAQgKGhoSW3j42NsXbtWubm5rj//vvT21944QV27NjBHXfcQW9vL4cOHeLAgQOceeaZfOQjH+Gqq67i6aefDvW5eJIW9ODeg9977ihb13fQ07Y8TfHSjasB+P5zx8o/UFrQa/hNWAYq6CFj7YpEUGd++CAc3wNnX5779nUXQksP7P122YdKR+g1/GE699xz+eQnP8lb3vIWtmzZwkc/+tElt3/mM59hx44dXHzxxbzuda9Lb//EJz7B5s2bOe+883jjG9/Ili1bePDBBznvvPPYunUrzzzzTDqr5brrruMNb3gDe/fupa+vj3vuuSfU5xh0hH7s5DQ/Hxjlba5wZ7NxbTunrWzi3/YEKehqueTi1EkmjgiBe+h7v+NcnuNRzJtIOmmLz33LSVdLlt7s6VTw0AFuuOEGbrjhhpy3fehDH+JDH/rQsu3f+MY3lm277bbbuO2225Zt//rXv17+IMshYEH/nht5X7pxVc7bRYRLN67mH58YYHpugab6ZM79fGE/NyroOdEIPWRSQVsu+74DPWdD15ne+5z9azA9Ci8/Vtah7JhrXM9rn4AF/bvPHWNdRzPnrG733OetG1cxNbfAj18YLO9gGqHnRQU9ZBbz0AN4sIV5OPRTOPOX8++34S3OZdmC7lzWeoRe8wQo6MYYHj84xMWvzd9Q7Q1ndlOXEB4/OOS5jy9U0POigh4ygUbox/fA3AT0XZR/v+YO6DkHBh4v63CnwqToKUGAgn5wcJKRyTm2nZ4/g6qpPsnGtSt48uWR8g6ogp4XFfSQWfTQA3gwK9B92wvv2/d6OLyrLL9ENEKvDQIU9CdfHgbgggKC7uzTwdMDI+nU3ZJQQc+LCnrIpIIs/R94Alq6obO/8L59F8LkIAy/WPLhkgnroaugxxr7+gUg6E8dGqG1IclrV7UV3Hfr+g4mZhd4/thY6QcUd0JVBT0nKughYz9LySBM9IHHncjbz5dD3+vd+zxR8uHUcqkRAo3QR9iyvsPX+9lG8U+VY7tohJ4XFfSQSQU1KTo1Aif2wjofdgtA70aobynLRz9VJ0Vvv/12/uIv/iKQxzp06BC/8iu/wqZNmzj33HP5whe+EMjjFkVAgj49t8CeIyfZur7D1/793S10tNSX56NrYVFeNA89ZGx0W3Ye+is/cy79+OcAyTo4bZvjo5dIOg9dg6OSqaur4/Of/zzbtm1jbGyMCy+8kLe//e1s2rQpvEEEJOjPHB5lPmV8+efgvH+2ru/gqUPlCLrmoedDI/SQSaUC8tBfedK5PO0C//dZtw1e/cViP+wiSZwihUWVbJ+7du1atm1zlt1tb29n48aNHD4ccrfplNsHpUxBf3pgFIAtfTlaTniwpa+DfcfGmJotsReLHXNKe7nkQiP0kAnMcjm2B1aud1IS/bL6XFiYhaED0HtO0YcM3XL59m3OF1CQrNkMl/+Z581hts89ePAgTz75JDt27Aj2ORYioAh939Exulob6C1imbnXrWnHGNh/bJzNRXwRpFEPPS8aoYdMYHnox/bAqo3F3cfuf+zZkg55KkyKhtU+d3x8nGuuuYa/+qu/YsWKFSE9O5eABH3v0THOXt1WlH149pr29H1LQgU9Lxqhh0wgeegLc3BiH7z20uLu13O284E4tgfOfWfRhw09Dz1PJF0tgmifOzc3xzXXXMP111/P1VdfHf6TCEDQjTHse3WMd13YV9T9zuhqoaEuwT4V9IqgEXrIBLIE3dABxzpZVeREWn2z0/OlzAi9lvPQK90+1xjDTTfdxMaNG5d1cgyNAPLQD49MMTG7kI64/VKXTPDa3jb2vqqCXgk0Qg+ZQCyXY3ucy2ItF3sfe/8iORUsl8z2uclkkgsuuID+/v707bZ9bm9vLzt27GBszBGmT3ziEzz//PMYY7j00kvZsmULd955J/fddx/19fWsWbOGP/zDP+SHP/wh9913H5s3b2br1q0AfPazn+WKK64I70kGEKE/f3QcIG9DLi/OWdPOYwdKbNKlgp4XFfSQCWRS9Nge543dc3bx9121CZ57GOamnIi9CMJesahaVLJ97pve9Kbq/8IJYIEL64GfVYKgn726nX968jCjU3OsbC6ynbPmoedFLZeQCSQP/dizjnVSpCADToRuUo4HXyRhLxKtVIgAIvR9r46xdmVT8YIMnLPGaRPwfCk+ekIj9HyooIdMIO1zj+2B3tcV3i8XvTbTpXjb5VTw0E8JAhD0vUfHSorOAc5aVUami1oueVFBDxlruZTcy2V+BoZeKM0/B+h+DSTqS5oYXcxDL+3QftEvjAqfAyuGidJWDlpIGfYfG+dsHw25crGuo5nWhiT7SpkYVUHPiwp6yNiy+ZInRYcPOm/mUvxzcJag69oAgy8UfdcwlqBrampicHDwlBZ1YwyDg4M0NTVV6ADlRehHRqeYmU/xmhIFPZEQNvS28uLgZPF3VkHPi06KhsxCuXnoVoi7XlP6ILpe46Q+FomN0BcqKLZ9fX0MDAxw/Pjxih0jDjQ1NdHXV1yOt29MeaX/B084Qtzf3VryEPq7W9OtA4oiLeha+p8LFfSQKTsPfcgK+obSB9F1Jhz4vvNzIeH/Qx2Gh15fX8+GDWU8N6UwZeahvzg4AUB/T0vJQ+jvbuWRXxxhdj5FQ10R49AIPS9quYRM2XnoQweguRNaugrv60X3mTA/DWNHirpbQrst1gZlWi4vnZigqT7B6vbSLaH+nlZSBgaGi7RdVNDzooIeMmXnoQ++4ETY5WDtmqHifHRdgq5GKDMP/eDgBP3drek01lLY4Eb3B91o3zeah54XFfSQKTsPfejF8vxzWPxCKNJHPxUqRU8JyozQDw5OckZ36XYLwBmu/279eN9ohJ4XFfSQKSsPfW4aRg+VH6Gv7INkQ9GZLumaDo2O4k0Zgr6QMrw8OEl/T+kTogDdrQ20N9aVEKHrAhf5UEEPmbIWuBh5CTBOLnk5JJLQuUEj9FOVMgT9yOgUswspNpSR4QLOL9T+nlYOFpu6qBF6XlTQQ6asSdF0ymKZEbp9jKIF3blUDz3mlCHo1iI5o0xBdx6jhYMnSvXQVdBzoYIeMul+6KWc+aEABb3bzUUvImXlVFmCruYpQ9BtyuKGMi0X+xgDw5PMzhchzuJWt6qg58TXKyoil4nIXhHZLyK35bj9dBH5vog8KSJPi0iIvUDjhSknQg8iZdHStcFNXXzF910W89DLP7xSRcoQdJuyuKqIZee8OKPbSV08VEzqokboeSn4iopIErgLuBzYBFwnItkrK3wKeNAYcwFwLfA/gx5orZDu5VKKoA8fhM7+YAbS6RbvDL/k+y4aodcI6cKi4nu5vDw0yeldLWWlLFpspsyhIRX0oPDzFX0RsN8Yc8AYMws8AFyVtY8B7MKIKwH/Yd8pxmLaYgl3HjkEHacHM5COM5zL0UO+77KYhx7MEJQqUUYe+uGRKfo6y0tZtPR1Nqcf0zcq6HnxI+jrgMxP/YC7LZPbgfeKyADwCPDhXA8kIjeLyC4R2XWq9upIlVr6b4wjvkEJ+kq3T8jIy77vku6Hrooeb1Kl93IZGJ5iXUcJffhzsKq9ifqkMDBcgqBruXJOgpoUvQ641xjTB1wB3Cey/N1ijPmKMWa7MWZ7b29vQIeOF4tpi0XecfyY43mvDEjQ65ugbbWbCukPzXKpEUr00Mem5xidmktH1uWSTAhrVzYXKeiah54PP6/oYWB9xvU+d1smNwEPAhhjfgw0AT1BDLDWKDlt0VojQUXo9rFG/FsumodeI5Qo6NYaWReQoINjuxzWSdHA8POKPg6cJSIbRKQBZ9JzZ9Y+LwOXAojIRhxBPzU9lQKkSm2fayPpwAXdv+WivVxqhBIFfWDIEfSgPHTnsYqN0FXQ81HwFTXGzAO3AI8Ce3CyWXaLyB0icqW728eAD4rIz4GvAzcarQ/PiTEGkRJ6uVjh7Viff79iWLkeRgd8+5G6BF2NUKqgu5F0UJYLwLqOFo6NzTAz77O/uQp6Xnz1QzfGPIIz2Zm57dMZ/z8LXBzs0GqTlCm17P9lJwe9sbR1HHPScTqk5mD8VVhxWsHd1XKpEUoW9Cma6hN0tzYENhT75fDKyLS/YiUV9LxopWjIpIwprTFXkCmLFpu66NN20UnRGqHEBS4OjzgZLiV3Cs2BFXTffdFV0POigh4yKVNi69yRlx2LJEisfeNzYjSdtqh6Hm/KiNDXBeifw+IE62G/PnpCS//zoYIeMqaUCN0YR9BtRB0U9gvCZ+qieug1QomFRQPDk4H65wBrVjSRTBSRi64LXORFBT1kHMulSEWfHIT5qWAnRAEaWqClx3e1qFouNYJJAVKUoE/MzDM8GVwOuqUumWDNiib/1aJqueRFBT1kUqaEPi6VSFm0dJzuu5+LTorWCCa1aF34JJ2DHlCVaCZ9nc3++7loYVFeVNBDZiFlis9BHx1wLm25fpCs7IOT2XViubHjXlBFjzdmofSiogoI+rqOZo6MTvu/gySc56AsQwU9ZIwxxXeqO+n2OltRIUEfPezLk1QPvUYwqaIF/VVXcNdWQNDXdjRx9OS0/0BBEhqhe6CCHjIl5aGfPAzJxmD6oGez4jSYm4CZkwV3VculRihB0I+MTiNCIH3Qs1mzspn5lGFwfMbfHVTQPVFBD5mS8tBPvuIIb4D5v2lsQdHJwh2PdVK0RjCmhAh9it62RuqTwUvG2hVNAP5tFxV0T1TQQ6akPPSTr8CK7I7FAWEfd7Swjy4aodcGJUboa1c2VWQ4a1ZaQS8i00UFPScq6CFTUh76ycO+SvNLIh2h+5sYTYh66LHHpIr+tffq6HRaeINm7cpSInR9D+ZCBT1kis5DT6Xg5BFYWaEIvX0tIL4sF3B8dLVcYk6Jk6JrVwY/IQrQ1dpAQ10iPfFaEI3QPVFBD5miJ0UnjjsNtCpluSTrnYUufEfoopZL3ClS0Mem5xibma+Y5SIirF3ZVESELiroHqigh0zKFJmHboW2UpaLfWy/EXpCJ0VjT5GCbiPnSlku4LQA8B+hJ1XQPVBBDxlTbISezkGvtKD7j9BVz2NOkYJuI+dKWS7OYzfxik6Klo0KesgUnbaYFvQKWS72sYvx0NVziTclRuiVslzAyUU/enLa33tLBd0TFfSQSRmKqxQ9eRgS9U4TrUqx4jSnsGi6cHGRiKYtxh6TcmwLn9gIfdWK4IuKLGtXNjG3YBicmC28swq6JyroIZNKFZnlYouKEhV8qWyPmLEjBXfVLJcaIFVkhH5yip62RhrrimvoVQw2+vflo0sCUtrLJRcq6CFTkuVSSbsFispFT4hOisaeIvPQK1lUZLH+vK/iIs1D90QFPWSKzkM/OQAr1lZuQLAo6D6qRTVCrwGKnRQdmWb1isoK+ppiiovUcvFEBT1kiir9NwbGXnWLfypI2xrncuzVgruK5qHHnyIF/ejYNGtWVs4/B+hubaAuIRw96UfQNQ/dCxX0kCmq9H96FOanKy/o9U3Q3AnjhQVdS/9rgCIEfWZ+gZHJOVa3VzZCTySE3vZGjo356LioEbonKughU1SlqI2Y29dUbkCWtjW+InQnbbHyw1EqSBGCfuykI7CVtlzAac3rL0JXQfdCBT1kipoUtVknYQh6u19B10nR2FOMoI85AttbwZRFy6oVTRzXCL0sVNBDpigPffyoc1lpy8Uew4+gJ9RDjz2lROgVtlwAVq/wGaEntPTfCxX0kCnKQ7cRetvqio0nTftqx0Mv4Kc4pf+q6LGmiAUurMCuDiNCb29ieHKOmfkCOeYaoXuigh4yRaUtjr0KDe3Q2FbZQYEToafmYWoo725qudQAReShHx2boS4hdLY0VHhQi18aBW0XFXRPVNBDJpUqclI0DP8cFo9ToFpU2+fWAEVaLqvaG4tf2LwEVrkTr0dPFhJ00cIiD1TQQ2ahmPa5YQp6Ohf9aN7dRJznoMQYs1DUpOiqEDJcYHEB6uNjBXx0STjPQVmGCnrIGGNI+o12xo5EMkJXDz3mmJQzseiDoyen00JbaVb7jtDVcvHCl6CLyGUisldE9ovIbR77/JaIPCsiu0Xk74MdZu3gOw/dGCfLJYwJUcgQ9PyZLpqHXgMUlbY4E0oOOkBXi89qURV0T+oK7SAiSeAu4O3AAPC4iOw0xjybsc9ZwB8AFxtjhkVkVaUGHHd8r1g0PRJOlailrtFXtajopGj88Sno03NulWgIGS5QRLWoCronfr6mLwL2G2MOGGNmgQeAq7L2+SBwlzFmGMAYcyzYYdYOviP0MKtELT5y0XVStAbwmbZos03C8tDtsTRCLx0/gr4OOJRxfcDdlsnZwNki8kMReUxELsv1QCJys4jsEpFdx48fL23EMcd3Hno1BL1tdWFBT2gvl9jjM0K3VaJheej2WJq2WDpBTYrWAWcBvwxcB9wtIh3ZOxljvmKM2W6M2d7b2xvQoeOF7zz0tKCHZLnYY/mK0FXQY43PPPSjIfZxsfiqFtV+6J74EfTDwPqM633utkwGgJ3GmDljzIvAPhyBV7JIpXyW/odZJWppX1OwWlTb59YAPiN0K6xhRuir/VSLaoTuiR9Bfxw4S0Q2iEgDcC2wM2ufb+JE54hID44FcyDAcdYMvptzjR+DhrZwqkQtbaucatHpEc9dkjopGn98CvrxEKtELT3ul8fgeJ61RVXQPSn4qhpj5oFbgEeBPcCDxpjdInKHiFzp7vYoMCgizwLfBz5hjBms1KDjjPE7KTpxzBHYMGl1bbBx7zltJw89pPEolcGnoJ8Yn6GnLZwqUUtPW2P62J6ooHtSMG0RwBjzCPBI1rZPZ/xvgI+6f0oeUsb4W+95/Fi4dgssfoGMH4VVr8u5i3roNUAREXpPe3jROUBPW0P62J6ooHuilaIh4+Sh+4h4xo8uRsxh0eoK+oR3BpLmodcAfgV9fIbetvD8c9AIvVxU0EPGdx56mFWilnSEnt9y0UrRmJPyH6H3hjghCqSPd6KQh57SXi65UEEPmZQxJAvp+fyMs55o2ILe1AGJOse/9yCR0Ag99viI0FMpw+D4bOiC3lSfpK2xTi2XElFBDxlfeeg2Qg57UjSRcGyecW/LRT30GsCHoI9MzTGfMmkLJEx62hp8WC76HsyFCnrI+MpDTwt6yBE6OIKeJ0LXPPQawIeg2wg57AgdHB89v6CLRugeqKCHjK/Sf7uWaNgRuj1mXg9dS/9jTzGCXpUIvbGwh66CnhMV9JDxNSk6USXLBZxMlzxZLtqcqwbwIeg2Qq5KhN7ux3JRQc+FCnrI+MpDtxFy2GmLAG29jqB7ROG6pmgNUESE3lMly2Vkco65BQ/RVkH3RAU9ZFLGj4d+1OlNXhf+h4m21bAw61n+rxF6DeBH0MdnaKxL0N7oq/YwUHoLlf8nkiroHqigh4xvD70aE6KwWFzkkemiS9DVAD76odscdF9FcAFTsLhII3RPVNBDxl/a4vHq+OfgWC7gmemieeg1gE8PvRr+OSwK+nEV9KJRQQ8ZX5Oi40cXI+Wwac1fLappizWAj37ox8dmqpKDDouZNSe8ios0D90TFfSQSaV8rClajcZclrb8/Vyc0n/9MMUas+DbcqkGtiGYZ+qiiPMclGWooIdMQctlZhzmJqpnuTR3gSQ9I3TNcqkBClgu8wsphiZnq5KDDtDSUEdLQ1I99BJQQQ+ZlIFkvllRGxlXI2UR3PL/Hm8PXS2X+GNSTqaIB0OTsxiz2Mq2GuStFlVB90QFPWSc9rl5dpg44VxWK0IHx0f3yHLR9rk1QIEI3aYLVstDd46dp7hIBd0TFfSQKbhiUTpC7wlnQLlo8+7noisW1QA+Bb27qoLeyIkxLw9dBd0LFfSQKbimaLUtF8gboauHXgMUyEMfnHAi4+5qWi7tarmUggp6yBScFLWC3hKBCD2HcGv73BqgQIRus0u6W6vroQ9NzjKfq/xfBd0TFfSQKVj6PzkIDe1Q3xTeoLJpXQXz0zAztuwmzUOvAQrkoQ9NzFCXEFY01Yc4qKX0tjVgjDNBuwzNQ/dEBT1EbMl8Qculmv455M1FTya0fW7s8eGhd7U2kCjYo6JypMv/c/noGqF7ooIeIjayLWi5VNM/h8Xj277sGWjaYg3gw3Kp5oQoLHZ5zFn+r4LuiQp6iKR8Regnqi/oeRaLVg+9BigUoU/MVDUHHTIjdBX0YlBBDxErhHk99ChYLq3elosIWvofd3xYLtWcEIXFoqacmS4q6J6ooIdIyn0PelouqZQboVdZ0Fu6AckToYc/JCUgjPEh6DN0tVbXcmlrrKOxLuEt6Cnt5ZILFfQQKWi5TI84TYeqbbkk6xxRz1FcpHnoMce+dh6CPj23wMTsQlVz0MH5Feu5tqhG6J6ooIeIFULPXi627L/agg7uYtHLLRf10GOOFULJ3ctlcMKW/VdX0CFPcZEkAKOpizlQQQ8Ra1V4euhRKPu3tOYu/9c89JiTFvTc78FBV0C7q2y5gJOLftxrUhRU0HOggh4iBfPQo1D2b2lb5eGhax56rEkLeu6P/mIflwhE6PksF1DbJQcq6CFSMA89SoLeuipnlotOisacAoJuLY5qdlq09LQ1MjQxw0L2G85+flTQl6GCHiIFJ0Wth97cFc6A8tHWC3OTzoIbGeikaMwpFKG7HnpXldMWwfHxUwaGs8v/NUL3xJegi8hlIrJXRPaLyG159rtGRIyIbA9uiLVDwTz0ieOOmCfrQhyVB+lc9KW2SyLhtM9V2yWmFLRcZmiqT9DS4L0ARljYatFlE6N2cQ4V9GUUFHQRSQJ3AZcDm4DrRGRTjv3agVuBnwQ9yFrB+LFcomC3QEa16FLbxY5d9Tym+Jt0SQ8AABS+SURBVPDQu1sb8xe/hYRnPxeN0D3xE6FfBOw3xhwwxswCDwBX5djvM8CdwHSA46spClouk4PREfSWbudy8sSSzXbsarvEFB+WSxRSFmGxfa/tz55GBd0TP4K+DjiUcX3A3ZZGRLYB640xD+d7IBG5WUR2iciu48dzL6BQy/iaFI1CyiIsjmNiqaDbyE0nRmNKgcKiwYmZqjfmslgff2hCI3S/lD0pKiIJ4C+BjxXa1xjzFWPMdmPM9t7eiESiIWJ7oHj+mo2S5WIX2FgWoVtBV0WPJcYtmffMQ69+HxdLR0sDIiroxeBH0A8D6zOu97nbLO3AecAPROQg8EvATp0YXc6i5ZLjw7QwB1PD0YnQG1qgvgUmBpdsVssl5uSxXIwxTi/0iFguyYTQ2dKQzrxJo4LuiR9Bfxw4S0Q2iEgDcC2w095ojBk1xvQYY/qNMf3AY8CVxphdFRlxjElbLrnO+qQrnFERdHCidM8IvRoDUsomj6CPzcwzu5CiJwJVopau1gaGsouLNA/dk4KCboyZB24BHgX2AA8aY3aLyB0icmWlB1hL5I3Qo1RUZGntzuGhO5caoccUK4KJ5WmJUaoStXS1NqjlUgS+Ep6NMY8Aj2Rt+7THvr9c/rBqE5NX0CPUmMvS0rM8D92mLepnKZ7kidCH3GySqEyKgpPpsu9o1tq2KuieaKVoiOTNcomioLf2qIdea+QRdNs3JSqToqARerGooIdI3jz0KHVatLR0Ox56hnjbhYNV0GNKHkG3lksU+rhYulsbGJmaW9rPRQXdExX0EEmlO5d6eOiJOmjqCHdQ+WjtgflpmJ1Ib9I89JiTJw/dts7tbK0Pc0R56WptwGT3c1FB90QFPUQKRugtPXmS1KtAjlz0ZLr0XxU9luSL0CdmaW+qo7Gu+n1cLF3ur4UltotoLxcvVNBDJG8vl4kT0fLPIaNadNFHX/TQqzAepXzyLHBxYnwmUnYLZJT/j+eK0PVNmI0KeoikI/RcZz1KZf+WHBG6VorGnAIeepQmRMGj/F/z0D1RQQ+RvO1zJ6MYobsNujJy0TUPPebkTVucjVQOOixG6EPqoftCBT1E8hcWnYhXhK6fpXiSsr1ccnnoM3RFqEoUoNMKei7LxT4XJY0Keogs5qFn3TA7CbPj0RP0xnZINiyJ0K1dpBF6TPGI0BdShqEItc611CcTrGiqSxc9ARqh50EFPURst8VlEfpkBIuKwPFXWnoW+8ygHnrs8RD0kclZUiZaRUWW7rbGpQ26VNA9UUEPERuhL3NcotjHxZLVz0Xz0GOORx66Fcwolf1bllWLqqB7ooIeIjZ3O5mt6FYwWyJmucCyjovWLtI89JiSjtCX5prbdTujGKGroPtHBT1EFtvnZlsuEWyda2ntWeqha4Qebzzy0Icn5oBoRujdrQ0elou+CbNRQQ8Rz0rRdITeHe6A/LDMQ3cu1UOPKR4eup10jFLZv6WrtYHhidnFX4UaoXuigh4innnok4OQqHeySqJGa7eTgTPnrP2tk6Ixx1PQnQi9syWalst8ynByat7ZkFBB90IFPUQ8S/8nB53oPEp9XCxZuejpfuiq5/HEQ9CHJ50+LvXJ6EmCLXYatKmLGqF7Er1Xr4bxtFwmh6Lpn0NGPxdX0DUPPd54RujRK/u32GKn9MSoCronKugh4rnAxeQJaOkKf0B+yIrQNW0x5uQR9M6ICnq6QZcKekFU0EPENulf5qxYyyWKZHVctF9GC6ro8cTkLv0fmpilK4L+OeRo0JUWdC39z0YFPUQ81xSNsqDbcaU9dOeq5qHHFI/CouHJ6Ebo3oKuEXo2KughktNyWZiHqZFoFhWBs4KSJBc9dLVc4k0Oy8UYE2kPvak+SWtDcrEnugq6JyroIZJzUnRqGDDRjdATicW1RdH2ubEnR2HR5OwCM/OpyEboAF1tDYsNurSwyBMV9BDJmYdui3aiOikKbrXoUg9dBT2m5IjQrZURVQ8dnEyXxUlRXeDCCxX0ELEamEzkEvSIRuiwJELXPPSYY0UwsdjLxS7AHOUIvTuzn4taLp6ooIdITsslyn1cLBn9XLT0P+bki9AjLOhdKui+UEEPkZyTopMR7uNiyei4qHnoMSemgm4bdBljVNDzoIIeIoseesZGG6E3R9xDnx6Fhbm0XaQRekyJrYfewOx8ionZhcXWvyroy1BBD5GceeiTQ9DQBvVNVRqVD9K56IOahx53cuShD0/OkkwI7U11VRpUYboy1xbVCN0TFfQQyW25RLioyJLRz0UXiY45OSP0OTpbGpb36Y8QSxp0qaB7ooIeIjknRSdORF/QM/q5aB56zMmRhz40MUNXBPugZ7KkQZfmoXviS9BF5DIR2Ssi+0Xkthy3f1REnhWRp0XkuyJyRvBDjT+plEceetQFPVeErh+meJJa3stl2I3Qo8ySBl3pqEJ7uWRTUNBFJAncBVwObAKuE5FNWbs9CWw3xpwP/CPw50EPtBZYtFwyNk4ORV/Q0xH6oJb+x51clsvkbKQzXCCrn4taLp74idAvAvYbYw4YY2aBB4CrMncwxnzfGDPpXn0M6At2mLVBKuek6GC0c9ABmjsBgckhzUOPOzkEfXgi+oLe0pCksS7hFEGpoHviR9DXAYcyrg+427y4Cfh2rhtE5GYR2SUiu44fP+5/lDXCsknRuSmYm4h22T9Asg6aO2ByUPPQ406WoKdShuEYROgikl5bVAXdm0AnRUXkvcB24HO5bjfGfMUYs90Ys723tzfIQ8cCm+qXDo7iUPZvaenWtMVaIEvQR6fmSJloriWaTWdLg1ouBfCTeHoYWJ9xvc/dtgQReRvwSeAtxpiZYIZXW1ibImkj9NgJuk6Kxp60oDvFOUOT0a8StaTL/1XQPfEToT8OnCUiG0SkAbgW2Jm5g4hcAHwZuNIYcyz4YdYGyyyXtKBH3EMHV9CHNA897mQVFg3HoOzf0tnawPDknAp6HgoKujFmHrgFeBTYAzxojNktIneIyJXubp8D2oCHROQpEdnp8XCnNMtK/yfiFKF3OZaLLhIdb7Ly0AdjJOhdLfVOhJ7Q0n8vfNX6GmMeAR7J2vbpjP/fFvC4ahLjGaHHQdBdD929qnoeU7I8dBuhR7l1rqWztYHRqTnmU65w6ZtwGVopGiK2sCidhz45CIiTQRJ1WrphYZbkvJOdqhF6TMkS9LSHHoNJUfsrYnTGLSjSCH0ZKughktNDb+lasthAZHF/RSSnnV8VmrYYU3JE6M31SZobov8etJk4I5PzzgYV9GWooIfIQraHPhmDPi6WtKAPA4vPRYkZZmnp/2AMioos6WrRKSvoWvqfjQp6iBhjEMno5RKHsn+LFfSpIUDz0GNLjgi9M+KNuSzpCH1KI3QvVNBDJGVM/FrnWtIRuiPoKfVc4skyDz36jbks6Qh9Uj10L1TQQyRlcqwnGjNBT7gRuup5TMmRh94dE8vF/pIY0gjdExX0EEkZs2i3GBMvQW9aCZIkYSN0tVziSXaEPjEbi5RFgMa6JG2NdQxNqKB7oYIeIiYzQp8ehdR8fARdBFq60xG66nlMySgsmplfYHxmPhYpi5bO1nqGJuecK/omXIYKeoikUiaefVwsLd3IlE1b1A9TLDEpJzoXYcQVxrhE6ODkyw9q2qInKugh4njoGRkuEP1e6JlkROjqoccUK+i4i0VAbDx0cL58FiN0FfRsVNBDJOWmLQJODjpEvxd6Ji1d6S8ijdBjSg5Bj1uE7nRcTKqg50AFPUSMMYsrq8fcctE89JiSQ9DjUlgEbsdF20JXBX0ZKughstRyiaegMzmEkFLLJa5kCPqw28clLnno4Hz5TMwuYFTQc6KCHiJOYZF7ZXIQko3Q0FbVMRVFSzdiFmhnUi2XuGLMcsulJR6VopDx5aOCnhMV9BBZkoc+4eagZ1aORh3310R3YkwrReNKamGJoK9srqcuGR8Z6HKLiwziPBdlCfF5JWuAVCqrdW6c7BZYFHQZV8slrphUOogYilFjLouN0FOS0Dz0HKigh8iSXi62dW6ccMfbLWNqucSVLA89TnYLLE7gGkQtlxyooIfIsknROOWgQzpC79QIPb4syXKZo6u1scoDKg6bYpkyKui5UEEPEZOdhx5by+Wkpi3GlSWCPpP2pONCR7Mz3pRG6DlRQQ+RtOWyMOf0comboDe0QrKRLrVc4osr6MYYhifmYlVUBFCXTLCyuZ4FFfScqKCHSMpAMiEw5az6EztBdxt0dTGmlktcMSmQJBOzC8wupGLVmMvS1dqglosHKughki79j2NRkaWlm06N0OOLm4c+HMMqUUtnSz3zRvPQc6GCHiLGTopO2D4ucRT0LjoZ04yxuOJaLoMxFvSu1gYWNELPiQp6iKQrRWMeoXegEXpscfPQh2PYmMvS2dLAvEHz0HOggh4i6UlRFXSlWrgReroxV0w99HkjGKOVotmooIfIQgqn9N/2Qo+joLf2sJJxzMJ8tUeilIJxSv9tY66utngKesoIC/P6HsxGBT1ETNpyOQGNK6Aufh8m+yXUNH+yygNRSiLDQ69LCO2NddUeUdF0tjaQQphRQV+GCnqILLFc4lb2b3HH3Tw3UuWBKCXhCvqwuzi0xKk5nEtXSwMpEszNqeWSjQp6iKTsItFxbMxlccfdMq+CHksyPPQ4+ufgROgGYVYj9GWooIdIun3u5CC0xKyPi8UV9Ob50SoPRCkJm4c+Gb9Oi5Yu13KZU0Ffhgp6iBgboU/EP0Jv1Qg9nmR46LEVdNdymVXLZRm+BF1ELhORvSKyX0Ruy3F7o4j8g3v7T0SkP+iB1gI14aE3O+Nu0Qg9nmTkoXfGrDGXpb2pDoMwrxH6MgoKuogkgbuAy4FNwHUisilrt5uAYWPMa4H/AdwZ9EBrgZQxNDED81PxjdDrm5ikiZYFFfRYYlIYSTAyNRdbDz2REBKJBHMLGqFn4ydn6SJgvzHmAICIPABcBTybsc9VwO3u//8I/I2IiKlAj9XHv/EFep+5O+iHDYXPLBha69xTEldBB0ZlBRcOPcLBO86r9lCUIlmdOs5LifUYE88qUYsk6jhjdFds34ODF/4+F/76bwf+uH4EfR1wKOP6ALDDax9jzLyIjALdwInMnUTkZuBmgNNPP720Abd1M9SyoaT7RoHWlc3QdTG89m3VHkrJHDr3d6g7+O/VHoZSAkNs4OnWN3JV52lc+rrV1R5OyYxs/s+Mv/BotYdRMg1tlbFcpVAQLSLvAi4zxvy2e/19wA5jzC0Z+zzj7jPgXn/B3edErscE2L59u9m1a1cAT0FRFOXUQUSeMMZsz3Wbn0nRw8D6jOt97rac+4hIHbASGCx+qIqiKEqp+BH0x4GzRGSDiDQA1wI7s/bZCdzg/v8u4HuV8M8VRVEUbwp66K4nfgvwKJAEvmqM2S0idwC7jDE7gXuA+0RkPzCEI/qKoihKiPjqzGOMeQR4JGvbpzP+nwbeHezQFEVRlGLQSlFFUZQaQQVdURSlRlBBVxRFqRFU0BVFUWqEgoVFFTuwyHHgpRLv3kNWFWoEifoYdXzlEfXxQfTHqOMrjTOMMb25bqiaoJeDiOzyqpSKClEfo46vPKI+Poj+GHV8waOWi6IoSo2ggq4oilIjxFXQv1LtAfgg6mPU8ZVH1McH0R+jji9gYumhK4qiKMuJa4SuKIqiZKGCriiKUiPETtALLVhdhfGsF5Hvi8izIrJbRG51t98uIodF5Cn374oqjvGgiPzCHccud1uXiPyriDzvXnZWcXznZJynp0TkpIj8fjXPoYh8VUSOuYu32G05z5k4fNF9Tz4tItuqNL7Pichz7hj+SUQ63O39IjKVcR6/VKXxeb6eIvIH7vnbKyK/Vunx5RnjP2SM76CIPOVuD/0cloQxJjZ/OO17XwDOBBqAnwObqjymtcA29/92YB/OYtq3Ax+v9jlzx3UQ6Mna9ufAbe7/twF3VnucGa/xq8AZ1TyHwCXANuCZQucMuAL4NiDALwE/qdL4fhWoc/+/M2N8/Zn7VfH85Xw93c/Lz4FGYIP7GU9WY4xZt38e+HS1zmEpf3GL0NMLVhtjZgG7YHXVMMYcMcb8zP1/DNiDs8Zq1LkK+Dv3/78DfrOKY8nkUuAFY0ypVcSBYIz5D5ze/pl4nbOrgK8Zh8eADhFZG/b4jDH/YoyZd68+hrO6WFXwOH9eXAU8YIyZMca8COzH+axXlHxjFBEBfgv4eqXHESRxE/RcC1ZHRjxFpB+4APiJu+kW9+fvV6tpaQAG+BcRecJdqBtgtTHmiPv/q0BUVgy+lqUfoqicQ/A+Z1F8X34A51eDZYOIPCki/y4ib67WoMj9ekbx/L0ZOGqMeT5jW1TOoSdxE/TIIiJtwP8Gft8YcxL4W+A1wFbgCM7Pt2rxJmPMNuBy4PdE5JLMG43zm7Lq+aviLHF4JfCQuylK53AJUTlnuRCRTwLzwP3upiPA6caYC4CPAn8vIiuqMLTIvp45uI6lgUVUzmFe4ibofhasDh0RqccR8/uNMd8AMMYcNcYsGGNSwN2E8BPSC2PMYffyGPBP7liOWlvAvTxWrfFlcDnwM2PMUYjWOXTxOmeReV+KyI3AbwDXu186uFbGoPv/Ezge9dlhjy3P6xmZ8wfphe6vBv7BbovKOSxE3ATdz4LVoeJ6bfcAe4wxf5mxPdNDfSfwTPZ9w0BEWkWk3f6PM3H2DEsX9r4B+D/VGF8WS6KiqJzDDLzO2U7g/W62yy8BoxnWTGiIyGXAfwOuNMZMZmzvFZGk+/+ZwFnAgSqMz+v13AlcKyKNIrLBHd9Pwx5fBm8DnjPGDNgNUTmHBan2rGyxfzgZBftwviE/GYHxvAnnp/fTwFPu3xXAfcAv3O07gbVVGt+ZOBkEPwd223MGdAPfBZ4H/g3oqvJ5bAUGgZUZ26p2DnG+WI4Aczie7k1e5wwnu+Uu9z35C2B7lca3H8eLtu/DL7n7XuO+9k8BPwPeUaXxeb6ewCfd87cXuLxar7G7/V7gd7P2Df0clvKnpf+Koig1QtwsF0VRFMUDFXRFUZQaQQVdURSlRlBBVxRFqRFU0BVFUWoEFXRFUZQaQQVdURSlRvj/XW4jv7TWmxQAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def build_dataset(singal,noise_ratio,number_of_each_class,class_number):\n",
    "    singal = np.expand_dims(singal,0)\n",
    "    singal_matrix = np.repeat(singal,number_of_each_class, axis=0)\n",
    "    \n",
    "    noise = noise = np.random.normal(0,noise_ratio,[number_of_each_class,singal.shape[-1]])\n",
    "    lables = np.ones(number_of_each_class)*class_number\n",
    "    return singal_matrix+noise,lables\n",
    "\n",
    "\n",
    "nosie_weight = 0\n",
    "number_of_each_class = 16\n",
    "\n",
    "x_train_class1, train_lables_class1 = build_dataset(singal_class_1,nosie_weight,number_of_each_class,0)\n",
    "x_test_class1, test_lables_class1 = build_dataset(singal_class_1,nosie_weight,number_of_each_class,0)\n",
    "\n",
    "x_train_class2, train_lables_class2 = build_dataset(singal_class_2,nosie_weight,number_of_each_class,1)\n",
    "x_test_class2, test_lables_class2 = build_dataset(singal_class_2,nosie_weight,number_of_each_class,1)\n",
    "\n",
    "\n",
    "X_train_numpy = np.float32(np.concatenate((x_train_class1,x_train_class2),0))\n",
    "y_train_numpy = np.int64(np.concatenate((train_lables_class1,train_lables_class2),0))\n",
    "\n",
    "X_test_numpy = np.float32(np.concatenate((x_test_class1,x_test_class2),0))\n",
    "y_test_numpy = np.int64(np.concatenate((test_lables_class1,test_lables_class2),0))\n",
    "\n",
    "print(X_train_numpy.shape)\n",
    "print(y_train_numpy)\n",
    "plt.plot(X_train_numpy[2,:],label='class1')\n",
    "plt.plot(X_train_numpy[number_of_each_class+2,:],label='class2' )\n",
    "\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# The FCN train and classification result is in the below cell,\n",
    "# as you can see the train and test acc are still 0.5 for FCN can not tell the difference between class 1 and class 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "code is running on:  cuda:0\n",
      "190 tensor(2, device='cuda:0')\n",
      "99 0.693153440952301 0.0005\n",
      "train_acc=\t 0.5 \t test_acc=\t 0.5 \t loss=\t 0.693153440952301\n",
      "199 0.6973710656166077 0.000125\n",
      "train_acc=\t 0.5 \t test_acc=\t 0.5 \t loss=\t 0.6973710656166077\n",
      "299 0.6931663751602173 0.0001\n",
      "train_acc=\t 0.5 \t test_acc=\t 0.5 \t loss=\t 0.6931663751602173\n",
      "test_acc =  0.5\n"
     ]
    }
   ],
   "source": [
    "print_result_every_x_epoch = 100\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "print('code is running on: ',device)\n",
    "\n",
    "X_train = torch.from_numpy(X_train_numpy)\n",
    "X_train.requires_grad = False\n",
    "X_train = X_train.unsqueeze_(1).to(device)\n",
    "y_train = torch.from_numpy(y_train_numpy).to(device)\n",
    "X_test = torch.from_numpy(X_test_numpy)\n",
    "X_test.requires_grad = False\n",
    "X_test = X_test.unsqueeze_(1).to(device)\n",
    "y_test = torch.from_numpy(y_test_numpy).to(device)\n",
    "\n",
    "input_shape = X_train.shape[-1]\n",
    "n_class = max(y_train) + 1\n",
    "print(input_shape, n_class)\n",
    "    \n",
    "    \n",
    "torch_FCN = Torch_FCN(total_length,n_class.item()).to(device)\n",
    "\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(torch_FCN.parameters())\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(300):\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,print_result_every_x_epoch):\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,'\\t loss=\\t', output.item())\n",
    "\n",
    "torch_FCN.eval()\n",
    "acc_test = eval_model(torch_FCN, test_loader)\n",
    "torch.cuda.empty_cache()\n",
    "print('test_acc = ',acc_test)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# The following is OS-CNN result on handcrafted data\n",
    "# as you could see OS-CNN would converge."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "code is running on  cuda:0\n",
      "epoch = 99 lr =  0.001\n",
      "train_acc=\t 1.0 \t test_acc=\t 1.0 \t loss=\t 0.023457884788513184\n",
      "log saved at:\n",
      "./Example_Result/Handcrafted_Dataset/Handcrafted_Dataset_for_positional_information_loss/Handcrafted_Dataset_for_positional_information_loss_.txt\n",
      "epoch = 199 lr =  0.001\n",
      "train_acc=\t 1.0 \t test_acc=\t 1.0 \t loss=\t 4.38690185546875e-05\n",
      "log saved at:\n",
      "./Example_Result/Handcrafted_Dataset/Handcrafted_Dataset_for_positional_information_loss/Handcrafted_Dataset_for_positional_information_loss_.txt\n",
      "epoch = 299 lr =  0.001\n",
      "train_acc=\t 1.0 \t test_acc=\t 1.0 \t loss=\t 7.867813110351562e-06\n",
      "log saved at:\n",
      "./Example_Result/Handcrafted_Dataset/Handcrafted_Dataset_for_positional_information_loss/Handcrafted_Dataset_for_positional_information_loss_.txt\n",
      "correct: tensor([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1,\n",
      "        1, 1, 1, 1, 1, 1, 1, 1], device='cuda:0')\n",
      "predict: [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1.]\n",
      "1.0\n"
     ]
    }
   ],
   "source": [
    "from Classifiers.OS_CNN.OS_CNN_easy_use import OS_CNN_easy_use\n",
    "from sklearn.metrics import accuracy_score\n",
    "Result_log_folder = './Example_Result/Handcrafted_Dataset/'\n",
    "dataset_name = 'Handcrafted_Dataset_for_positional_information_loss'\n",
    "\n",
    "\n",
    "\n",
    "model = OS_CNN_easy_use(\n",
    "        Result_log_folder = Result_log_folder, \n",
    "        \n",
    "        dataset_name = dataset_name,\n",
    "        \n",
    "        device = \"cuda:0\", \n",
    "        \n",
    "        Max_kernel_size = 89, \n",
    "    \n",
    "        paramenter_number_of_layer_list = [8*128, 5*128*256 + 2*256*128],\n",
    "        \n",
    "        max_epoch = 300,\n",
    "        \n",
    "        print_result_every_x_epoch = 100\n",
    "        )\n",
    "    \n",
    "\n",
    "model.fit(X_train_numpy, y_train_numpy, X_test_numpy, y_test_numpy)\n",
    "    \n",
    "y_predict = model.predict(X_test_numpy)\n",
    "print('correct:',y_test)\n",
    "print('predict:',y_predict)\n",
    "acc = accuracy_score(y_predict, y_test_numpy)\n",
    "print(acc)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# However, if we change the Max receptive field of OS-CNN smaller than the gap between the handcrafted data, OS-CNN cannot obtain the positional information too.\n",
    "# that is the reason why we need a kernel = 0.25* dataset_length\n",
    "# below code we change the kernel size to 19. the receptive field would be 19+19= 38 <70\n",
    "# Following code shows OS-CNN will not converge with small RF "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "code is running on  cuda:0\n",
      "epoch = 99 lr =  0.0005\n",
      "train_acc=\t 0.5 \t test_acc=\t 0.5 \t loss=\t 0.6996207237243652\n",
      "log saved at:\n",
      "./Example_Result/Handcrafted_Dataset/Handcrafted_Dataset_for_positional_information_loss_2/Handcrafted_Dataset_for_positional_information_loss_2_.txt\n",
      "epoch = 199 lr =  0.000125\n",
      "train_acc=\t 0.5 \t test_acc=\t 0.5 \t loss=\t 0.7037078142166138\n",
      "log saved at:\n",
      "./Example_Result/Handcrafted_Dataset/Handcrafted_Dataset_for_positional_information_loss_2/Handcrafted_Dataset_for_positional_information_loss_2_.txt\n",
      "epoch = 299 lr =  0.0001\n",
      "train_acc=\t 0.5 \t test_acc=\t 0.5 \t loss=\t 0.6931563019752502\n",
      "log saved at:\n",
      "./Example_Result/Handcrafted_Dataset/Handcrafted_Dataset_for_positional_information_loss_2/Handcrafted_Dataset_for_positional_information_loss_2_.txt\n",
      "correct: tensor([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1,\n",
      "        1, 1, 1, 1, 1, 1, 1, 1], device='cuda:0')\n",
      "predict: [1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1.]\n",
      "0.5\n"
     ]
    }
   ],
   "source": [
    "from Classifiers.OS_CNN.OS_CNN_easy_use import OS_CNN_easy_use\n",
    "Result_log_folder = './Example_Result/Handcrafted_Dataset/'\n",
    "dataset_name = 'Handcrafted_Dataset_for_positional_information_loss_2'\n",
    "\n",
    "\n",
    "\n",
    "model = OS_CNN_easy_use(\n",
    "        Result_log_folder = Result_log_folder, \n",
    "        \n",
    "        dataset_name = dataset_name,\n",
    "        \n",
    "        device = \"cuda:0\", \n",
    "        \n",
    "        Max_kernel_size = 19,   \n",
    "    \n",
    "        paramenter_number_of_layer_list = [8*128, 5*128*256 + 2*256*128],\n",
    "        \n",
    "        max_epoch = 300,\n",
    "        \n",
    "        print_result_every_x_epoch = 100\n",
    "        )\n",
    "    \n",
    "    \n",
    "model.fit(X_train_numpy, y_train_numpy, X_test_numpy, y_test_numpy)\n",
    "    \n",
    "y_predict = model.predict(X_test_numpy)\n",
    "print('correct:',y_test)\n",
    "print('predict:',y_predict)\n",
    "acc = accuracy_score(y_predict, y_test_numpy)\n",
    "print(acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
