{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## When N is a small number "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\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",
    "result_list = []\n",
    "for i in range(800):\n",
    "    z = i+3\n",
    "    Prime_list = get_Prime_number_in_a_range(1,z)\n",
    "    Maxium_number_of_scale = np.sqrt(2*z)\n",
    "    Channel_of_OS = len(Prime_list)\n",
    "    result_list.append(Channel_of_OS-Maxium_number_of_scale)\n",
    "\n",
    "plt.plot(result_list)\n",
    "plt.ylabel('Channel_of_OS - Maxium_number_of_scale')\n",
    "plt.xlabel('length of singal')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## When N is a larger number"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/tangw/anaconda3/envs/python35/lib/python3.6/site-packages/ipykernel_launcher.py:8: RuntimeWarning: divide by zero encountered in log\n",
      "  \n",
      "/home/tangw/anaconda3/envs/python35/lib/python3.6/site-packages/ipykernel_launcher.py:8: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  \n"
     ]
    },
    {
     "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": [
    "largest_N = 10000\n",
    "\n",
    "N_list = np.asarray([i for i in range(largest_N)])\n",
    "\n",
    "np.sqrt(2*N_list)\n",
    "\n",
    "plt.plot(np.sqrt(2*N_list), label= 'maxium number of scales')\n",
    "plt.plot(N_list/np.log(N_list), label= 'channels of OS')\n",
    "plt.xlabel('length of singal')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "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
}
