{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# This code calculate how much parameter is used for OS-design\n",
    "# the number of parameter is calculated by this function:\n",
    "\n",
    "calcualte_total_number_of_parameter_for_prime_number(Prime_list, N)\n",
    "\n",
    "# you could scroll down to see the image result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\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",
    "def calcualte_total_number_of_parameter_for_prime_number(Prime_list, N):\n",
    "    # this part is for speed up calculation\n",
    "    # for instance if the prime list is [1, 2, 3, 5, 7]\n",
    "    # The even number we want to get is [2, 4, 6, 8, 10] (with 1 and 2 in the third layer, it will be any integer)\n",
    "    # to obtain [2, 4, 6, 8, 10] we need 1+1=2, 1+3=4 1+5=6 1+7=8 3+7=10\n",
    "    # for the reason that the channel number is min(a,b)\n",
    "    # the channel number for 3 should be 3\n",
    "    # the calculation result should be \n",
    "    #    first layer = 1+2+3+5+7\n",
    "    #    second layer = 1+2+3+5+7\n",
    "    #    extar channel for 3*(3-1) # -1 is because the first layer has one channel  #\"1.2_from\"\n",
    "    #    result = first layer + second layer + extra channle = 18+18+6 = 42\n",
    "    Prime_list = np.asarray(Prime_list)\n",
    "    Prime_list_row =np.expand_dims(Prime_list, axis=0)\n",
    "    Prime_list_column =np.expand_dims(Prime_list, axis=1)\n",
    "    all_sum_result = Prime_list_row + Prime_list_column\n",
    "\n",
    "    #list_1 = np.asarray([(i+1)*2 for i in range(int((Prime_list[-1]+1)/2))])\n",
    "    list_1 = np.asarray([(i+1)*2 for i in range(int(N/2))])\n",
    "    #print(list_1)\n",
    "    number_of_parameter = sum(Prime_list)*2\n",
    "\n",
    "    for i in range(len(Prime_list)):\n",
    "        list_2 = all_sum_result[i]\n",
    "        common_element = np.intersect1d(list_1,list_2)\n",
    "        if len(common_element)!=0:\n",
    "            number_of_parameter = number_of_parameter+Prime_list[i]*(Prime_list[i]-1)*len(common_element)\n",
    "            #print(Prime_list[i],end='\\t')\n",
    "        list_1 = np.setdiff1d(list_1,common_element)\n",
    "        if len(list_1)==0:\n",
    "            break\n",
    "    return number_of_parameter\n",
    "\n",
    "def calculate_total_number_of_parameter_for_using_all_sizes_of_kernel(N):\n",
    "    purally_using_kernel = (N*(1+N))*0.5\n",
    "    return purally_using_kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "42\n"
     ]
    }
   ],
   "source": [
    "# check the function calcualte_total_number_of_parameter_for_prime_number is correct\n",
    "print(calcualte_total_number_of_parameter_for_prime_number([1,2,3,5,7],10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/tangw/anaconda3/envs/python35/lib/python3.6/site-packages/ipykernel_launcher.py:30: UserWarning: Matplotlib is currently using module://ipykernel.pylab.backend_inline, which is a non-GUI backend, so cannot show the figure.\n"
     ]
    },
    {
     "data": {
      "image/png": "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BPS4syg1TdOsLKcYZfIFGLsWXApf2CunKOXQtu40cbuxUnppoQtXlgJXrlzhm2++yX2ft9hjSQkODmbHjh2572fMmMGcOXMK2aNg+S0NUBxyznP27FmGDRtWaN/PP/+c1NTU3PcPPPBAvvXPblVsbCxBQUG0bt2abdu23dYxlFJ88MEHNGvWjObNm9O9e3fCwsJyt8+aNQtfX1/8/Pzw8fFh5Up9B7jcMJlg5dMQtctcjNL95iN990cn4Oxkh1fNKjfta026/EspkJNcnn766WI9T2El9oODg6latSr33HMPABMmTCjWWAqSnZ2Nra3tLe1Tv3793NpkBfn888955JFHqFzZfAshp4jmndq8eTO+vr58//33Fu9z/Wf8+uuv2bFjB/v376dy5cps2LCBAQMGEBYWRlxcHB9++CF79uyhevXqJCcno4fTlyPB/4ZDy+C+d8F7kEW7HIi+gp97dWxK4fDjvPSVSykwZcoUTpw4QUBAAJMnTwYgOTmZYcOGcddddzFq1ChyJruGhobStWtX2rZtS+/evTl3zjzVZ9++fXTo0AE/Pz8GDx5MfHw8AN26deOFF14gMDCQL774gtjYWIYOHUq7du1o164df/75J5GRkcyYMYPPPvuMgIAAtm3bds2CYMePH+e+++7D39+fNm3acOLECZKTk+nRowdt2rTB19f3pn9NR0ZG5n6Wli1bMmzYsNwrCU9PT1577TXatGnDkiVLCiz1f+rUKe6++258fX158803rzl2Tq2y7OxsXnnlFXx8fPDz82P69Ol8+eWXnD17lu7du9O9e/fcc+Yswvbpp5/i4+ODj48Pn3/+ee4xC1qKIMe+fft49dVXWblyJQEBAVy9epUFCxbg6+uLj48Pr732T8GIqlWr8vLLL+Pv78/OnTuvOc5HH33EV199lZv4evXqxT333MO8efO4ePEizs7OuVdpVatW1UU9y4s9c2Hrf6H1o9DxBYt2ScvM5si5JPzcS+dD/Lz0lct1Pvr7I45cLnzdklt1l+tdvNa+4Mo006ZN49ChQ7lFIoODg9m7dy9hYWHUr1+fjh078ueffxIUFMRzzz3HypUrcXNzY9GiRbzxxhvMmjWL0aNHM336dLp27crbb7/Ne++9l/uLMiMjg5yqBCNHjuTFF1+kU6dOnDlzht69exMeHs6ECROoWrUqr7xirri6efPm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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "OS_CNN_parameter_number_list = []\n",
    "single_scale_parameter_number_list = []\n",
    "perdict_1_list =[]\n",
    "perdict_list = []\n",
    "\n",
    "for i in range(6,200):\n",
    "    largest_length_of_kernels = i\n",
    "    Prime_list = get_Prime_number_in_a_range(1,largest_length_of_kernels)\n",
    "    #print(Prime_list)\n",
    "    OS = calcualte_total_number_of_parameter_for_prime_number(Prime_list,largest_length_of_kernels)\n",
    "    single = calculate_total_number_of_parameter_for_using_all_sizes_of_kernel(largest_length_of_kernels)\n",
    "    \n",
    "    OS_CNN_parameter_number_list.append(OS)\n",
    "    single_scale_parameter_number_list.append(single)\n",
    "    perdict_list.append(1.2*i*i/(np.log(i)))  #1.2 comes from here: Search \"1.2_from\" in this page \n",
    "    perdict_1_list.append(i*i/2)\n",
    "    \n",
    "fig= plt.figure()\n",
    "ax = fig.add_subplot(1, 1, 1)\n",
    "ax.plot(OS_CNN_parameter_number_list,label='OS')\n",
    "ax.plot(single_scale_parameter_number_list,label='all kernel size')\n",
    "ax.plot(perdict_list,label='theoretical prediction for OS')\n",
    "#ax.plot(perdict_1_list,label='theoretical predict for single kernel')\n",
    "\n",
    "ax.set_ylabel('Number of parameter')\n",
    "ax.set_xlabel('Largest scale')\n",
    "ax.legend()\n",
    "fig.show()\n",
    "path = './model_size_compare.pdf'\n",
    "fig.savefig(path,bbox_inches = 'tight')"
   ]
  },
  {
   "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
}
