{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Check the Capability equivalent  with random initialization kernel and weight\n",
    "\n",
    "## To explain Capability equivalent we need denotes some names:\n",
    "### input signal : X\n",
    "### one layer convolution: Q \n",
    "### two-layer convolution: K and W \n",
    "\n",
    "### Conv(X,Q) denotes passing input singal X into one layer convolution Q\n",
    "\n",
    "### Conv(Conv(X,K),W) denotes passing input signal X into one layer convolution K, then pass the result to W.\n",
    "\n",
    "\n",
    "# Capability equivalent means no matter what X is, for any Q we can find a K, W, which can get the same information from X as Q.\n",
    "\n",
    "# K,W and Q are of same receptive field\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "## in the following code verification \n",
    "###  conv Q which size is \n",
    "kernel_filter_length (in here the value is 12 you could change the value)\n",
    "\n",
    "### and sizes of two layer conv are\n",
    "kernel1, kernel2 (this is auto generate you could change the value as long as kernel1+kernel2 = kernel_filter_length +1 )\n",
    "\n",
    "\n",
    "# Some times it cannot get expected result for the reason that back propagation cannot guarantee global minimum, you could change the optimizer's learning rate and run the second cell again."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from random import randint\n",
    "\n",
    "\n",
    "\n",
    "class SampaddingConv1D(nn.Module):\n",
    "    def __init__(self,in_channels,out_channels,kernel_size):\n",
    "        super(SampaddingConv1D, self).__init__()\n",
    "        #self.padding = nn.ConstantPad1d((int((kernel_size-1)/2), int(kernel_size/2)), 0)\n",
    "        self.conv1d = torch.nn.Conv1d(in_channels=in_channels, out_channels=out_channels, kernel_size=kernel_size)\n",
    "    def forward(self, X):\n",
    "        #X = self.padding(X)\n",
    "        X = self.conv1d(X)\n",
    "        return X\n",
    "\n",
    "class two_layer_CNN(nn.Module):\n",
    "    def __init__(self,kernel1,kernel2,channel):\n",
    "        super(two_layer_CNN, self).__init__()\n",
    "        self.conv1 = SampaddingConv1D(1,channel,kernel1)\n",
    "        self.bn = nn.BatchNorm1d(num_features=channel)\n",
    "        self.conv2 = SampaddingConv1D(channel,1,kernel2)\n",
    "    def forward(self, X):\n",
    "        X = self.conv1(X)\n",
    "        X = self.bn(X)\n",
    "        X = F.relu(X)\n",
    "        X = self.conv2(X)\n",
    "        return X\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 137 iteration\n",
      "Already Get expected Result!\n",
      "We verify 1 times and success  1 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 183 iteration\n",
      "Already Get expected Result!\n",
      "We verify 2 times and success  2 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 179 iteration\n",
      "Already Get expected Result!\n",
      "We verify 3 times and success  3 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 167 iteration\n",
      "Already Get expected Result!\n",
      "We verify 4 times and success  4 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 144 iteration\n",
      "Already Get expected Result!\n",
      "We verify 5 times and success  5 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 114 iteration\n",
      "Already Get expected Result!\n",
      "We verify 6 times and success  6 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 88 iteration\n",
      "Already Get expected Result!\n",
      "We verify 7 times and success  7 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 104 iteration\n",
      "Already Get expected Result!\n",
      "We verify 8 times and success  8 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 184 iteration\n",
      "Already Get expected Result!\n",
      "We verify 9 times and success  9 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 156 iteration\n",
      "Already Get expected Result!\n",
      "We verify 10 times and success  10 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 143 iteration\n",
      "Already Get expected Result!\n",
      "We verify 11 times and success  11 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 199 iteration\n",
      "Already Get expected Result!\n",
      "We verify 12 times and success  12 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 203 iteration\n",
      "Already Get expected Result!\n",
      "We verify 13 times and success  13 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 167 iteration\n",
      "Already Get expected Result!\n",
      "We verify 14 times and success  14 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 63 iteration\n",
      "Already Get expected Result!\n",
      "We verify 15 times and success  15 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 179 iteration\n",
      "Already Get expected Result!\n",
      "We verify 16 times and success  16 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 101 iteration\n",
      "Already Get expected Result!\n",
      "We verify 17 times and success  17 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 93 iteration\n",
      "Already Get expected Result!\n",
      "We verify 18 times and success  18 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 174 iteration\n",
      "Already Get expected Result!\n",
      "We verify 19 times and success  19 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 306 iteration\n",
      "Already Get expected Result!\n",
      "We verify 20 times and success  20 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 116 iteration\n",
      "Already Get expected Result!\n",
      "We verify 21 times and success  21 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 553 iteration\n",
      "Already Get expected Result!\n",
      "We verify 22 times and success  22 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 95 iteration\n",
      "Already Get expected Result!\n",
      "We verify 23 times and success  23 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 256 iteration\n",
      "Already Get expected Result!\n",
      "We verify 24 times and success  24 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 80 iteration\n",
      "Already Get expected Result!\n",
      "We verify 25 times and success  25 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 102 iteration\n",
      "Already Get expected Result!\n",
      "We verify 26 times and success  26 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 113 iteration\n",
      "Already Get expected Result!\n",
      "We verify 27 times and success  27 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "not successful, loss =  1.7580463886260986\n",
      "Input X is : tensor([[[0.1586, 0.6630, 0.9579, 0.8810, 0.5929, 0.1102, 0.3848, 0.3950,\n",
      "          0.3951, 0.0861, 0.5953, 0.0801]]])\n",
      "Weight Q is  tensor([[[0.9281, 0.6857, 0.8970, 0.9492, 0.2386, 0.2079, 0.0783]]])\n",
      "We verify 28 times and success  27 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 120 iteration\n",
      "Already Get expected Result!\n",
      "We verify 29 times and success  28 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 190 iteration\n",
      "Already Get expected Result!\n",
      "We verify 30 times and success  29 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 392 iteration\n",
      "Already Get expected Result!\n",
      "We verify 31 times and success  30 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 105 iteration\n",
      "Already Get expected Result!\n",
      "We verify 32 times and success  31 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 187 iteration\n",
      "Already Get expected Result!\n",
      "We verify 33 times and success  32 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 101 iteration\n",
      "Already Get expected Result!\n",
      "We verify 34 times and success  33 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 77 iteration\n",
      "Already Get expected Result!\n",
      "We verify 35 times and success  34 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 69 iteration\n",
      "Already Get expected Result!\n",
      "We verify 36 times and success  35 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 100 iteration\n",
      "Already Get expected Result!\n",
      "We verify 37 times and success  36 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 146 iteration\n",
      "Already Get expected Result!\n",
      "We verify 38 times and success  37 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 116 iteration\n",
      "Already Get expected Result!\n",
      "We verify 39 times and success  38 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 91 iteration\n",
      "Already Get expected Result!\n",
      "We verify 40 times and success  39 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 105 iteration\n",
      "Already Get expected Result!\n",
      "We verify 41 times and success  40 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 167 iteration\n",
      "Already Get expected Result!\n",
      "We verify 42 times and success  41 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 142 iteration\n",
      "Already Get expected Result!\n",
      "We verify 43 times and success  42 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 346 iteration\n",
      "Already Get expected Result!\n",
      "We verify 44 times and success  43 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "at 146 iteration\n",
      "Already Get expected Result!\n",
      "We verify 45 times and success  44 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 213 iteration\n",
      "Already Get expected Result!\n",
      "We verify 46 times and success  45 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 97 iteration\n",
      "Already Get expected Result!\n",
      "We verify 47 times and success  46 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 197 iteration\n",
      "Already Get expected Result!\n",
      "We verify 48 times and success  47 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 191 iteration\n",
      "Already Get expected Result!\n",
      "We verify 49 times and success  48 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 91 iteration\n",
      "Already Get expected Result!\n",
      "We verify 50 times and success  49 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 159 iteration\n",
      "Already Get expected Result!\n",
      "We verify 51 times and success  50 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 132 iteration\n",
      "Already Get expected Result!\n",
      "We verify 52 times and success  51 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "not successful, loss =  0.1057349145412445\n",
      "Input X is : tensor([[[0.0140, 0.8167, 0.9336, 0.7736, 0.1019, 0.1306, 0.4000, 0.2341,\n",
      "          0.8010, 0.0758, 0.8775, 0.3567]]])\n",
      "Weight Q is  tensor([[[0.2423, 0.8446, 0.8410, 0.1707, 0.5862, 0.8878, 0.8932]]])\n",
      "We verify 53 times and success  51 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 150 iteration\n",
      "Already Get expected Result!\n",
      "We verify 54 times and success  52 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 78 iteration\n",
      "Already Get expected Result!\n",
      "We verify 55 times and success  53 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 213 iteration\n",
      "Already Get expected Result!\n",
      "We verify 56 times and success  54 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 160 iteration\n",
      "Already Get expected Result!\n",
      "We verify 57 times and success  55 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 213 iteration\n",
      "Already Get expected Result!\n",
      "We verify 58 times and success  56 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 137 iteration\n",
      "Already Get expected Result!\n",
      "We verify 59 times and success  57 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 378 iteration\n",
      "Already Get expected Result!\n",
      "We verify 60 times and success  58 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 154 iteration\n",
      "Already Get expected Result!\n",
      "We verify 61 times and success  59 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 190 iteration\n",
      "Already Get expected Result!\n",
      "We verify 62 times and success  60 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 566 iteration\n",
      "Already Get expected Result!\n",
      "We verify 63 times and success  61 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 215 iteration\n",
      "Already Get expected Result!\n",
      "We verify 64 times and success  62 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 135 iteration\n",
      "Already Get expected Result!\n",
      "We verify 65 times and success  63 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 115 iteration\n",
      "Already Get expected Result!\n",
      "We verify 66 times and success  64 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 229 iteration\n",
      "Already Get expected Result!\n",
      "We verify 67 times and success  65 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 123 iteration\n",
      "Already Get expected Result!\n",
      "We verify 68 times and success  66 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 87 iteration\n",
      "Already Get expected Result!\n",
      "We verify 69 times and success  67 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 576 iteration\n",
      "Already Get expected Result!\n",
      "We verify 70 times and success  68 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 128 iteration\n",
      "Already Get expected Result!\n",
      "We verify 71 times and success  69 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 495 iteration\n",
      "Already Get expected Result!\n",
      "We verify 72 times and success  70 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 249 iteration\n",
      "Already Get expected Result!\n",
      "We verify 73 times and success  71 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 122 iteration\n",
      "Already Get expected Result!\n",
      "We verify 74 times and success  72 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 128 iteration\n",
      "Already Get expected Result!\n",
      "We verify 75 times and success  73 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 117 iteration\n",
      "Already Get expected Result!\n",
      "We verify 76 times and success  74 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 237 iteration\n",
      "Already Get expected Result!\n",
      "We verify 77 times and success  75 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 93 iteration\n",
      "Already Get expected Result!\n",
      "We verify 78 times and success  76 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 245 iteration\n",
      "Already Get expected Result!\n",
      "We verify 79 times and success  77 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 91 iteration\n",
      "Already Get expected Result!\n",
      "We verify 80 times and success  78 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 329 iteration\n",
      "Already Get expected Result!\n",
      "We verify 81 times and success  79 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 152 iteration\n",
      "Already Get expected Result!\n",
      "We verify 82 times and success  80 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 403 iteration\n",
      "Already Get expected Result!\n",
      "We verify 83 times and success  81 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 633 iteration\n",
      "Already Get expected Result!\n",
      "We verify 84 times and success  82 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 129 iteration\n",
      "Already Get expected Result!\n",
      "We verify 85 times and success  83 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 421 iteration\n",
      "Already Get expected Result!\n",
      "We verify 86 times and success  84 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 184 iteration\n",
      "Already Get expected Result!\n",
      "We verify 87 times and success  85 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 164 iteration\n",
      "Already Get expected Result!\n",
      "We verify 88 times and success  86 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "at 105 iteration\n",
      "Already Get expected Result!\n",
      "We verify 89 times and success  87 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "not successful, loss =  0.034917160868644714\n",
      "Input X is : tensor([[[0.6959, 0.5729, 0.4727, 0.6347, 0.9924, 0.9635, 0.6785, 0.9656,\n",
      "          0.4446, 0.5854, 0.0659, 0.5282]]])\n",
      "Weight Q is  tensor([[[0.1762, 0.8259, 0.3964, 0.8246, 0.4939, 0.9077, 0.8352]]])\n",
      "We verify 90 times and success  87 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 118 iteration\n",
      "Already Get expected Result!\n",
      "We verify 91 times and success  88 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 107 iteration\n",
      "Already Get expected Result!\n",
      "We verify 92 times and success  89 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 106 iteration\n",
      "Already Get expected Result!\n",
      "We verify 93 times and success  90 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 146 iteration\n",
      "Already Get expected Result!\n",
      "We verify 94 times and success  91 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 139 iteration\n",
      "Already Get expected Result!\n",
      "We verify 95 times and success  92 times  \n",
      "\n",
      "kernel-size of first layer is : 2 and kernel-size of second layer is 6\n",
      "channle number is: 2\n",
      "at 101 iteration\n",
      "Already Get expected Result!\n",
      "We verify 96 times and success  93 times  \n",
      "\n",
      "kernel-size of first layer is : 5 and kernel-size of second layer is 3\n",
      "channle number is: 3\n",
      "at 123 iteration\n",
      "Already Get expected Result!\n",
      "We verify 97 times and success  94 times  \n",
      "\n",
      "kernel-size of first layer is : 3 and kernel-size of second layer is 5\n",
      "channle number is: 3\n",
      "at 133 iteration\n",
      "Already Get expected Result!\n",
      "We verify 98 times and success  95 times  \n",
      "\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 2\n",
      "at 84 iteration\n",
      "Already Get expected Result!\n",
      "We verify 99 times and success  96 times  \n",
      "\n",
      "kernel-size of first layer is : 4 and kernel-size of second layer is 4\n",
      "channle number is: 4\n",
      "at 94 iteration\n",
      "Already Get expected Result!\n",
      "We verify 100 times and success  97 times  \n",
      "\n"
     ]
    }
   ],
   "source": [
    "# running 100 times using correct_count to count the times that two layer network can get same result as one layer\n",
    "correct_count = 0\n",
    "Not_successfuL_list =[] \n",
    "for epo in range(100):\n",
    "    input_signal_length = 12\n",
    "    kernel_filter_length = 7\n",
    "    \n",
    "    # random depend the kernel size of two layer\n",
    "    kernel1 = randint(2, kernel_filter_length-1)\n",
    "    kernel2 = kernel_filter_length+1-kernel1\n",
    "    channel = min(kernel1,kernel2)\n",
    "    \n",
    "    #generate signal x\n",
    "    X = np.random.rand(input_signal_length)\n",
    "\n",
    "    #generate weight in a filter of 1D CNN\n",
    "    Q = np.random.rand(kernel_filter_length)\n",
    "\n",
    "    # expend dimention of signal to fit requirement of CNN\n",
    "    X_torch = torch.from_numpy(X).unsqueeze(0).unsqueeze(0)\n",
    "\n",
    "    # expend dimention of filter to fit requirement of CNN\n",
    "    Q_torch = torch.from_numpy(Q).unsqueeze(0).unsqueeze(0)\n",
    "\n",
    "    X_torch = X_torch.type(torch.FloatTensor)\n",
    "    Q_torch = Q_torch.type(torch.FloatTensor)\n",
    "    \n",
    "    deeplearning_conv_result = F.conv1d(X_torch ,Q_torch)\n",
    "\n",
    "    print('kernel-size of first layer is :',kernel1,'and kernel-size of second layer is',kernel2 )\n",
    "    print('channle number is:', channel )\n",
    "    two_layer_CNN_classifier = two_layer_CNN(kernel1,kernel2,channel)\n",
    "    optimizer = optim.Adam(two_layer_CNN_classifier.parameters(),lr=0.01)\n",
    "    scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, 'min', factor=0.5, patience=10, min_lr=0.00001)\n",
    "\n",
    "    \n",
    "    epoch = 3000\n",
    "    for i in range(epoch):\n",
    "        optimizer.zero_grad()\n",
    "        result = two_layer_CNN_classifier(X_torch)\n",
    "        output = torch.sum((deeplearning_conv_result-result)**2)\n",
    "        output.backward()\n",
    "        optimizer.step()\n",
    "        scheduler.step(output)\n",
    "        if output.item()< 0.0001*input_signal_length:\n",
    "            for param_group in optimizer.param_groups:\n",
    "                print('at',i+1,'iteration')\n",
    "                print('Already Get expected Result!')\n",
    "                correct_count = correct_count+1\n",
    "            break;\n",
    "        if i == (epoch-1):\n",
    "            print('not successful, loss = ',output.item())\n",
    "            not_successful_dict= {}\n",
    "            not_successful_dict['X'] = X_torch \n",
    "            not_successful_dict['Q'] = Q_torch\n",
    "            not_successful_dict['kernel1'] = kernel1\n",
    "            not_successful_dict['kernel2'] = kernel2\n",
    "            Not_successfuL_list.append(not_successful_dict)          \n",
    "            print('Input X is :',X_torch)\n",
    "            print('Weight Q is ',Q_torch)\n",
    "    print(\"We verify\",epo+1,'times and success ', correct_count, 'times  \\n')\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# change initial value and try failed tasks."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Input X is : tensor([[[0.1586, 0.6630, 0.9579, 0.8810, 0.5929, 0.1102, 0.3848, 0.3950,\n",
      "          0.3951, 0.0861, 0.5953, 0.0801]]])\n",
      "Weight Q is  tensor([[[0.9281, 0.6857, 0.8970, 0.9492, 0.2386, 0.2079, 0.0783]]])\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 4\n",
      "at 145 iteration, loss = 0.001155853969976306 lr =  0.01\n",
      "Already Get expected Result!\n",
      "\n",
      "Input X is : tensor([[[0.0140, 0.8167, 0.9336, 0.7736, 0.1019, 0.1306, 0.4000, 0.2341,\n",
      "          0.8010, 0.0758, 0.8775, 0.3567]]])\n",
      "Weight Q is  tensor([[[0.2423, 0.8446, 0.8410, 0.1707, 0.5862, 0.8878, 0.8932]]])\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 4\n",
      "at 108 iteration, loss = 0.0011096029775217175 lr =  0.01\n",
      "Already Get expected Result!\n",
      "\n",
      "Input X is : tensor([[[0.6959, 0.5729, 0.4727, 0.6347, 0.9924, 0.9635, 0.6785, 0.9656,\n",
      "          0.4446, 0.5854, 0.0659, 0.5282]]])\n",
      "Weight Q is  tensor([[[0.1762, 0.8259, 0.3964, 0.8246, 0.4939, 0.9077, 0.8352]]])\n",
      "kernel-size of first layer is : 6 and kernel-size of second layer is 2\n",
      "channle number is: 4\n",
      "at 114 iteration, loss = 0.0010895737214013934 lr =  0.0025\n",
      "Already Get expected Result!\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for not_successful_dict in Not_successfuL_list:\n",
    "    X_torch = not_successful_dict['X']\n",
    "    Q_torch = not_successful_dict['Q']\n",
    "    kernel1 = not_successful_dict['kernel1']\n",
    "    kernel2 = not_successful_dict['kernel2'] \n",
    "    \n",
    "    two_layer_CNN_classifier = two_layer_CNN(kernel1,kernel2,channel)\n",
    "    optimizer = optim.Adam(two_layer_CNN_classifier.parameters(),lr=0.01)\n",
    "    scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, 'min', factor=0.5, patience=10, min_lr=0.00001)\n",
    "    \n",
    "    deeplearning_conv_result = F.conv1d(X_torch ,Q_torch)\n",
    "    deeplearning_conv_result = deeplearning_conv_result.type(torch.FloatTensor)\n",
    "    \n",
    "    print('Input X is :',X_torch)\n",
    "    print('Weight Q is ',Q_torch)\n",
    "    print('kernel-size of first layer is :',kernel1,'and kernel-size of second layer is',kernel2 )\n",
    "    print('channle number is:', channel )\n",
    "    \n",
    "    \n",
    "    epoch = 2000\n",
    "    for i in range(epoch):\n",
    "        optimizer.zero_grad()\n",
    "        result = two_layer_CNN_classifier(X_torch)\n",
    "        output = torch.sum((deeplearning_conv_result-result)**2)\n",
    "        output.backward()\n",
    "        optimizer.step()\n",
    "        scheduler.step(output)\n",
    "        \n",
    "        \n",
    "        if output.item()< 0.0001*input_signal_length:\n",
    "            for param_group in optimizer.param_groups:\n",
    "                print('at',i+1,'iteration, loss =',output.item(), 'lr = ', param_group['lr'])\n",
    "                print('Already Get expected Result!\\n')\n",
    "                correct_count = correct_count+1\n",
    "            break;"
   ]
  },
  {
   "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
}
