{
 "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+7=10) should be 3 channle for kernel of size 3 and 1 for kenel of size 7\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  \n",
    "    # \"1.2_from\" this kind of model size increase is about 1.2\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": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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MZHY2Ngcid3kAwtfh/XT4MaXIbSnv6PJUXbnkg8888wz7Nixg4iICJ588kkAEhMT6du3L02aNGHQoEGkT3ZduXIl119/Pa1bt+amm27iwIEDAKxZs4Z27drRokULevXqxfHjTpm1Dh068OijjxIZGcn7779PbGwsffr04corr+TKK6/kl19+ITo6mlGjRvHuu+8SERHB4sWLz1gQbPv27dx4442Eh4fTqlUrduzYQWJiIp06daJVq1aEhYVl+9d0dHR0xndp2rQpffv2zbiTqFu3Lk8//TStWrViypQp5y31v2vXLq666irCwsJ4/vnnzzh3eq0yj8fDE088QfPmzWnRogUffvghH3zwAfv376djx4507Ngx45rpi7C98847NG/enObNm/Pee+9lnPN8SxGkW7NmDU899RSzZs0iIiKCU6dOMXHiRMLCwmjevDlPP/1HwYiyZcvy+OOPEx4eztKlS884z5tvvsm///3vjMTXpUsXrr76aiZMmMDhw4cpV65cxl1a2bJlrahnYbFqPCx6C1oOhvaP+juanKeqRerVunVrPdvGjRsz3r+x/A0d+t3QHH29sfyNP10zs127dmloaGjG559++knLly+ve/fuVY/Ho+3atdPFixdrSkqKXnXVVXr48GFVVZ00aZIOGzZMVVXDwsJ04cKFqqr6wgsv6COPPKKqqtdff72OHDky49wDBw7UxYsXq6rq7t27tUmTJqqq+tJLL+lbb72VsV/mz23atNHp06erquqpU6f05MmTmpqaqnFxcaqqGhsbqw0aNFCv16uqqmXKlDnndwR0yZIlqqo6bNiwjPPXqVNH33zzzYx9b7jhBt26dauqqi5btkw7duyoqqrdunXTsWPHqqrqv//974zrZP7v9/HHH2ufPn00NTVVVVWPHj2acY3Y2NiMa6R/joqK0ubNm2tiYqImJCRos2bNdNWqVbpr1y4NDAzU1atXq6rq7bffruPHj//T9/r888/1gQceUFXVmJgYrV27th4+fFhTU1O1Y8eOOmPGDFVVBXTy5Ml/Oj4uLk4rVar0p/b33ntPH3vsMU1LS9MuXbpo7dq1dejQoTp79uw/7at65s+wKQC2/qj6ciXVsT1U01L8HY1PgCi9gN+19lgsn2rTpg21ajnzRyMiIoiOjqZixYqsX7+ezp07A85f6TVq1CAuLo4TJ05w/fXXAzBkyJAzSuX3798/4/38+fPZuHFjxuf4+HgSExPPG0dCQgIxMTH06tULgJIlSwKQmprKc889x6JFiwgICCAmJoZDhw5x+eWXn/dctWvXpn379gDceeedfPDBBzzxxBNnxJhVqf9ffvmFadOcQYWDBw8+484g8/e77777Mh7/Va5c+bzxACxZsoRevXplVIru3bs3ixcvpnv37udciiArK1asoEOHDqRP1B00aBCLFi2iZ8+eBAYG0qdPnyyPP5fAwEC+//57VqxYwYIFC3jsscdYuXIlL7/88gWfy+QT+9fA13dB9WbQf3yBH3J8PpZczvJ0m/xR+/LsMvhpaWmoKqGhoX96rBIXF5fluTKX2Pd6vSxbtiwjSVysCRMmEBsby8qVKwkKCqJu3brZLhMgZ00Iy/w5PcbsSv2ffY7cdK6lCC5WyZIlz9mXVL58ecqUKcPOnTupX79+Rnv6409wvnObNm1o06YNnTt3ZtiwYZZcCqrju50hx6Urw6CpUKKcvyPKNdbnkg+UK1eOhISEbPdr3LgxsbGxGcklNTWVDRs2UKFCBSpVqpQxWmn8+PEZv5jO1qVLFz788MOMz+m/xM8XQ7ly5ahVq1ZGpeLk5GSSkpKIi4vjsssuIygoiJ9++ondu3dnG/+ePXsyYv/qq6+45ppr/rRPVqX+27dvz6RJkwAnuZ1L586d+c9//kNaWhoAx44dy/L7XXvttcycOZOkpCROnjzJjBkzuPbaa7P9LufSpk0bfv75Z44cOYLH42HixInn/d8hsyeffJKHH344I3nNnz+fJUuWcMcdd7B//35WrVqVse+aNWuoU6dwDFUtcpKOwZd9wJMMd06Dcue/yy8MLLnkA1WqVKF9+/Y0b948o0P/XIoXL87UqVN5+umnCQ8PJyIiImP48NixY3nyySdp0aIFa9as4cUXXzznOT744AOioqJo0aIFzZo1Y9SoUQB069aNGTNmZHToZzZ+/Hg++OADWrRowdVXX83BgwcZNGgQUVFRhIWFMW7cOJo0aZLt92zcuDEfffQRTZs25fjx44wcOfKc+02YMIHPPvuM8PBwQkNDMwYLvP/++3z00UeEhYURExNzzmPvuecegoODadGiBeHh4Rnr24wYMYKuXbtmdOina9WqFUOHDqVNmza0bduWe+65h5YtW2b7Xc6lRo0avPHGG3Ts2JHw8HBat25Njx49sj3uoYce4sorryQsLIzGjRvz6quvMmvWLEqVKkVqaipPPPEETZo0ISIigsmTJ/P+++9fVHzGj9LL55/YDQMnQbXG2R9TwOVqyf38yEru+0d0dDS33XYb69ev93cohZL9DOdjXg9MGQKb5sDtn0NoL39HdFEKSsl9Y4wp/FRh3nOw6Ru46Z8FNrFcDHssZvJE3bp17a7FFD1LP4Llo6DdA3BV7k6Szm8subiK2uNBU3jYz24+tX4a/PA3aNbTWfSriLHkgjNM9OjRo/Z/UlPgqCpHjx695KHlJodFL4EZ90Hw1U7NsICi96vW+lyAWrVqsW/fPqvZZAqkkiVLZky4NfnAwXUwcSBUqgcDJkBQ0Uz8llyAoKAgq9dkjLl0x3bB+N7O5MjB053JkkVUbq5EOUZEDovI+kxtL4tIjIiscV+3ZNr2rIhsF5EtInJTpvaubtt2EXkmU3s9EVnutk8WkeK59V2MMSZbCYdgfC/wpsLgGVChaN9NZplcRCRARPpd5Lm/ALqeo/1dVY1wX3Pd6zTDWf441D3mYxEJFJFA4CPgZqAZMNDdF+BN91wNgePA8LMvZIwxeeJ0HEzo4yz4NWhqkZgkmZ0sk4uqeoGnLubEqroIOObj7j2ASaqarKq7gO1AG/e1XVV3qmoKMAnoIU6BqRuA9EU8xgKFazEEY0zBkHoaJt4Bhzc5hSgL0YJfl8KXx2LzReQJEaktIpXTX5dwzQdF5Hf3sVklt60msDfTPvvctvO1VwFOqGraWe3GGJN3vB6YNhx2L3FGhTW80d8R5Ru+JJf+wAPAImCl+4rK8ojz+wRoAEQAB4B/XeR5LoiIjBCRKBGJshFhxpgcoQpzHoPNc6DrmxCW9VLbRU22o8VUNceGUanqofT3IvJfYI77MQaonWnXWm4b52k/ClQUkWLu3Uvm/c913dHAaHBqi13i1zDGGPjfa7BqLFz3JLTzz7Lg+Vm2dy4iUlpEnheR0e7nEBG57WIuJiI1Mn3sBaSPJJsNDBCREiJSDwgBfgNWACHuyLDiOJ3+s91V0X4C0v9UGAJkvc6uMcbklGWfwOK3ofVQ6Pg3f0eTL/kyz+VznEdhV7ufY4Ap/HHXcU4iMhHoAFQVkX3AS0AHEYkAFIgG/gKgqhtE5GtgI5AGPKCqHvc8DwLzgEBgjKpucC/xNDBJRF4DVgOf+fBdjDHm0vz+NXz/DDTtBre+A3m4gF1Bkm3JfRGJUtVIEVmtqi3dtrWqGp4nEeawc5XcN8YYn2z5HiYPguCrnCHHRWj2/YWW3PelQz9FRErh3G0gIg2A5IuMzxhjCqZdi+Dru+DyMBjwVZFKLBfDl8diLwPfA7VFZALQHhiWm0EZY0y+sncFfDUAqjSAO6dDyfL+jijf82W02A8ishJoBwjwiKoeyfXIjDEmPzi4zpl9X666U9alCNcLuxC+jBZboKpHVfVbVZ2jqkdEZEFeBGeMMX51ZBuM6wnFy8Fds6Dc5f6OqMA4752LiJQESuOM9qqEc9cCUB6bDW+MKeyO74ZxPZzRYHfNgorB/o6oQMnqsdhfgEeBK4BVmdrjgX/nZlDGGONXCQedxJKSCEPnQtWG/o6owDlvclHV94H3ReQhVf0wD2Myxhj/OXnUeRR2Mta5Y7m8ub8jKpB8GYo8Jqdm6BtjTL52Oh6+7A3Hd8HASVbh+BL4lFyAFM6cof9arkVkjDH+kJIEX/WHQ+uh3ziod62/IyrQfEkuDVT1/4BUAFVN4o/OfWOMKfhST8OkO2DvMujzKTS6KftjTJZshr4xpmhLS3ZKuuxcCD0+gtBe/o6oUPBlhv5L/HmG/tDcDMoYY/JEWgpMHgzb50P3DyHiDn9HVGj4MkP/RxFZhc3QN8YUJp5UmDIUts2D296FVnf5O6JCxZfHYuBMmgwEigPXiUjv3AvJGGNymScVpt4NW76FW96GyLv9HVGhk+2di4iMAVoAGwCv26zA9FyMyxhjcocnDaaPgE2z4aZ/Qpt7/R1RoeRLn0s7VW2W65EYY0xu83pg5kjYMB06vwpX3e/viAotXx6LLRWRC04uIjJGRA6LyPpMbW+JyGYR+V1EZohIRbe9roicEpE17mtUpmNai8g6EdkuIh+IOMu+iUhlEflRRLa5/1a60BiNMUWI1wuzHoR1X0OnF6H9w/6OqFDzJbmMw0kwW9yksE5EfvfhuC+Arme1/Qg0V9UWwFbg2UzbdqhqhPu6L1P7J8C9QIj7Sj/nM8ACVQ0BFrifjTHmz7xe+OZhWPuVs+b9tY/7O6JCz5fHYp8Bg4F1/NHnki1VXSQidc9q+yHTx2VA36zOISI1gPKqusz9PA7oCXwH9AA6uLuOBRYCT/sanzGmiPB64du/wurxcN1TcP1T/o6oSPAlucSq6uxcuPbdwORMn+uJyGqcqsvPq+pinFFq+zLts48/yv1XV9UD7vuDQPVciNEYU5B5vTDnEVg1Dq55DDo+5++IigxfkstqEfkK+IZMM/NV9aJHi4nI34A0YILbdAAIVtWjItIamCkiob6eT1VVRDSL640ARgAEB9uaDMYUCV4PzH4I1kyA6550HoeJVa7KK74kl1I4SaVLpraLHoosIkOB24BOqqoAqprsXgNVXSkiO4BGOEUya2U6vJbbBnBIRGqo6gH38dnh811TVUcDowEiIyPPm4SMMYWEJ80ZFbbua+jwHHSwJ+Z5zZcZ+sNy6mIi0hV4CrjeLYCZ3l4NOKaqHhGpj9Nxv1NVj4lIvIi0A5YDdwHpa8vMBoYAb7j/zsqpOI0xBZgn1ZnHsmE63PACXPeEvyMqknyZRFkSGA6EAiXT21U1yymtIjIRp8O9qojsw6lR9ixQAvjRHVG8zB0Zdh3wioik4gwauE9Vj7mnuh9n5FkpnI7879z2N4CvRWQ4sBvol/3XNcYUamkpMG24M0Gy8yvQ/hF/R1Rk+fJYbDywGbgJeAUYBGzK7iBVHXiO5s/Os+80YNp5tkUBf1oKTlWPAp2yi8MYU0SkJcOUYU5Jl5teh6se8HdERZov81waquoLwElVHQvcCrTN3bCMMeYCpJ52qhtv+RZufssSSz7gy51LqvvvCRFpjjPs97LcC8kYYy5A6imYNAh2LHCqG1sRynzBl+Qy2i2t8jxOJ3pZ4IVcjcoYY3yRkgQTB8CuRc56LFY2P9/IMrmISAAQr6rHgUVA/TyJyhhjsnM6Dr4aAHuWQs+PbaGvfCbLPhdV9eIMHTbGmPzj5FEY2w32/easeW+JJd/x5bHYfBF5AqdUy8n0xkxDhY0xJu/E74fxveB4NAz4Chrd5O+IzDn4klz6u/9mHn6h2CMyY0xeO7YLxvWApKMwaCrUu9bfEZnz8GWGfr28CMQYY7J0eDOM7+mMDrtrNtRq7e+ITBZ8uXPBHYLcjDNn6I/LraCMMeYM+1fD+N4QGATDvoPqtjhufudL+ZeXcMq4NAPmAjcDS3AWETPGmNy1+1f4qj+UrAh3zYQqDfwdkfGBLzP0++KUWTnoFrEMByrkalTGGAOwbb5zx1K2Otz9nSWWAsSX5HLKHZKcJiLlcUrb187dsIwxRd7GWc4EyaoNnUdhFWplf4zJN3zpc4kSkYrAf4GVQCKwNFejMsYUbVGfO0sT14yEQVOgVEV/R2QukC+jxe53344Ske9x1rT/PXfDMsYUSaqw6C346R/QsDP0GwvFy/g7KnMRfB0t1hu4Bmd+yxLAkosxJmd5PfDd07Div9BiAPT4tzM6zBRIvowW+xhoCEx0m/4iIjeqqtW0NsbkjLRkZ/XIjTPh6ofhxr9DgC9dwia/8uV/vRuAm1T1c1X9HLjFbcuWiIwRkcMisj5TW2UR+VFEtrn/VnLbRUQ+EJHtIvK7iLTKdMwQd/9tIjIkU3trEVnnHvOBuMtbGmMKkNPxMKGvk1iBACocAAAgAElEQVS6vAZdXrXEUgj48r/gdiA40+fabpsvvgC6ntX2DLBAVUOABe5ncObPhLivEcAn4CQjnCWS2wJtgJfSE5K7z72Zjjv7WsaY/CzxMIy9zZnL0ms0XP2QvyMyOcSX5FIO2CQiC0XkJ2AjUF5EZovI7KwOVNVFwNkFLnsAY933Y4GemdrHqWMZUFFEauAsr/yjqh5zS///CHR1t5VX1WWqqjiTOntijCkYju2Cz7rAkW0wcBKE98/+GFNg+NKh/2IOX7O6qh5w3x8EqrvvawJ7M+23z23Lqn3fOdqNMfldzCr4qp/TiT/kG6gV6e+ITA7zZSjyz7l1cVVVEdHcOn86ERmB86iN4ODgbPY2xuSqLd/D1GFQpppT2bhaI39HZHKBP3rNDrmPtHD/Pey2x3DmzP9abltW7bXO0f4nqjpaVSNVNbJatWo58iWMMRdhxWcwaSBUawz3zLfEkkc2H4xn+BcriD5yMvudc4g/kstsIH3E1xBgVqb2u9xRY+2AOPfx2Tygi4hUcjvyuwDz3G3xItLOHSV2V6ZzGWPyE68XfnzJmXUf0gWGfgtlL/N3VEXGxOV7WLztCBVK5d28ofMmFxFZ4P775sWeXEQm4pSKaSwi+0RkOPAG0FlEtgE3up/Bqbi8E2ck2n+B+yFjxctXgRXu65VMq2DeD3zqHrMD+O5iYzXG5JK0ZJh+L/zyHkQOh/4TbNZ9HjqV4mH66hhuDrucSmWK59l1s+pzqSEiVwPdRWQScMYcElVdld3JVXXgeTZ1Ose+ypmrXWbeNgYYc472KKB5dnEYY/zk1HGYdCfsXgI3vgztHwWbjpanvl13gITTaQxsk7f9zVkllxeBF3D6Mt45a5vi40RKY0wRdWIPfNkXju+CPp9BWF9/R1SkrIg+xkc/bWfTgXjqVy1D23qV8/T6500uqjoVmCoiL6jqq3kYkzGmoNsXBRMHgicZBs+Autf4O6Ii518/bGHD/ngaXlaWe6+tT14XMPFlKPKrItIduM5tWqiqc3I3LGNMgbV+GswYCeVrwB1znJFhJk/tiE1k2c5jPNW1Mfd3aOiXGLIdLSYi/wQewZmZvxF4RERez+3AjDEFjCosfBOm3g01W8M9/7PE4icTl++hWIBwe+s/ZnEke5LzNAZfZujfCkS4q1EiImOB1cBzuRmYMaYAST0Nsx+EdVMgfCB0ex+KlfB3VEXCxwu3s3BLLF6v4lHF61W2HkrkptDLqVauBHHJcXy+/nOmb5vOlG5TqF6mevYnzQE+recCVOSPGmEVcikWY0xBlBgLk+6Afb9Bpxfhmr/aiLA8cjj+NO/8sJXalUtTo0JJAgOEABGuCanK0Gsv48PVHzJh0wSSUpPoWq8rSq4XRMngS3L5J7DaLVopOH0vz2R9iDGmSDi0ESb2dxLM7WMh1GrH5qXJK/aS5lU+GxJJ/WplAYhPiWf8xvE8vORLElMT6VynMyPDRxJSKSRPY/OlQ3+iiCwErnSbnlbVg7kalTEm/9v2I0wZBsVLw7BvnX4Wk2c8XmXib3to37AK9auVJSElgS83fsn4jeNJSE2gc53O/KXFX2hc2T/9Xj49FnNLrWRZXt8YU0Sowi/vw/yX4fLmTrn8CrWyPczkDI9XufPT5Ww9lMDRkyk8dUsdRq0dxbiN40hISaBTcCdGho/0W1JJ52ufizHGQOopmP2Q03Ef2gt6fGSlXPLYwi2HWbrzKDc0LU9q2d94a+PrxKfE07F2R0aGj6Rplab+DhGw5GKM8VXcPqfj/sDv1nHvR18s20ylKxaxtfgvxCXG0aFWB0ZGjKRZlWb+Du0MWSYXEQkENqhqkzyKxxiTH+1eCl8PdoYcD5wIjW/2d0RFTlJqEh+vGstq7xdIhSQiLruekeEjCa0a6u/QzinL5KKqHhHZIiLBqronr4IyxuQjK7+Ab5+AirWdUvk2MTJPxSfHM3HzJMZtHE98ygm8p5vwya3PcH3d/D2AwpfHYpWADSLyG5Cx0oyqds+1qIwx/udJhe+fgRWfQoNO0PczKFXJ31EVCnuPJbF67wlUFY9X8Sp43QmQp1I9xBw/xYnkE2w5NZfo1HkQcJq0xMYUix/Mm7fcxvV1r/D3V8iWL8nlhVyPwhiTvyQchClDYc9SuPphp1x+QKCfgyocvF5l2Bcr2H448ZzbJTCBUlV/IbDiUghIpmpgJNdU7U+NOg3pEVGTmhVL5XHEF8eXeS4/i0gdIERV54tIacB+yowprHYvhSlDIDkBen8KLW73d0SFyuLtR9h+OJEXb2tGh8bVCBBnVv3R5ENM3zGBudEzSdNUutbtyr1h99Kwkn8KT16qbJOLiNwLjAAqAw2AmsAozrHgly9EpDEwOVNTfZy1YyoC9wKxbvtzqjrXPeZZYDjgAR5W1Xlue1fgfZxk96mqvoEx5uKowvJR8MPzUDHYKZVfPX92FhdkY5bsolq5EtzZrg7FiwWwN2EvY9aPYeb2maDQrUE3hocNp075Ov4O9ZL48ljsAaANsBxAVbeJyEUvfq2qW4AIyBiNFgPMAIYB76rq25n3F5FmwAAgFLgCmC8ijdzNHwGdgX3AChGZraobLzY2Y4qslJMw+2FYPxUa3wK9RkFJKyOYk96at5nVe07w646jPN65ETEnd/Ppuk/5due3BEgAfUL6cHfzu7mibP7vT/GFL8klWVVT0heaEZFikGPVzzoBO1R1dxYL2fQAJqlqMrBLRLbjJDuA7aq6041rkruvJRdjLsSR7c4w49jNzvyV9o9BQLarcZgLsPlgPB/9tIMG1crQpnES2/iEHjPnUyKwBHc0vYOhoUO5rPRF/82eL/mSXH4WkeeAUiLSGbgf+CaHrj8AmJjp84MichcQBTyuqsdxHsMty7TPPrcNYO9Z7W1zKC5jiobN38KM+yCgGNw5DRrY6uW54dNFOylVfid1Qtey4tBy9h4qy/Cw4QxuNpjKJfN2+eG84ktyeQanv2Md8BdgLvDppV5YRIoD3YFn3aZPgFdx7opeBf4F3H2p13GvNQKn34jg4OCcOKUxBZsnFf73qlMj7IqW0G+8M4/F5Kg0TxqTN37Hd8c/pljNfeyKr8pjrR/j9ka3U654OX+Hl6t8GS3mdRcIW47zi3+LqubEY7GbgVWqesi9zqH0DSLyXyB9KeUYIPNPfS23jSzaz/4Oo4HRAJGRkXm3oIEx+VHcPme1yL3LofUw6PoGBJX0d1QF1oroYzwwYRXJaV68XsWrikdTodxKAiv9TEDxIxBQhZHNn2Z4xO2UCCwai6j5MlrsVpzRYTtw1nOpJyJ/UdXvLvHaA8n0SExEarjVlwF6Aevd97OBr0TkHZwO/RDgNzeWEBGph5NUBgB3XGJMxhRuW+fBjL84dy59PoOwvv6OqMB7f/42PF6lV8uapJFEdPICtp6eyynvcSoXq8fVVe+mf7NbiKhdxd+h5ilfHov9C+ioqtsBRKQB8C1w0clFRMrgjPL6S6bm/xORCJy7o+j0baq6QUS+xumoTwMeUFWPe54HgXk4Q5HHqOqGi43JmEIt82Ow6mHQbyxUaeDvqAq89TFxLNl+hIc6X05QpQVM2jyJhNQE2tZoy/Dmw2lXox1ZDFYq1CS7J1wiskJVr8z0WYDfMrcVJJGRkRoVFeXvMIzJO5kfg0UOh5tet8dgPjqamEz00ZN4FbdMi+L1OqVaklLS+HTZb2w+NYcSlVaT6knhxjo3Mrz58HxbTPJSiMhKVY30df/z3rmISG/3bZSIzAW+xrmruB1YcUlRGmPyxtYfYMYIewx2EdI8XvqOWsquIyfP2qIElt5F8cqLKFZuM8WCguhWvztDQ4dSt0Jdf4SaL2X1WKxbpveHgOvd97FAwShuY0xRlZYMC16Bpf+2x2AX6dt1B9h15CTP3dKEZjUqoJrGqmOL+DHma3YnbqFcUEX6NBzB0LA7qFKqaPWn+OK8yUVVh+VlIMaYHBK7FabdDQfXwZX3QJd/2GOwC+T1Kh//tIOQy8oyoM1lzNgxnS83fcnBkwepW74uL7R7ge4NulOymP13PR9fRovVAx4C6mbe30ruG5PPqMKqsfDdMxBUylnb3hb1ylbcqVTuHRtFbGIyHq9TAj/V4yX21CG6XLWVLtOf5mTqSSKrR/K3tn/julrXESBWwSA7vowWmwl8hjMr35u74RhjLkrSMfjmYdj0DdTvAD1HQfka/o6qQBj7azS/RR/j1rAaBAUKiUSzJ+07TnuWs/yo0KVOF4aEDimUnfS5yZfkclpVP8j1SIwxF2fXYpg+Ak7GQudX4aoHrTaYjxKT0xjzyy46Na1C9/axTNg0gdWHV1MmqAyDG9/JoKaDCk0hybzmS3J5X0ReAn4AktMbVXVVrkVljMleWgr8/AYsfgcq14d7fnRKuZgMRxOT+XXHUWcIsSoedxixqpKc5mXR9t0klfqR7SVW8cTPh6lZtiZPRj5Jr5Behb48S27zJbmEAYOBG/jjsZi6n40x/nB4k3O3cvB3aHkndH0TSpT1d1T5zuNT1rJwS+yf2gNKHCSo0q8EVVhNictSCanUlkFNn+e6WtcRaCtu5ghfksvtQH1VTcntYIwx2fB6YNnHsOBVJ5n0/xKadsv+uCJo5e7jLNwSy4MdG9KrVU3Ay8rDvzI7ejJrj0RRPKAE3ep3545md9CoUqNsz2cujC/JZT3OKpGHczkWY0xWjkfDzPth9y/Q+Fbo9h6ULVxrgFwqVWe0V9ypVN75cQuVyxRn8NWXMW/PdCZunsi+xH1cXuZyHm31KH1C+lCxZEV/h1xo+ZJcKgKbRWQFZ/a52FBkY/KCKqweD98/Cwj0+Bgi7oAiWrMKIP50KgP+s4ztsYmoakZ5lswCih/iqogtdJ/9PElpSbS6rBWPtn6UTsGdKBbgy68+cyl8+S/8Uq5HYYw5t4RDzhDjrd9D3Wuh58fO+vZF3H8X7WTjgXiGta9LyaBAAkUIEFBJY8/pFWxNmse+0+vZfLI4Xet15Y6mdxBaxYYS5yVf1nP5OS8CMcZkogrrpsJ3T0FqEtz0T2h7nw0xBo4kJvPZkl3c2qIGL3VzEsbBkweZunUq07ZN48ipI9QsW5O/tv4rPRv2pFLJSn6OuGjyZYZ+As7oMIDiQBBwUlXL52ZgxhRZ8fthzl9h63dQM9K5W6nW2N9R+d2uIycZMuY3DsafxuNVHr2xIUv3L2Xylsks3LsQr3q5rtZ19G/cn/Y129ssej/z5c4lY7C3W26/B9AuN4MypkhShdVfwry/gSfZqQnWbiTY0FgA3pq3maOJyQxoU4XkUr/x118+ITo+mkolKjEkdAi3N7qdWuVq+TtM47qgXi13eeOZ7qTKZ3InJGOKoBN7YPbDsPMnqHMNdP/AqhhnsmbPcb7ftoKWYZv5Lv4XTh8/TXi1cF6/5nW61O1SZJYOLkh8eSzWO9PHACASOH2pFxaRaCAB8ABpqhopIpWByThFMqOBfqp63L1jeh+4BUgChqZXCBCRIcDz7mlfU9WxlxqbMXnG64Woz2D+y87nW/8Fre+2vhVXQkoCn6+dxue/T6JMvRj2JJfk1vq30r9xf5pWaerv8EwWfLlzyTxDKw3nl36PHLp+R1U9kunzM8ACVX1DRJ5xPz8N3AyEuK+2wCdAWzcZvYST8BRYKSKzVfV4DsVnTO6J3QpzHnXmrTS4Abq9X+hHgh1OOM3eY0kZZVi8XmcYsVeduSn7T5wi1eNl8/F1/HZ0LqeCVkFAKnhrMqDeozzcrp+VZSkgfOlzyct1XXoAHdz3Y4GFOMmlBzDOfSy3TEQqikgNd98fVfUYgIj8CHQFJuZhzMZcmNTTsPhfsORdKF4Guv/bKeFSyOetHIg7Red3FpGYnHbuHQKSCKqwiqCKKwgseYiA4iUIDrqWJmVu5OkbOnNZeVs7pSDJapnjF7M4TlX11Uu8tgI/iIgC/1HV0UB1VT3gbj8IVHff1wT2Zjp2n9t2vvYziMgIYARAcHDh/svQ5HM7FzojwY7tgBb9nU77stX8HVWeeOv7LaR4vIy6sxVlSwQREAACbI9fx+JD3xAV+zOp3hRCq4TSN+Q+bql/C6WDSvs7bHORsrpzOXvhaIAywHCgCnCpyeUaVY0RkcuAH0Vkc+aNqqpu4rlkbuIaDRAZGZkj5zTmgiTGwg9/g98nOxWMB8+EBh39HVWuU1Xm/H6A7YcTmb46hvs7NKBr8xocOXWEOTvmMG3bNKLjoykbVJbeIb3o26gvTSo38XfYJgdktczxv9Lfi0g54BFgGDAJ+Nf5jvOVqsa4/x4WkRlAG+CQiNRQ1QPuY6/0emYxQO1Mh9dy22L44zFaevvCS43NmBzj9cKaL+GHFyDlJFz3FFz7eJFZdnjWmv08OnkNAPWqlaBZyB4eWvARi2MW41EP4dXCebX9q3Sp08XuUgqZLPtc3A7zvwKDcPpAWuVEZ7mIlAECVDXBfd8FeAWYDQwB3nD/neUeMht4UEQm4XTox7kJaB7wuoikT8HtAjx7qfEZkyMO/O7MsN+zFIKvdgpNFqHJkCeT0/jnd5toEpzANS2j+WH3XJ5dcpyqpapyV+hd9GzQk/oV6/s7TJNLsupzeQvojfM4KUxVE3PwutWBGc4IY4oBX6nq925xzK9FZDiwG+jn7j8XZxjydpyhyMMAVPWYiLwKrHD3eyW9c98Yv0k6Bj/9A6LGQKlKTod9xKBCN7x43/EkZq3Zj8erfxr5FZ8Sx7JD80movJikUjFM216MjrU70rNhT66+4morHFkEiDMA6xwbRLw4VZDT+KP8Czh9cFpQy79ERkZqVFSUv8MwhZHX41Qvnv93OH0CrrwXOj7rJJhCJtXj5dYPFrP1UOa/OT0EldtOUIUoAspuRMRDlaB63NuyP7fWu9XK2xdwIrJSVSN93T+rPpfC9WeWMblp7wqY+wQcWAN12sPN/weXN/d3VLnmi1+i2XookVF3tib48hN8F/0tc3fO5fCpw1QqUYlb6w+kZ8OeNK5cdB4DmjPZvakxlyLxsHOnsuZLKFcD+nwGzfsUmjkrqspLszfw265j7hr0zmt/4kGaNdnGf3eOYevKrRSTYlxT8xqebfgs19e6nqDAIH+HbvzMkosxFyP1lLPc8OJ3Ie00tH8ErnsSShSu2ePTVsUwbulurqpfhbKl0jgmUcR6l1Lisk3sRWlRrAXPtX2OrnW7Wml7cwZLLsZcCFVYP82pBRa311luuPMrULWhvyPLccdOpvDat+toXG8vNRstZOG+n0j2JFO7XG0G1h/JrfVvJbi8TUo252bJxRhf7VkG856DmJVweQvo+QnUu9bfUeU4VWVZzCqe+v4L0mquYH+xkyQdrEivhr24rcFttKjaAikkj/1M7rHkYkx2ju2C+S/BxllOv0rPT6DFgEI1tFhV2Xh0E28tmcy6E4tIkSNoYDHCK7fn3lZ9aX9Fe+tHMRfEkosx53PyCCx+B1b8FwKKQYfn4OoHnWKThcSOEzv41y+TWXn0J5L0IKoBlExrQg1u46E2PenWwtaUMRfHkosxZ0tOgKUfwa8fOuvXR9wBHZ+H8jX8HVmO2BO/h292zOWH6HnsjN+OqhCY3JByaR24L7Ing9s0s8de5pJZcjEmXeppZ1b94rch6Sg07Q43PF9gSrYs23mUrYcS8HoVjzqPujzurPkDJ/ez7vgiDnqWk8guANKS6pAW352b6nbh/buuIzDAEorJOZZcjPGkwe+TYOEbzgiw+h2g04tQs7W/I/PZr9uPcMeny89ok6BjFCu3nqBy6wksvQeAoLQ6VPH04bqaNxJSuRYVSxfn1rAaBFhiMTnMkospurxe2DQLfvonHNkCV7SE7h/m+1L4J5JSOJniwetV0rzK6VQPj09ZS/2qZfjngOosO7iQRTH/Y+sJZxWLJpWacmOdh7il3s3ULl87m7MbkzMsuZiix+uFjTPh5/+D2E1QtRH0Gw9Nu+X7mfXfrHVK2Hu86eX+lIASByhefj3lg3dwz4LdAIRXC+eJyCfoFNyJWuVq+S9gU2RZcjFFx5+SSmOnXEtoLwgI9Hd02dpzNIlnp6+jec1yXNf8FFsSfmVzwi8cTzmIEECt8pEMDRvEDbVvoHqZ6tmf0JhcZMnFFH5eT6aksrnAJZVZa2J4Zc7vnAzYQlDVTcRX3c4X0YcpFlCMtjXa0jn4PjoGd6Ryycr+DtWYDJZcTOHlSXVKtSx510kq1ZpA3zHQrGeBSConTp9gysYfeG/pTAJrbSVIkikeUJIW1a7mxjo3cn3t6ylfvECufGGKAEsupvBJOQmrxsPSfzujvy5rBn0/d5NK/p1V//kvu5i1YS1xspbEwLWcDtgOogSULM+t9W7l5gadaFujLSUCS/g7VGOylefJRURqA+NwVqNUYLSqvi8iLwP3ArHurs+p6lz3mGeB4YAHeFhV57ntXYH3gUDgU1V9Iy+/i8lnTh6F30Y7r1PHIPgquPVfENIl33bUe7wefj/yO2NWzWHBnp8ILOH8+JfU2tTgNqrSksc6deTKulX9HKkxF8Yfdy5pwOOqukpEygErReRHd9u7qvp25p1FpBkwAAgFrgDmi0gjd/NHQGdgH7BCRGar6sY8+RYm/zixx5lRv2qcM6O+8S3Q/lEIbuvvyM7p2Olj/BLzC0tilrBg92KSvQmoBlI2sBEPRg7nxjoduaLsFf4O05hLkufJRVUPAAfc9wkisgmomcUhPYBJqpoM7BKR7UAbd9t2Vd0JICKT3H0tuRQFqrBvBSz7xCkoKQJh/aD9w3BZU39HdwaP18OGoxtYErOEJTFLWH9kPYpSKqACiccaUjUwguBSLXmrTztqVizl73CNyRF+7XMRkbpAS2A50B54UETuAqJw7m6O4ySeZZkO28cfyWjvWe3n/FNVREYAIwCCg239iQItLcVJJss/cUrfl6gA7UZC2/ugYv6ZIJj57uSXmF+JSzkBCOWlAcEBPSnnDeO3TaXo0qwGHw9qZbW8TKHjt+QiImWBacCjqhovIp8Ar+L0w7wK/Au4OyeupaqjgdEAkZGRms3uJj86eRRWjoEVn0HCAajSEG55G8IHQomy/o6ONG8a64+s59f9v55xd1KpRCUCTjcl+WBdqge1IIiynA4Q0gKETk1K89bt4ZZYTKHkl+QiIkE4iWWCqk4HUNVDmbb/F5jjfowBMv9JWsttI4t2U1jErHKKSa6b4iwn3OAG6PYBNLzRbyO/VJ2SK7vidrH84DJ+O7icVYejSEo7SQAB1CvXlFtqDSG4VCtWbivDgi2xvNE7jAFt7K7ZFB3+GC0mwGfAJlV9J1N7Dbc/BqAXsN59Pxv4SkTewenQDwF+AwQIEZF6OEllAHBH3nwLk6uSE2H9VIj6HA6sgaDSzh1K2/vgsiZ+Cys2KZaFe37h3SXfEsdGAoLiAfCmVCHtZHM8JxuSllSfNZ4yrAEgiXIlU3j0xhBLLKbI8cedS3tgMLBORNa4bc8BA0UkAuexWDTwFwBV3SAiX+N01KcBD6iqB0BEHgTm4QxFHqOqG/Lyi5gcduB3WPk5/D4FUhLgslDn0VeLflCyQp6EoKqogkeVhJREVh1ayfIDy1l+cBm74nc4+0hp6peNoG6ZCOqUiqBi8eoEiBAYIJQMCqBmxdKULhFIyWKBNKpelmKB+XdujTG5RVSLVhdEZGSkRkVF+TsMky45ATbMhJVfQEwUFCvplGWJvBtqXZmn81Omrd7OC/PmkBa0nWKldxFQah8iXtRbDE9SPffOpCH/160rfVvbnYgpWkRkpapG+rq/zdA3ec/rgV2LYO1E2PSNMzelamPo+ga06A+lc7dGVvzpVFZGHychJYEdCevZHr+GLXFrOXh6B4E1vARRjGrFG3BFyV7ULtmCK0o2pUSxElQpW5wml5enaQ0ruWJMdiy5mLxzZDus/QrWToL4GGcYcYt+EDEoT+5S4pLj+Cl6Ga//9C2JbCWg5H5EFPUG4jldm6rFuvJKl260q9maUsVsvokxl8KSi8ldibHOglxrJzmTHiUAGnSCLq86M+mDcu6XuKoya81+9sedwutV4lIPciB5MweTN3M4ZQvH0/YAipYoRkj5UCKqdSG0ckuaVAqjdFAJ6lYpY/0jxuQQSy4m5yUdg81zYP105/GXeqBaU+j8ijOLvnyNHL2cqpKUmswj0+fw854VBJbaTWDp3QQUS3S2e0rgOVWHYqldqFEilL/fdDNX1b88R2MwxpzJkovJGafjYctcp8T9jp/AmwqV6sE1j0Job6gemqOPvY6cOsLa2LVM27CERf/f3r0Hx1Wedxz//na1K1mSdZfliyxfhTMGYrANMQkJFGi4pIlJoCmZzpRMmlKmpW2aZoAOGcp0pjOhNExzgWagMFAmDZe2NIbQECBMGdxws+OLbGxLMjaybMmSL7It62Jpn/5xXpm1kYRsr7Ur9Hxmdvbsu2fPPvvu2fPsey7v+/47kGxBsUEKaqC2eDZLqi9nSfUFLJ12AQvKFpAX91XdufHkvzh3+o50wLZfRkml6RUY7IPS2bDiVjjvBphxQUYSypH+I/yy8W1WbXmLjv5G9g80czTVCYCl4kxJzKG+5Assq1nKzcsuo2qK9yDsXLZ5cnGnprMJtv4CtrwALW8CBiW10anD530FZi0/oyvn+wb72Lp/Kw2dDTR0NrChYyPvH96JEZ0yb8cqUN9s1L+CWP88LptzIffesJSCRO4P/uXcZOLJxY1ucCA6EN/4Imz5BXRui8qnnw+X3QGfuA6mf/K0Wih9g328uG0d9736aw4MbIf8Fsjfg5QCIDUwlVRPLYO9VzGnaBEP3riS+mo/VuLcRODJxX3YgZ3Q/Eq0q+u916DvECgOcz8DF30TFl0LZad2EeHB3oNsPbCVLfu3sGZPA2+1NtBtu0EpKIKkiqjIm09l4iKqEwupTtZTnFfJ1II86iqKuHxRtbdOnJtAPLm4qDtpTTIAAAyUSURBVC+vnf/3QULZ1xiVl9TCuddHpw7PvwymlH/kojqO9PDSts3sPrqd1qPNtHY3s7unma5jHcfnsYFS1D+T8ryrqS1cyB1XXsH5NfOJyU8Ddu7jwpPLZNTbBe+/ATteh52rYfe66HThvClR62T5N2DhlVB1zrC7u8yMgVSKXYdbaTzQRHNXE1v2NbK5cxttPe+DBsJ8ItVfTap3FoO9y0n1ziTVN4OL6+r4/k1LqC0vHO9P7pwbJ55cJoPuzujg+47VsPN1aNsIloJYAmqXR6cLz70U6j4NiQIAUiljMGX0DfTRcqiVp9ev5b83raOHVmL57cTy96JY//G3SB0rJdU3ncrk5Xz53GUsLK9nTvF8piQKiAliMZGIxZhWku+7t5ybBDy5fNwc64l6F259B3a9E90ffD96Lp4Psy+Gz90etVBqL4LEFAYGU2ze20pz41s8vX4t69oaIdFBLNmBkvuPH2CnDEpiZZTlzaYyuYSKRB2V+XVUJuuoKixlTkURK+ZX+FXuzjlPLhNafzfsfRfaG0JCWRNNp6LdUpTUQu0yuOhPGJi5lN+qnPWdu9jbs5uOptfp3PgM7T2ttB3dhcV6ji82WZGgNG8GZYmFlCVmUZGcxeKqBXx1yVLKCsqy9GGdcxOJJ5eJIJWCQ7ugfVOUPNoaovt9zRCu/+hNFLOzcjHv1d/AzqJptCSn0DZ4mH19u+nY8RxdTY8AqeOLNIthx8pJ9VdQkncRl8xexMyiOVyx4FwunDmPeMx3XTnnTt+ETy6SrgF+QDRg2L+a2feyHNLp6z0UnanV2QT7mo5PD+xvZn+qj/Z4nLa8OLuLp9E8pZTttctoj0NHqoeBeDdSG/S3QTgUkhoowo5VkOqvIWHnckldPZfOXURN4SyqCqpJxhMk8kT9tKnEYz6Ou3MucyZ0cpEUBx4AfhfYBbwtaZWZbc5uZMMwg96DcLAFulro2tvMjtatHOluobtvL4eP7eeQHaUzHmdfPE5nPE57PElnfpwjs6qiQZ0/WBiWOkIsVU7eQDmV+fV8cvpcZk2dTlXBNKoKaqgpnElhopB4TFQW5VNVnETjOPCWc25ym9DJBbgYaDKz7QCSngRWEg2JfNZYKkVPbxeHD7fTfbSDg4c72L2vje6jHfT2dLK/u4Pu/gP0pY7Qaz300Ee3Bjgi6IrH6IrFODrURUoi3MgH8oml4iSsmGS8ggTlTFUplSolP1ZKoSooTVazsKKWK+rncX5tqScM51xOmujJZRbQkvZ4F/Cps/FGtz58GVti++iT0RMTgx+1UU9CnkHhoChIJUmkismniMpYGdPyKigqnEHdtDqmF1VTUVBJeUElVVMqqS4qoabEB6pyzk1sEz25jImkW4BbAOrqTm/s8xnJ6cT7BsmP5ZNkCglNIS9eRCJeTDJRQuXUSqYWTyNZVMOCmQuZW1FDYaLQWxbOuUlpoieXVmB22uPaUHYCM3sIeAhg+fLldjpv9Hc3P3U6L3POuUlpol/t9jZQL2mepCRwE7AqyzE559ykN6FbLmY2IOk24EWiU5EfNbNNWQ7LOecmvQmdXADM7AXghWzH4Zxz7gMTfbeYc865HOTJxTnnXMZ5cnHOOZdxnlycc85lnCcX55xzGSez07qmcMKS1AHsPM2XVwGdGQwnk3I5Nsjt+HI5Nsjt+HI5Nsjt+CZabHPMrHqsC5h0yeVMSHrHzJZnO47h5HJskNvx5XJskNvx5XJskNvxfdxj891izjnnMs6Ti3POuYzz5HJqHsp2AKPI5dggt+PL5dggt+PL5dggt+P7WMfmx1ycc85lnLdcnHPOZZwnlzGSdI2krZKaJN2Z5VhmS3pV0mZJmyT9VSi/R1KrpHXhdl2W4tshaWOI4Z1QViHpJUmN4b48S7EtSqufdZIOSfpWtupO0qOS9kpqSCsbtq4U+WFYBzdIWpql+O6TtCXE8KykslA+V1JPWh3+JAuxjfg9SvrbUHdbJV19NmMbJb6n0mLbIWldKB/vuhtpG5K5dc/M/PYRN6Lu/JuB+UASWA8szmI8M4ClYXoqsA1YDNwDfCcH6msHUHVS2T8Cd4bpO4F7cyDOONAGzMlW3QGfA5YCDR9VV8B1wP8AAlYAb2Ypvs8DeWH63rT45qbPl6XYhv0ew+9jPZAPzAu/5/h4x3fS898H7s5S3Y20DcnYuuctl7G5GGgys+1m1g88CazMVjBmtsfM1obpw8C7wKxsxTNGK4HHw/TjwPVZjGXIlUCzmZ3uRbVnzMxeA/afVDxSXa0E/s0ibwBlkmaMd3xm9iszGwgP3yAaAXbcjVB3I1kJPGlmfWb2HtBE9Ls+a0aLT9H4518FfnY2YxjJKNuQjK17nlzGZhbQkvZ4FzmyMZc0F7gQeDMU3RaarY9ma9cTYMCvJK2RdEsoqzGzPWG6DajJTmgnuIkTf9y5UHcwcl3l4nr4DaJ/tEPmSfqtpP+V9NksxTTc95hrdfdZoN3MGtPKslJ3J21DMrbueXKZwCQVA/8JfMvMDgH/AiwALgD2EDW7s+FSM1sKXAv8uaTPpT9pUTs7q6cpKhoW+0vAM6EoV+ruBLlQVyORdBcwAPw0FO0B6szsQuDbwL9LKhnnsHLyexzG1zjxj01W6m6YbchxZ7rueXIZm1Zgdtrj2lCWNZISRCvFT83svwDMrN3MBs0sBTzMWW72j8TMWsP9XuDZEEf7UDM63O/NRmxprgXWmlk75E7dBSPVVc6sh5K+Dvwe8IdhI0TY5bQvTK8hOq5xznjGNcr3mEt1lwd8BXhqqCwbdTfcNoQMrnueXMbmbaBe0rzwj/cmYFW2ggn7ax8B3jWz+9PK0/eBfhloOPm14xBbkaSpQ9NEB38biOrr5jDbzcDPxzu2k5zwzzEX6i7NSHW1CvijcObOCqArbRfGuJF0DXA78CUzO5pWXi0pHqbnA/XA9nGObaTvcRVwk6R8SfNCbG+NZ2xprgK2mNmuoYLxrruRtiFkct0br7MTJvqN6GyJbUT/KO7KciyXEjVXNwDrwu064AlgYyhfBczIQmzzic7KWQ9sGqoroBJ4BWgEXgYqslh/RcA+oDStLCt1R5Tg9gDHiPZj//FIdUV0ps4DYR3cCCzPUnxNRPvfh9a9n4R5bwjf+TpgLfDFLMQ24vcI3BXqbitwbTbqLpQ/Btx60rzjXXcjbUMytu75FfrOOecyzneLOeecyzhPLs455zLOk4tzzrmM8+TinHMu4zy5OOecyzhPLs4Fko7kQAzXS1p8Fpf/mKQbz9bynRviycW5MxSuuM6U64l6p3VuQvPk4twoJH1R0puhQ8GXJdWE8nskPSFpNfCEpEJJT4fxMZ4Nr1ke5v28pN9IWivpmdCfE5K+F+bfIOmfJH2aqL+z+8KYHgtOiuX3JTVIWi/ptVAWD69tCMv5i1B+t6S3Q/lD4Yrskz/bstBJ4hpJL35UL7fOnYpM/uNy7uPodWCFmZmkbxJ1e/I34bnFRJ109kj6DnDAzBZLOo/oimckVQHfBa4ys25JdwDflvQAUfcknwjLLjOzg5JWAc+b2X8ME8vdwNVm1qowQBdwC9FYIBeY2YCkilD+YzP7+xDDE0T9gD03tKDQr9SPgJVm1iHpD4B/IOrl2Lkz5snFudHVAk+Ff/VJ4L2051aZWU+YvhT4AYCZNUjaEMpXECWh1aHxkAR+A3QBvcAjkp4Hnh9DLKuBxyQ9DQx1NHgVUfcrA+G9h8YP+R1JtwOFQAVR1yLPpS1rEXAe8FKIK07UVYlzGeHJxbnR/Qi438xWSbqcaKTDId1jeL2Al8zsax96QrqYaMCyG4HbgCtGW5CZ3SrpU8AXgDWSlg37hlIB8CBR/08tku4BCoaJa5OZXTKGz+DcKfNjLs6NrpQPuha/eZT5VhONLEg42+v8UP4G8BlJC8NzRZLOCcddSs3sBeCvgSVh/sNEw85+iKQFZvammd0NdBB1gf4S8KdDJxWE3WJDiaQzvM9wZ4dtBaolXRJel5B07iifz7lT4i0X5z5QKGlX2uP7iVoqz0g6APyaaPz14TwIPC5pM7CFaDdUVzie8XXgZ5Lyw7zfJUoiPw+tDBENEAXRENoPS/pL4EYza057j/sk1Yf5XyHqebqBaNyPDZKOAQ+b2Y8lPRyeayMaMuIEZtYfTkn+oaRSom3BP4e4nTtj3iuycxkQxuJImFlvOMvrZWCRmfVnOTTnssJbLs5lRiHwajgLS8CfeWJxk5m3XJxzzmWcH9B3zjmXcZ5cnHPOZZwnF+eccxnnycU551zGeXJxzjmXcZ5cnHPOZdz/A7uP2nZWy7AgAAAAAElFTkSuQmCC\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((1+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.5.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
