{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Codes here shows how do we set the channel number \n",
    "# The there are two constrains:\n",
    "# 1. total number of parameter, in here the variable name is:\n",
    "paramenter_number_of_layer_list\n",
    "# 2. the largest length of kernels, in here the variable name is: \n",
    "largest_length_of_kernels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "paramenter_number_of_layer_list =  [1024, 229376]\n",
      "largest_length_of_kernels =  25\n"
     ]
    }
   ],
   "source": [
    "# it should be noticed that this \"paramenter_number_of_layer_list\" does not fully follow \n",
    "# the number parameter in each layer of FCN\n",
    "# the reason is that with larger kernel size and limited total parameter constrain, \n",
    "# we will have much less channel.\n",
    "# For the reason that the third layer of our nerual network only has kernel 1 and 2\n",
    "# less channel number mean it will have less parameters\n",
    "# for instance, in this example you will see, the largest_lenght_of_kernels = 60\n",
    "# the third will have only 252*36*(1+2) number of parameters\n",
    "# only around 1/3 number of paramets than the number of parameter in the third layer of FCN\n",
    "# Thus, we leave those extra number of parameter to the second layer of our model\n",
    "\n",
    "paramenter_number_of_layer_list = [8*128, 5*128*256 + 2*256*128] \n",
    "largest_length_of_kernels = 25  # for ECG200 dataset, the length is 100 thus, 100/4 =25 is the largest_length_of_kernels\n",
    "\n",
    "print('paramenter_number_of_layer_list = ',paramenter_number_of_layer_list)\n",
    "print('largest_length_of_kernels = ',largest_length_of_kernels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# generate prime number list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "prime number list =  [1, 2, 3, 5, 7, 11, 13, 17, 19, 23]\n"
     ]
    }
   ],
   "source": [
    "# getting primist list which is less than 30\n",
    "\n",
    "def get_Prime_number_in_a_range(start, end):\n",
    "    Prime_list = []\n",
    "    for val in range(start, end + 1): \n",
    "        prime_or_not = True\n",
    "        for n in range(2, val):\n",
    "            if (val % n) == 0:\n",
    "                prime_or_not = False\n",
    "                break\n",
    "        if prime_or_not:\n",
    "            Prime_list.append(val)\n",
    "    return Prime_list\n",
    "\n",
    "\n",
    "Prime_list = get_Prime_number_in_a_range(1,largest_length_of_kernels)\n",
    "print ('prime number list = ',Prime_list)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# The output of following code is the structure of OS-CNN based on the constains"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "kernels of layer 1 : (number of input channel, number of output channel, kernel size)\n",
      "\n",
      "[(1, 10, 1), (1, 10, 2), (1, 10, 3), (1, 10, 5), (1, 10, 7), (1, 10, 11), (1, 10, 13), (1, 10, 17), (1, 10, 19), (1, 10, 23)]\n",
      "\n",
      "kernels of layer 2 : (number of input channel, number of output channel, kernel size)\n",
      "\n",
      "[(100, 22, 1), (100, 22, 2), (100, 22, 3), (100, 22, 5), (100, 22, 7), (100, 22, 11), (100, 22, 13), (100, 22, 17), (100, 22, 19), (100, 22, 23)]\n",
      "\n",
      "kernels of layer 3 : (number of input channel, number of output channel, kernel size)\n",
      "\n",
      "[(220, 100, 1), (220, 100, 2)]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "def get_out_channel_number(paramenter_layer, in_channel, prime_list):\n",
    "    out_channel_expect = int(paramenter_layer/(in_channel*sum(prime_list)))\n",
    "    return out_channel_expect\n",
    "\n",
    "def generate_layer_parameter_list(start,end,paramenter_number_of_layer_list, in_channel = 1):\n",
    "    prime_list = get_Prime_number_in_a_range(start, end)\n",
    "    if prime_list == []:\n",
    "        print('start = ',start, 'which is larger than end = ', end)\n",
    "    input_in_channel = in_channel\n",
    "    layer_parameter_list = []\n",
    "    for paramenter_number_of_layer in paramenter_number_of_layer_list:\n",
    "        out_channel = get_out_channel_number(paramenter_number_of_layer, in_channel, prime_list)\n",
    "        \n",
    "        tuples_in_layer= []\n",
    "        for prime in prime_list:\n",
    "            tuples_in_layer.append((in_channel,out_channel,prime))\n",
    "        in_channel =  len(prime_list)*out_channel\n",
    "        \n",
    "        layer_parameter_list.append(tuples_in_layer)\n",
    "    \n",
    "    tuples_in_layer_last = []\n",
    "    first_out_channel = len(prime_list)*get_out_channel_number(paramenter_number_of_layer_list[0], input_in_channel, prime_list)\n",
    "    tuples_in_layer_last.append((in_channel,first_out_channel,start))\n",
    "    tuples_in_layer_last.append((in_channel,first_out_channel,start+1))\n",
    "    layer_parameter_list.append(tuples_in_layer_last)\n",
    "    return layer_parameter_list\n",
    "  \n",
    "\n",
    "\n",
    "layer_parameter_list = generate_layer_parameter_list(1,largest_length_of_kernels,paramenter_number_of_layer_list)\n",
    "\n",
    "\n",
    "for i, layer_parameter in enumerate(layer_parameter_list):\n",
    "    print('kernels of layer',i+1,': (number of input channel, number of output channel, kernel size)',end = '\\n\\n')\n",
    "    print(layer_parameter,end = '\\n\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def calculate_mask_index(kernel_length_now,largest_kernel_lenght):\n",
    "    right_zero_mast_length = math.ceil((largest_kernel_lenght-1)/2)-math.ceil((kernel_length_now-1)/2)\n",
    "    left_zero_mask_length = largest_kernel_lenght - kernel_length_now - right_zero_mast_length\n",
    "    return left_zero_mask_length, left_zero_mask_length+ kernel_length_now\n",
    "\n",
    "def creat_mask(number_of_input_channel,number_of_output_channel, kernel_length_now, largest_kernel_lenght):\n",
    "    ind_left, ind_right= calculate_mask_index(kernel_length_now,largest_kernel_lenght)\n",
    "    mask = np.ones((number_of_input_channel,number_of_output_channel,largest_kernel_lenght))\n",
    "    mask[:,:,0:ind_left]=0\n",
    "    mask[:,:,ind_right:]=0\n",
    "    return mask\n",
    "\n",
    "def insert_column(a,index,b):\n",
    "    a_shape = a.shape\n",
    "    b_shape = b.shape\n",
    "    z = np.ones([a.shape[0],a_shape[1]+b_shape[1]])\n",
    "    z[:,index:index+b.shape[1]] = b\n",
    "    z[:,0:index] = a[:,0:index]\n",
    "    z[:,index+b.shape[1]:] = a[:,index:]\n",
    "    return z"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "prime_list = get_Prime_number_in_a_range(1,89)\n",
    "max_kernel_size = prime_list[-1]\n",
    "temp_list= []\n",
    "for i in prime_list:\n",
    "    z = np.squeeze(creat_mask(2,1,i,max_kernel_size), axis=1)\n",
    "    temp_list.append(z)\n",
    "prime_layer = np.concatenate(temp_list,0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "dilation = np.ones([prime_layer.shape[0],5])*0\n",
    "dilation_prime_layer= insert_column(prime_layer,1,dilation)\n",
    "for i in range(1,15):\n",
    "    dilation_prime_layer = insert_column(dilation_prime_layer,i*11+1,dilation)\n",
    "\n",
    "f = plt.figure(figsize=(20,3))\n",
    "ax1 = plt.subplot2grid((1,2),(0,0))\n",
    "ax2 = plt.subplot2grid((1,2),(0,1))\n",
    "\n",
    "ax1.matshow(prime_layer)\n",
    "ax1.set_title('The layer with multipe prime size kernels') \n",
    "ax2.matshow(dilation_prime_layer)\n",
    "ax2.set_title('The dialiated layer with multipe prime size kernels') \n",
    "f.savefig(\"./mask_layer.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
