{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.stats as stats \n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAGM1JREFUeJzt3XuUnHV9x/H3d2Z2drLZS66QkAQTaDQGjxfcIoi21GvgeJK2x2qoHlGp6FFqPdqe0tpDkf5T9ViPVqpGpYJVMFovqSeK1GI9xxJMQEACBJYQyJr7xVx2k92dmW//eJ4Nw+zs7mwy8/yezXxe5+zZ5/KbZ748TD7z29/zzG/M3RERkdaSCV2AiIgkT+EvItKCFP4iIi1I4S8i0oIU/iIiLUjhLyLSgiYNfzO71cz2mdkj4+w3M/u8mfWZ2cNmdnHjyxQRkUaqp+f/dWDVBPuvBJbHP9cBXzzzskREpJkmDX93/wVwaIIma4DbPbIJmGVmCxtVoIiINF6uAcdYBOysWO+Pt+2ubmhm1xH9dUBbR9cr87MXsmJBVwNKEBFpDffff/8Bd59/psdpRPhbjW0154xw93XAOoAFF17kS6/9PJv+/vUNKEFEpDWY2TONOE4j7vbpB5ZUrC8Gdk32IAO89nuEiIg0WSPCfwPwrviun0uBI+4+ZshnDIOysl9EJIhJh33M7A7gCmCemfUD/wi0Abj7l4CNwFVAHzAIvKfeJ9eEoiIiYUwa/u5+9ST7HfjQ6Ty5ppMWEQkj6Cd8Ff0iImEEC39DPX8RkVCC9vx1wVdEJIywwz7q+YuIBBEu/E13+4iIhBJwzN90wVdEJJDAY/6KfxGREAKP+Yd8dhGR1hX2Vk8N/IiIBKFbPUVEWlDQu33U8RcRCUMXfEVEWpDm9hERaUFBL/iq5y8iEoZu9RQRaUFBwx80v4+ISAjhhn0s+t73ku73FBFJXPCev7JfRCR5QS/4gi76ioiEkIKev8JfRCRpAcf8o98a9hERSZ56/iIiLSh8+KvrLyKSuKDf5AUa9hERCSHsrJ7oPn8RkRCC3+qpT/iKiCQv/Ji/sl9EJHHBe/4l9fxFRBIXfMxfd/uIiCQv+LCPOv4iIsnTsI+ISAsK2PMfvc9f4S8ikrTgc/voVk8RkeQFH/MvlUNXICLSeoKP+WvYR0QkeXWFv5mtMrNtZtZnZjfU2H++md1jZr82s4fN7Kp6C9D0DiIiyZs0/M0sC9wCXAmsBK42s5VVzf4BWO/urwDWAv826TOfGvOfUr0iItIA9fT8LwH63H27uw8DdwJrqto40B0v9wC7Jjuohn1ERMKpJ/wXATsr1vvjbZVuAt5pZv3ARuAvax3IzK4zsy1mtuXIkaOA7vMXEQmhnvC3GtuqE/tq4Ovuvhi4CviGmY05truvc/ded++d1dMzum2KJYuIyJmqJ/z7gSUV64sZO6xzLbAewN3vBQrAvAmPqu/wFREJpp7w3wwsN7NlZpYnuqC7oarNs8DrAczsxUThv7+eAnS3j4hI8iYNf3cvAtcDdwGPEd3Vs9XMbjaz1XGzjwHvM7OHgDuAd/sk4zm64CsiEk6unkbuvpHoQm7lthsrlh8FLj+dApT9IiLJCz63j4Z9RESSp1k9RURaUPCJ3ZT9IiLJCz6xm4Z9RESSF/47fNX1FxFJXPCev8JfRCR5KbjgG64CEZFWpZ6/iEgLCj7mrwu+IiLJ062eIiItSMM+IiItKHjPX8M+IiLJCz63jzr+IiLJC97z17CPiEjygt/nr+/wFRFJXvBhHw35i4gkL/ywj9JfRCRxutVTRKQFhe/5K/tFRBIXfsxf6S8ikrgU9PwV/iIiSQs45q8pnUVEQlHPX0SkBQWf0llj/iIiyUvBrZ6hKhARaV3Bh31K5XLoEkREWk7Q8G/LGkV1/UVEEhc0/LMZ03z+IiIBBA3/XCajnr+ISADq+YuItKDAPX9jpKQLviIiSQsb/ln1/EVEQtCYv4hIC9KYv4hIC6or/M1slZltM7M+M7thnDZvM7NHzWyrmX2rnuNqzF9EJIzcZA3MLAvcArwR6Ac2m9kGd3+0os1y4O+Ay939sJmdU8+Tq+cvIhJGPT3/S4A+d9/u7sPAncCaqjbvA25x98MA7r6vnifPZTXmLyISQj3hvwjYWbHeH2+r9ELghWb2SzPbZGarah3IzK4zsy1mtmX//v3k1PMXEQminvC3GtuqEzsHLAeuAK4Gvmpms8Y8yH2du/e6e+/8+fPJZjS3j4hICPWEfz+wpGJ9MbCrRpsfuvuIuz8NbCN6M5hQLmMUdcFXRCRx9YT/ZmC5mS0zszywFthQ1eYHwB8BmNk8omGg7ZMdOKdZPUVEgpg0/N29CFwP3AU8Bqx3961mdrOZrY6b3QUcNLNHgXuAv3H3g5MdO5fJaMxfRCSASW/1BHD3jcDGqm03Viw78NH4p24a8xcRCSP4xG4a8xcRSZ6mdxARaUGBv8ZRH/ISEQlBPX8RkRYUfsy/rDF/EZGkBe/5F0vq+YuIJC34N3lpzF9EJHnBv8lLY/4iIslLwbCPxvxFRJIW/IKvev4iIskL2/PPGiMKfxGRxIX9kJfG/EVEggg+5l8qO2W9AYiIJCpo+Odz0dOP6INeIiKJChv+2ejph4sKfxGRJKWi56/wFxFJVvBZPQFGNMWDiEii1PMXEWlB6Qh/fcpXRCRRgS/4GqCev4hI0tTzFxFpQSm54KvwFxFJku7zFxFpQekY9lH4i4gkKhXDPhrzFxFJVtDwb1fPX0QkCA37iIi0oFQM++huHxGRZKWj56/wFxFJVDrCX8M+IiKJSsd9/ur5i4gkKh3hr56/iEiigoZ/JmPksxmGFP4iIokKGv4AhbYMJ4ZLocsQEWkpwcN/Rj7LyRGFv4hIkuoKfzNbZWbbzKzPzG6YoN1bzczNrLfeAma0ZTmh8BcRSdSk4W9mWeAW4EpgJXC1ma2s0a4L+DBw31QKKLRlNewjIpKwenr+lwB97r7d3YeBO4E1Ndr9E/Ap4ORUCpiRV89fRCRp9YT/ImBnxXp/vO0UM3sFsMTdfzTRgczsOjPbYmZb9u/fD0TDPhrzFxFJVj3hbzW2+amdZhngs8DHJjuQu69z9153750/fz6gMX8RkRDqCf9+YEnF+mJgV8V6F/AS4OdmtgO4FNhQ70XfQl5j/iIiSasn/DcDy81smZnlgbXAhtGd7n7E3ee5+1J3XwpsAla7+5Z6CoiGffQhLxGRJE0a/u5eBK4H7gIeA9a7+1Yzu9nMVp9pARr2ERFJXq6eRu6+EdhYte3GcdpeMZUCZmjYR0QkccE/4VuIe/7uPnljERFpiODhP6MtC6DJ3UREEpSC8I9K0L3+IiLJCR/++ajnr4u+IiLJCR7+hXjYRxd9RUSSEzz8O/LRDUcDQwp/EZGkBA//rkIU/seGRgJXIiLSOoKHf2d7HP4ni4ErERFpHcHDv7vQBij8RUSSFDz8O+Nhn+MnNewjIpKU4OF/asxfPX8RkcQED/+2bIZCW4bjQwp/EZGkBA9/gM72No6q5y8ikphUhH93IccxjfmLiCQmFeHfWchp2EdEJEGpCP+uQk4XfEVEEpSK8O9s17CPiEiSUhH+szvyHB5U+IuIJCUV4T9nZp7DA8P6Ni8RkYSkJvyLZefoCY37i4gkIRXhP7czD8DBgaHAlYiItIZUhP/sjij8Dw8OB65ERKQ1pCL8585sB+DgcYW/iEgSUhH+c+Jhn0MDCn8RkSSkIvznzhwd81f4i4gkIRXhX2jL0pHPqucvIpKQVIQ/RLd7KvxFRJKRmvCf19nOvmMnQ5chItISUhP+580qsPt3Cn8RkSSkJvwX9sxg15ETmuJBRCQBKQr/AidHyvxOE7yJiDRdasL/vFkzANh15ETgSkREzn6pCf+FPQUAjfuLiCQgNeE/2vPfrZ6/iEjT1RX+ZrbKzLaZWZ+Z3VBj/0fN7FEze9jMfmZmL5hqIfM722nLGv2/U/iLiDTbpOFvZlngFuBKYCVwtZmtrGr2a6DX3V8KfBf41JQLyRjnz+lgx4GBqT5URESmqJ6e/yVAn7tvd/dh4E5gTWUDd7/H3Qfj1U3A4tMpZtm8Tp5W+IuINF094b8I2Fmx3h9vG8+1wI9r7TCz68xsi5lt2b9//5j9F86fyY6Dg5TKutdfRKSZ6gl/q7GtZjqb2TuBXuDTtfa7+zp373X33vnz54/Zv2zeTIaLZXZp3F9EpKnqCf9+YEnF+mJgV3UjM3sD8HFgtbuf1vcxLps3E4Cn9h8/nYeLiEid6gn/zcByM1tmZnlgLbChsoGZvQL4MlHw7zvdYpaf2wXAE3uPne4hRESkDpOGv7sXgeuBu4DHgPXuvtXMbjaz1XGzTwOdwHfM7EEz2zDO4SY0Z2ae83oKPPLbo6fzcBERqVOunkbuvhHYWLXtxorlNzSqoIsW9fDIriONOpyIiNSQmk/4jnrJeT08fWCA40PF0KWIiJy10hf+i7pxh8d2a+hHRKRZUhf+L108C4AHnjkcuBIRkbNX6sJ/flc7F86fyb3bD4YuRUTkrJW68Ae47MK5bH76ECOlcuhSRETOSqkM/0svmMvAcInf/FZ3/YiINEMqw/+yC+aSMfj5trHz/4iIyJlLZfjP7Wynd+kc7npkT+hSRETOSqkMf4BVFy1g295jbNc8PyIiDZfa8H/zSxYA8GP1/kVEGi614b9o1gwuWTqH9Vt2Utb8/iIiDZXa8Ad4x6Xn88zBQX751IHQpYiInFVSHf6rXrKA2R1t3H7vM6FLERE5q6Q6/NtzWd512VLufnSv5voREWmgVIc/wHsvX0ZXe47P/feToUsRETlrpD78ezra+IvXXsBPtu7h/zT2LyLSEKkPf4D3/+EFLJkzgxt/uJXhoub7ERE5U9Mi/AttWT6x+iL69h3nMz/dFrocEZFpb1qEP8DrVpzLn7/qfL78i+3cs+20vyNeRESYRuEPcONbVrJiQRcfvuPXPL5Hd/+IiJyuaRX+hbYsX3v379ORz3LNrb9ix4GB0CWJiExL0yr8IZr24bb3XsJwscxbv3Sv7v8XETkN0y78AVYs6Gb9+y8jlzH+7Ev38hNN/iYiMiXTMvwBlp/bxfc++GouPKeTD/zH/Xziv7YyOFwMXZaIyLQwbcMf4LxZM1j//kt596uX8u+/3MGbPvsL7nl8H+6aBVREZCLTOvwhmv/nptUXsf79l5HPZXjP1zdz9Vc28cCzh0OXJiKSWhaql9zb2+tbtmxp6DGHiiXuuO9ZvnBPHweOD/OqZXN4z+VLeePKBWQz1tDnEhEJwczud/feMz7O2RT+owaGinzrvme57d4d9B8+wcKeAqtfdh6rX34eKxd2Y6Y3AhGZnhT+dSiVnbsf3ct3tuzkf5/YT7HsXDh/Jq9bcQ5XvOgcepfOpj2XbWoNIiKNpPCfosMDw2x8ZDcbf7ObzU8fZrhUpiOf5VXL5tC7dA4Xnz+bly3poSOfS6wmEZGpUvifgYGhIvc+dZCfP7GP+7Yf4sl9xwHIZowVC7p48cJuVizoYuXCblYs7GbOzHyQOkVEqin8G+jI4AgPPHuY+585zEP9v+PxPcfYf2zo1P55ne0sm9fBC+bOZOnc0d8zOX9uB92FnK4hiEhiFP5NduD4EI/vPsbje47yxN5j7Dg4yDMHB9h7dOh57TryWRb0FFjYU2BB94zod0+BBd0F5nbmmTuznTmdeWbms3qTEJEz1qjw1wD3OOZ1tvOa5e28Zvm8520fHC7y7KFBdhwYZOehQXYfOcmeoyfYc+Qk9z51gL3HhiiVx76h5nMZ5s7MMyf+mdfZzuyOPN0zcnQX2ugq5Oie0XZquSde7izkdJuqiDScwn+KOvI5VizoZsWC7pr7S2XnwPEh9hw5ycGBIQ4eH+bQQPRzcPT38SGePjDA4YFhBoZLkz5nZ3uOrkKOGfksHfksHflc/Ltyeey2GfksM9qytOcytI/+rl7OZWnLmv4qEWkxdYW/ma0CPgdkga+6+z9X7W8HbgdeCRwE3u7uOxpb6vSQzRjndhc4t7tQV/tiqczxoSJHTxQ5enIk+jlR5NjJEY6eLHL0RLTt+MkigyMlBoeKDA6XODQwzM5DRU4Ml6Ltw6XT/opLM8hna78xtLdlyGcz5HMZchmjLZuhLZshlx1dNnKZzHPL2Yo2mYo22UxVezt1nGzGyFr02IxF+zMZyGUyZDOM2XZqn9mYbRlDb2QidZg0/M0sC9wCvBHoBzab2QZ3f7Si2bXAYXf/PTNbC3wSeHszCj7b5LIZZnXkmdVx5ncUFUtlBkdKnBguMRC/SQwVSwyNlBkqlqPlYjlej5eLZYZGKpZrtRuJ3qCKJWekVGakVKZYdkaKZUbKTrFUZiTeVyx7zWGvJI2+mVS+IeSyGTJmZKveLMyiN5dM/NsqlkffSJ5bt+faZ6bYvtbxM1NrbwYGYIZFvzCe224Vb3w198Xr0f7njlH3sYlWrOrx4x278rjRvsr1sY+veWwqa4vbndr33PNx6jkqt4++IsbbbzXbW1V7aux/7r+19mOaXUMj1NPzvwToc/ft0ZPbncAaoDL81wA3xcvfBb5gZuaaYS1RuWyG7myG7kJb0DrKZWekXKZYcoolZ7hUphivD5fKY95EiiWn7E6x7JTjN49i+fnbTu0bZ1up8nEVjx/dXmtfsey4O+5Qdo9/wOPfz193ymVOHXOkVEf7eNvzjl+eYvt4f6nsOKB/UdIo9YT/ImBnxXo/8Krx2rh70cyOAHOBA5WNzOw64Lp4dcjMHjmdohM2j6r/jpRSnY0zHWoE1dlo06XOFzXiIPWEf60/NKr7H/W0wd3XAesAzGxLI25XajbV2VjToc7pUCOozkabTnU24jj1TOncDyypWF8M7BqvjZnlgB7gUCMKFBGRxqsn/DcDy81smZnlgbXAhqo2G4Br4uW3Av+j8X4RkfSadNgnHsO/HriL6FbPW919q5ndDGxx9w3A14BvmFkfUY9/bR3Pve4M6k6S6mys6VDndKgRVGejtVSdwaZ3EBGRcKb91ziKiMjUKfxFRFpQ08PfzFaZ2TYz6zOzG2rsbzezb8f77zOzpc2uqUYNS8zsHjN7zMy2mtlf1WhzhZkdMbMH458bk64zrmOHmf0mrmHMLV8W+Xx8Ph82s4sTru9FFefoQTM7amYfqWoT7Fya2a1mtq/yMyZmNsfM7jazJ+Pfs8d57DVxmyfN7JpabZpY46fN7PH4/+n3zWzWOI+d8PWRQJ03mdlvK/7fXjXOYyfMhQTq/HZFjTvM7MFxHpvk+ayZQ017fUafcGzOD9EF4qeAC4A88BCwsqrNB4EvxctrgW83s6Zx6lwIXBwvdwFP1KjzCuBHSddWo9YdwLwJ9l8F/JjosxeXAvcFrDUL7AFekJZzCfwBcDHwSMW2TwE3xMs3AJ+s8bg5wPb49+x4eXaCNb4JyMXLn6xVYz2vjwTqvAn46zpeFxPmQrPrrNr/GeDGFJzPmjnUrNdns3v+p6aGcPdhYHRqiEprgNvi5e8Crzdr5AwWk3P33e7+QLx8DHiM6FPL09Ea4HaPbAJmmdnCQLW8HnjK3Z8J9PxjuPsvGPsZlMrX4G3AH9d46JuBu939kLsfBu4GViVVo7v/1N2L8eomos/bBDXOuaxHPbnQMBPVGWfN24A7mvX89Zogh5ry+mx2+NeaGqI6VJ83NQQwOjVEEPGw0yuA+2rsvszMHjKzH5vZRYkW9hwHfmpm91s0XUa1es55UtYy/j+qNJzLUee6+26I/gEC59Rok6bz+l6iv+5qmez1kYTr4+GpW8cZokjTuXwtsNfdnxxnf5DzWZVDTXl9Njv8GzY1RBLMrBP4T+Aj7n60avcDRMMXLwP+FfhB0vXFLnf3i4ErgQ+Z2R9U7U/F+bToA4Grge/U2J2WczkVaTmvHweKwDfHaTLZ66PZvghcCLwc2E00pFItFecydjUT9/oTP5+T5NC4D6uxbcJz2uzwnzZTQ5hZG9EJ/6a7f696v7sfdffj8fJGoM3M5lW3azZ33xX/3gd8n+hP6Er1nPMkXAk84O57q3ek5VxW2Ds6NBb/3lejTfDzGl/EewvwDo8HeqvV8fpoKnff6+4ldy8DXxnn+YOfSziVN38KfHu8Nkmfz3FyqCmvz2aH/7SYGiIe9/sa8Ji7/8s4bRaMXosws0uIzt3B5KoEM5tpZl2jy0QXAatnRt0AvMsilwJHRv9kTNi4Pao0nMsqla/Ba4Af1mhzF/AmM5sdD2W8Kd6WCIu+UOlvgdXuPjhOm3peH01VdX3pT8Z5/npyIQlvAB539/5aO5M+nxPkUHNenwlcwb6K6Kr1U8DH4203E72IAQpEQwN9wK+AC5pdU40aX0P0J9LDwIPxz1XAB4APxG2uB7YS3ZmwCXh1gDoviJ//obiW0fNZWacRffnOU8BvgN4AdXYQhXlPxbZUnEuiN6TdwAhRb+laomtMPwOejH/Pidv2En1z3ehj3xu/TvuA9yRcYx/RmO7o63P0DrnzgI0TvT4SrvMb8evuYaLQWlhdZ7w+JheSrDPe/vXR12RF25Dnc7wcasrrU9M7iIi0IH3CV0SkBSn8RURakMJfRKQFKfxFRFqQwl9EpAUp/EVEWpDCX0SkBf0/adobbu8cVJEAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(array(1.), array(10.), array(6.32455532), array(60.))\n"
     ]
    }
   ],
   "source": [
    "# shape = 32\n",
    "# scale = 0.0625\n",
    "\n",
    "scale = 10.\n",
    "shape = 0.1\n",
    "\n",
    "x = np.linspace(0, 100, 10000) \n",
    "y1 = stats.gamma.pdf(x, a=shape, scale=scale) #a is alpha, loc is beta???\n",
    "\n",
    "plt.plot(x, y1) \n",
    "\n",
    "plt.ylim([0,1])\n",
    "plt.xlim([0,20])\n",
    "plt.show()\n",
    "\n",
    "print(stats.gamma.stats(a=shape, scale=scale, moments='mvsk'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "shape, scale = 8, 1/8  # mean=4, std=2*sqrt(2)\n",
    "s = np.random.gamma(shape, scale, 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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 scipy.special as sps\n",
    "count, bins, ignored = plt.hist(s, 50, density=True)\n",
    "y = bins**(shape-1)*(np.exp(-bins/scale) / (sps.gamma(shape)*scale**shape))\n",
    "plt.plot(bins, y, linewidth=2, color='r')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import gamma, poisson\n",
    "mean = 0.05\n",
    "scale = 1./10.\n",
    "shape = mean/scale\n",
    "\n",
    "N = 1000\n",
    "K = 20\n",
    "\n",
    "Z = gamma.rvs(shape, scale=scale, size=(N, K))\n",
    "A = poisson.rvs(np.dot(Z, Z.transpose()))\n",
    "A[A>1] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.08754428267700658, 9.01016696033337)"
      ]
     },
     "execution_count": 120,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "threshold = 2.0\n",
    "\n",
    "N = 1000\n",
    "i_shape = 0.1\n",
    "i_rate = 0.5\n",
    "i_scale = 1./i_rate\n",
    "I = gamma.rvs(i_shape, scale=i_scale, size=N)\n",
    "I[I<=threshold]=1e-10\n",
    "I.mean(), I.max()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10, 100)"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "smoothness = 100\n",
    "n_components = 10\n",
    "n_feats = 100\n",
    "\n",
    "a = smoothness * np.random.gamma(smoothness, 1. / smoothness, size=(n_components, n_feats))\n",
    "b = smoothness * np.random.gamma(smoothness, 1. / smoothness, size=(n_components, n_feats))\n",
    "\n",
    "(a/b).shape"
   ]
  },
  {
   "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
