{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "117f66c9-04d7-4148-a91e-1cfb6e6865ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import copy\n",
    "\n",
    "# explicit Euler\n",
    "N_grid = 100\n",
    "h = 1/N_grid\n",
    "\n",
    "# real degree of freedom: N pts = N_grid - 1\n",
    "# after padding (because of Neumann bc): N pts = N_grid + 1\n",
    "\n",
    "x = np.linspace(0,1,num=N_grid+1)\n",
    "y = np.linspace(0,1,num=N_grid+1)\n",
    "xx, yy = np.meshgrid(x, y)\n",
    "\n",
    "eps = 0.025\n",
    "u = np.tanh((0.35-np.sqrt((xx-0.5)**2+(yy-0.5)**2))/(2*eps))\n",
    "\n",
    "step = 0.001\n",
    "n_steps = 10000\n",
    "mu = 10\n",
    "\n",
    "def pad(u):\n",
    "    u = np.concatenate([u, u[:,[-1]]], axis=1)\n",
    "    u = np.concatenate([u[:,[0]], u], axis=1)\n",
    "    u = np.concatenate([u[[0],:], u], axis=0)\n",
    "    u = np.concatenate([u, u[[-1],:]], axis=0)\n",
    "    return u\n",
    "\n",
    "def lap(u):\n",
    "    u = pad(u)\n",
    "    return (u[2:,1:-1] + u[:-2:,1:-1] + u[1:-1,2:] + u[1:-1,:-2] - 4 * u[1:-1,1:-1])/h**2\n",
    "\n",
    "us = []\n",
    "\n",
    "for i in range(n_steps):\n",
    "    \n",
    "    us.append(copy.deepcopy(u))\n",
    "    \n",
    "    lap_ = lap(u)\n",
    "    rhs = mu*(eps**2*lap_ - u**3 + u)\n",
    "    u += step * rhs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "1250cc3c-498b-4d16-bfd9-591d7676e973",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAbUAAAGgCAYAAAAtsfn1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAkuklEQVR4nO3de3CU1eHG8Wdz2ySYpAXKLpGAYSYdVLwgWKbASKwSp6KVYcYbKDj2DyigxLRyEVuRkUToDGUKFQvTQacWcTpCpR3bId6iDG1BIIrYgVpTQCWTWmk2QNjczu8Pfuy+7wksBDbEnP1+ZjKT97Lvnj0Sn33POe85AWOMEQAADkjr6QIAAJAshBoAwBmEGgDAGYQaAMAZhBoAwBmEGgDAGYQaAMAZhBoAwBmEGgDAGYQaAMAZPRpqzz33nIqLi5Wdna2RI0fqvffe68niAAB6uYyeeuNXXnlF5eXleu655zR27Fj9+te/1ve//319/PHHGjx4cMLXdnR06IsvvlBeXp4CgcAlKjEAIFmMMWpqalJhYaHS0pJ3fxXoqQmNR48erRtuuEFr1qyJ7bvyyis1adIkVVVVJXztZ599pqKiou4uIgCgmx0+fFiDBg1K2vV65E6tpaVFu3bt0oIFC3z7y8rKtH379k7nR6NRRaPR2PbpHB6n25WhzO4tLAAg6drUqm16XXl5eUm9bo+E2pdffqn29naFQiHf/lAopPr6+k7nV1VV6emnn+60P0OZyggQagDQ6/x/G2Gyu5B6dKCI/WGMMWf8gAsXLlRjY2Ps5/Dhw5eqiACAXqRH7tT69++v9PT0TndlDQ0Nne7eJCkYDCoYDF6q4gEAeqkeuVPLysrSyJEjVV1d7dtfXV2tMWPG9ESRAAAO6LEh/RUVFXrwwQc1atQoffe739XatWt16NAhzZw5s6eKBADo5Xos1O69917997//1ZIlS3TkyBENHz5cr7/+uoYMGdJTRQIA9HI99pzaxYhEIiooKFCp7mL0IwD0Qm2mVe/oNTU2Nio/Pz9p12XuRwCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzCDUAgDMINQCAMwg1AIAzkh5qVVVVuvHGG5WXl6cBAwZo0qRJ2r9/v+8cY4wWL16swsJC5eTkqLS0VPv27Ut2UQAAKSbpoVZTU6PZs2frb3/7m6qrq9XW1qaysjIdP348ds7y5cu1YsUKrV69Wjt37lQ4HNaECRPU1NSU7OIAAFJIwBhjuvMN/vOf/2jAgAGqqanRTTfdJGOMCgsLVV5ervnz50uSotGoQqGQli1bphkzZpzzmpFIRAUFBSrVXcoIZHZn8QEA3aDNtOodvabGxkbl5+cn7brd3qfW2NgoSerbt68kqa6uTvX19SorK4udEwwGNX78eG3fvv2M14hGo4pEIr4fAABs3RpqxhhVVFRo3LhxGj58uCSpvr5ekhQKhXznhkKh2DFbVVWVCgoKYj9FRUXdWWwAQC/VraE2Z84cffjhh3r55Zc7HQsEAr5tY0ynfactXLhQjY2NsZ/Dhw93S3kBAL1bRndd+JFHHtGWLVv07rvvatCgQbH94XBY0qk7toEDB8b2NzQ0dLp7Oy0YDCoYDHZXUQEAjkj6nZoxRnPmzNGmTZv01ltvqbi42He8uLhY4XBY1dXVsX0tLS2qqanRmDFjkl0cAEAKSfqd2uzZs7Vhwwa99tprysvLi/WTFRQUKCcnR4FAQOXl5aqsrFRJSYlKSkpUWVmp3NxcTZkyJdnFAQCkkKSH2po1ayRJpaWlvv3r16/XQw89JEmaN2+empubNWvWLB09elSjR4/W1q1blZeXl+ziAABSSLc/p9YdeE4NAHq3XvucGgAAlwqhBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHAGoQYAcAahBgBwBqEGAHBGRk8XAEgJgcCleR9jLs37AF9T3KkBAJxBqAEAnEHzI3ChLlWTYld0pUw0VcJB3KkBAJxBqAEAnEGoAQCcQZ8akEhX+qgC5/8dMZCWnP4409GFfjHTYRUiQRnob0MvxZ0aAMAZhBoAwBmEGgDAGfSpAV7n6kNL0G/WqZ8sUR9bkvrUAoEEfV9WH5rpSFCec/W30ceGXoI7NQCAMwg1AIAzaH5E6rmIYfq+Jka7edFqUgx43yfNOjdRGexzOzrOfJ7UuVnQc64xdnmscz1Njp2aJhn+j16KOzUAgDMINQCAMwg1AIAz6FOD+5I5TD893XPZsx+TpIB32zrm63+7mOVi7Gmy2tvP/PsZtr19bgFZxxj+j16KOzUAgDO6PdSqqqoUCARUXl4e22eM0eLFi1VYWKicnByVlpZq37593V0UAIDjujXUdu7cqbVr1+raa6/17V++fLlWrFih1atXa+fOnQqHw5owYYKampq6szgAAMd1W5/asWPHNHXqVK1bt07PPPNMbL8xRitXrtSiRYs0efJkSdKLL76oUCikDRs2aMaMGd1VJOCUi3n2LCP+JxOw+8kyrT8n77kZ1jHvs2jpXfhu2W71Z1nPsJm2tvh7en6XJLVa254+NrsX7KKeaQN6ULfdqc2ePVsTJ07Urbfe6ttfV1en+vp6lZWVxfYFg0GNHz9e27dvP+O1otGoIpGI7wcAAFu33Klt3LhRu3fv1s6dOzsdq6+vlySFQiHf/lAopIMHD57xelVVVXr66aeTX1AAgFOSHmqHDx/W3LlztXXrVmVnZ5/1PHs4tDGm8xDp/7dw4UJVVFTEtiORiIqKipJTYLjpAqfCCthNgfYw/ays+EZWpv9Ypn/be9wE/cdMpue61rRYxip7wDtE3mpuDLT6h+IHoq3xjZZW3zGT4d8OWMd97OH/vk3rUQGbt/wM78cllvRQ27VrlxoaGjRy5MjYvvb2dr377rtavXq19u/fL+nUHdvAgQNj5zQ0NHS6ezstGAwqGAwmu6gAAMckvU/tlltu0d69e1VbWxv7GTVqlKZOnara2loNHTpU4XBY1dXVsde0tLSopqZGY8aMSXZxAAApJOl3anl5eRo+fLhvX58+fdSvX7/Y/vLyclVWVqqkpEQlJSWqrKxUbm6upkyZkuziAABSSI9MkzVv3jw1Nzdr1qxZOnr0qEaPHq2tW7cqLy+vJ4oDFyTqQ0s0hF/yD9tP1IcmKRD0bGf7m8RNrr8PuSMn3o/WnuPvU+sIxt+nI9PuU/MXzzu6Pq3V36eWFvX3b6U3x/vJ0pqtPrQTJ60Ln73OTEuLtSNeiIBVwIRD/JlCC5dYwJje968sEomooKBApbpLGYHMc78A7ruYUPPO52g9T+Z0qJ2Mxt8z6g8xO9S8z791GkRizz+Z6Lm13ve/G3STNtOqd/SaGhsblZ+fn7TrMvcjAMAZhBoAwBksPQM3eZ89S9DcKFlTXyVqbpSk3JzYrx2X+Zsb2y/zN0e25sdf29rH//2xLSdepvYsq4/K+qoZ8LTmpbf4m+8ymv1/wpnH482cmRF/E2J6hv/CaZ7n47rwVF/nKbUSLVvDFFq4xLhTAwA4g1ADADiD5kf0Thc4Ddapl1rTUHmbI62pr+wRjt4mx7aCHN+xaF//a6MF6Z7f/e/ZepnnmlYLp0n3N/AF2uOvTWvxXyfzmP+1wcb4Zw0G/ecGrSnAvH/8adb0W/YoxUCCFbVNp5XDE0yjxRB/dDPu1AAAziDUAADOINQAAM6gTw1uSDRryDmG9HtXrLaXj7FnCfEO27f70Jr7+a97sn/8faPf9PcdteV5VpLOtvqgrD41efrUAif979Ha5P/c7Z5HBToyrM9pCXhW0Q60WUvatFn9ZglmFOnU/+aZEoVVsnGpcacGAHAGoQYAcAahBgBwBn1qcJN3mqxEz6VJkndmfus5tQ5rdn3v1Ffe59Akfx+aJDUPiPcftffzz5ifmx+fMT8vJ+o7lpHm73dq8/RLNTX7n5s70cdaGcDXJ2hNi9XmL296NP5Z0qJt/mMnref1WuPlD6T7z0383FqCZ9aAbsCdGgDAGYQaAMAZND+i9+jK1FheadZ3twSz9Jugv9nNXtzTO9u+PfWVPWzf2+TYt3+T79jAvPh23+Bx37Fgmr/JLtoRL+9XuX18x45k+VeL/0rx7Wirf/6t9GZriq3j8c+Sccz/OdNO+LcDUU8d2c23dv22d2HYvve/KVNmIQm4UwMAOINQAwA4g1ADADiDPjU4odPq1t5tuy+u07nx73Ym099f1BH0b3tXrPYuHyP5p76S/MP2vX1oknRFn69iv38ry38sO80//P9kR7x/Kz/DP/zfdrIlfm7zcf+fd+tlZ/8s9ue06yHg7Tez6y9B/XqnzJIkwwh/dDPu1AAAziDUAADOoPkRqcduLvOuCG0NT+/ItGbBz/I02dkrVluz7XtnCrGH7XubHEOZjb5jmQH/dVrN2Wfbj7T5Zxj5Mic+5P9Etn9l7o4s/3V8n8X6nJ0fg/BsX+ijFcAlwJ0aAMAZhBoAwBmEGgDAGfSpwX12/1ACxuovskaky3guZewVqq1t72z79tRX3mH7dh+aPaRfHWc/Zl/XN8O/VR67vL7PYn/OrvSbdaF+ge7Gv0YAgDMINQCAMwg1AIAz6FOD+zrOfymUgLX8ScDqNgt4LhVot/qdrG3vitXe5WMk/9RXnZ5Ds4rrPe593Zmu631Puzx2eQMd8Q/X6XN2ZRmYLtQv0N24UwMAOINQAwA4g+ZHpB67ac27UrPVlJbW6t9Ob4m/Nq3Fas476W8KbGqOT2Flr1idaLb9RLP0/6fFWuk66r+u9z3t8qS1+N/H91msz9mpSdFbR6xQja8x7tQAAM4g1AAAziDUAADOoE8NTjAd1lB87xh1uw+ow96O9xcFWv3TTqVFrWmomuN/MpnH/JdpbfJ/RzzRJzv2+5Esf1+Yl718jD31lXfYvt2HdqTJf90Tkfh7Zlrlscub0ezpU7M+p10Pvj42u/4S1K/93wXobtypAQCcQagBAJxBqAEAnEGfGnoPb99NV5ZG6fTMlb+/yLS1xS8b9T8jlt7s3848Hn9mLNjo/07YnuMvU0dm/Nyv5O/7OtkSP/Zljr+fzLd8jPxTX3mfQ5P8fWiSlP5fT/mO+ssTbPT3b2Uej7+P/TntevDWkV1/FzVNFs+8Icm4UwMAOINQAwA4g+ZHuMnEm8SMvayz1XwW8Dattfib3dLs5sdIfK6pYNBqbsywZtv3fGeMtmb5jjQfj//pncjO8b/MXlHbM7u+PfWVPWzf2+SY/aX/OsFG/+f2fhb7c9r1IE8dGbv51m5CNMzaj57DnRoAwBmEGgDAGYQaAMAZ9KnBDVY/jvEMgw/YyzrbQ9JbPf1FGdbQ9hMnfdvpGfHrBtMTfydMa4v3f6U3+/vfWi+LH+vI8veTGatPzbtitb18jD31lXfYvt2HFvzKelzhWHz5G/tzmlarT6010ZB+f3l9U2PRv4ZLjDs1AIAzCDUAgDMINQCAM+hTQ+9kPxuVaNosu78twXNrAfv5LOu6aWnx74H2H0+g3f8+6dH4s2mZx/3fH9s8U2q1Z/nfw1hfNQOePqr0Fv/n9i4fc+p94mXwPocm+fvQJCntmKcf7aT/mP2cmvfZtIt6Lo1psdDNuFMDADiDUAMAOIPmR7jJO01Wh/+7W0DWNE9duKy3oTDNmp0+0ObfTovGh8FnHMv0HesIeob0Z/rLZ7eOep9ISGu138P/Wbyz7dtTX9nD9r1Njibqb6o0LdZ2gln6O61uzTB+9CDu1AAAziDUAADOINQAAM6gTw1uSDTEP8EUWqdO9bzW7i+y+pYSvWegzerfOhnvR0s74e9TM5meqbHS7D41f6dawPs+dj9eq7WMjnfFantYvj31led4p8+ZYCqsLvWhMYQflxh3agAAZxBqAABndEuoff7553rggQfUr18/5ebm6vrrr9euXbtix40xWrx4sQoLC5WTk6PS0lLt27evO4oCAEghSe9TO3r0qMaOHaubb75Zf/7znzVgwAD961//0je+8Y3YOcuXL9eKFSv0wgsv6Nvf/raeeeYZTZgwQfv371deXl6yi4RU5O3LSTSFluR/pq3dPnb2PqGA3f/mfZZLkjx9WIGo/08t4O1HO8cSNj7WVFx2H5uvDJ3K49/2TX1ln3sxz57Rj4YelPRQW7ZsmYqKirR+/frYviuuuCL2uzFGK1eu1KJFizR58mRJ0osvvqhQKKQNGzZoxowZna4ZjUYVjcYfFI1EIskuNgDAAUlvftyyZYtGjRqlu+++WwMGDNCIESO0bt262PG6ujrV19errKwsti8YDGr8+PHavn37Ga9ZVVWlgoKC2E9RUVGyiw0AcEDS79Q+/fRTrVmzRhUVFXriiSe0Y8cOPfroowoGg5o2bZrq6+slSaFQyPe6UCikgwcPnvGaCxcuVEVFRWw7EokQbLhwCYf4W0PkrTmrfA1r9rB3azuQ7llRO92/urXSPNc9V/OorwBW057dTOhtUjxH+Xyz7Z9r6iv/wXMWE+gpSQ+1jo4OjRo1SpWVlZKkESNGaN++fVqzZo2mTZsWOy9g/SEbYzrtOy0YDCoYDCa7qAAAxyS9+XHgwIG66qqrfPuuvPJKHTp0SJIUDoclKXbHdlpDQ0OnuzcAALoi6aE2duxY7d+/37fvwIEDGjJkiCSpuLhY4XBY1dXVseMtLS2qqanRmDFjkl0cAEAKSXrz42OPPaYxY8aosrJS99xzj3bs2KG1a9dq7dq1kk41O5aXl6uyslIlJSUqKSlRZWWlcnNzNWXKlGQXBzj3KtkJ+ogSLVtjAtZ3Qvt9vP1UafZy1gn60exzO7owDZXn3E4rVCcYpn9Ry8cwhB9fI0kPtRtvvFGbN2/WwoULtWTJEhUXF2vlypWaOnVq7Jx58+apublZs2bN0tGjRzV69Ght3bqVZ9QAABclYDp9nfv6i0QiKigoUKnuUkYg89wvALy6MtrQuhsL+EYtWndUadZExN734U4N8GkzrXpHr6mxsVH5+flJuy5zPwIAnMHSM0g9ie4sztHf1qVn2rx3cvb0VmlduFtMpAvPk13Us2fcjaGX4E4NAOAMQg0A4AyaHwGvJA7/t5snfZc1yWl+TNik2PnkLpxLcyN6J+7UAADOINQAAM4g1AAAzqBPDUjkIob/J7zs2bvbLh36zeAg7tQAAM4g1AAAziDUAADOoE8NuFBd6ZPqyiTKF4N+MqQ47tQAAM4g1AAAzqD5EbgUaBYELgnu1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAziDUAADOINQAAM4g1AAAzkh6qLW1tenJJ59UcXGxcnJyNHToUC1ZskQdHR2xc4wxWrx4sQoLC5WTk6PS0lLt27cv2UUBAKSYpIfasmXL9Pzzz2v16tX6xz/+oeXLl+vnP/+5Vq1aFTtn+fLlWrFihVavXq2dO3cqHA5rwoQJampqSnZxAAApJCPZF/zrX/+qu+66SxMnTpQkXXHFFXr55Zf1/vvvSzp1l7Zy5UotWrRIkydPliS9+OKLCoVC2rBhg2bMmNHpmtFoVNFoNLYdiUSSXWwAgAOSfqc2btw4vfnmmzpw4IAk6YMPPtC2bdt0++23S5Lq6upUX1+vsrKy2GuCwaDGjx+v7du3n/GaVVVVKigoiP0UFRUlu9gAAAck/U5t/vz5amxs1LBhw5Senq729nYtXbpU999/vySpvr5ekhQKhXyvC4VCOnjw4BmvuXDhQlVUVMS2I5EIwQYA6CTpofbKK6/opZde0oYNG3T11VertrZW5eXlKiws1PTp02PnBQIB3+uMMZ32nRYMBhUMBpNdVACAY5Ieao8//rgWLFig++67T5J0zTXX6ODBg6qqqtL06dMVDoclnbpjGzhwYOx1DQ0Nne7eAADoiqT3qZ04cUJpaf7Lpqenx4b0FxcXKxwOq7q6Ona8paVFNTU1GjNmTLKLAwBIIUm/U7vzzju1dOlSDR48WFdffbX27NmjFStW6OGHH5Z0qtmxvLxclZWVKikpUUlJiSorK5Wbm6spU6YkuzgAgBSS9FBbtWqVfvrTn2rWrFlqaGhQYWGhZsyYoZ/97Gexc+bNm6fm5mbNmjVLR48e1ejRo7V161bl5eUluzgAgBQSMMaYni5EV0UiERUUFKhUdykjkNnTxQEAdFGbadU7ek2NjY3Kz89P2nWZ+xEA4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgDEINAOAMQg0A4AxCDQDgjC6H2rvvvqs777xThYWFCgQC+sMf/uA7bozR4sWLVVhYqJycHJWWlmrfvn2+c6LRqB555BH1799fffr00Q9+8AN99tlnF/VBAADocqgdP35c1113nVavXn3G48uXL9eKFSu0evVq7dy5U+FwWBMmTFBTU1PsnPLycm3evFkbN27Utm3bdOzYMd1xxx1qb2+/8E8CAEh5AWOMueAXBwLavHmzJk2aJOnUXVphYaHKy8s1f/58SafuykKhkJYtW6YZM2aosbFR3/rWt/Tb3/5W9957ryTpiy++UFFRkV5//XXddtttnd4nGo0qGo3GtiORiIqKilSqu5QRyLzQ4gMAekibadU7ek2NjY3Kz89P2nWT2qdWV1en+vp6lZWVxfYFg0GNHz9e27dvlyTt2rVLra2tvnMKCws1fPjw2Dm2qqoqFRQUxH6KioqSWWwAgCMyknmx+vp6SVIoFPLtD4VCOnjwYOycrKwsffOb3+x0zunX2xYuXKiKiorYdmNjowYPHqw2tUoXfJ8JAOgpbWqVdKqFL5mSGmqnBQIB37YxptM+W6JzgsGggsFgbDsSiUiStun1iywpAKAnNTU1qaCgIGnXS2qohcNhSafuxgYOHBjb39DQELt7C4fDamlp0dGjR313aw0NDRozZsx5vU9hYaEOHz4sY4wGDx6sw4cPJ7VN1iWn+x+po8Sop3Ojjs6NOjq303V06NAhBQIBFRYWJvX6SQ214uJihcNhVVdXa8SIEZKklpYW1dTUaNmyZZKkkSNHKjMzU9XV1brnnnskSUeOHNFHH32k5cuXn9f7pKWladCgQbE7tvz8fP4BnQN1dH6op3Ojjs6NOjq3goKCbqmjLofasWPH9Mknn8S26+rqVFtbq759+2rw4MEqLy9XZWWlSkpKVFJSosrKSuXm5mrKlCmSTn2QH/7wh/rxj3+sfv36qW/fvvrJT36ia665RrfeemvyPhkAIOV0OdTef/993XzzzbHt0wM4pk+frhdeeEHz5s1Tc3OzZs2apaNHj2r06NHaunWr8vLyYq/5xS9+oYyMDN1zzz1qbm7WLbfcohdeeEHp6elJ+EgAgFTV5VArLS1NOFolEAho8eLFWrx48VnPyc7O1qpVq7Rq1aquvr1PMBjUU0895RtEAj/q6PxQT+dGHZ0bdXRu3V1HF/XwNQAAXydMaAwAcAahBgBwBqEGAHAGoQYAcAahBgBwRq8Oteeee07FxcXKzs7WyJEj9d577/V0kXpEVVWVbrzxRuXl5WnAgAGaNGmS9u/f7zvnfBZvTSVVVVUKBAIqLy+P7aOOTvn888/1wAMPqF+/fsrNzdX111+vXbt2xY6nej21tbXpySefVHFxsXJycjR06FAtWbJEHR0dsXNSrY6+VotHm15q48aNJjMz06xbt858/PHHZu7cuaZPnz7m4MGDPV20S+62224z69evNx999JGpra01EydONIMHDzbHjh2LnfPss8+avLw88+qrr5q9e/eae++91wwcONBEIpEeLHnP2LFjh7niiivMtddea+bOnRvbTx0Z89VXX5khQ4aYhx56yPz97383dXV15o033jCffPJJ7JxUr6dnnnnG9OvXz/zpT38ydXV15ve//7257LLLzMqVK2PnpFodvf7662bRokXm1VdfNZLM5s2bfcfPpz5mzpxpLr/8clNdXW12795tbr75ZnPdddeZtra2LpWl14bad77zHTNz5kzfvmHDhpkFCxb0UIm+PhoaGowkU1NTY4wxpqOjw4TDYfPss8/Gzjl58qQpKCgwzz//fE8Vs0c0NTWZkpISU11dbcaPHx8LNerolPnz55tx48ad9Tj1ZMzEiRPNww8/7Ns3efJk88ADDxhjqCM71M6nPv73v/+ZzMxMs3Hjxtg5n3/+uUlLSzN/+ctfuvT+vbL5saWlRbt27fItNCpJZWVlZ11oNJU0NjZKkvr27Svp/BZvTRWzZ8/WxIkTO80zSh2dsmXLFo0aNUp33323BgwYoBEjRmjdunWx49STNG7cOL355ps6cOCAJOmDDz7Qtm3bdPvtt0uijmzdtXj02XTLemrd7csvv1R7e/sZFyM920KjqcIYo4qKCo0bN07Dhw+XdH6Lt6aCjRs3avfu3dq5c2enY9TRKZ9++qnWrFmjiooKPfHEE9qxY4ceffRRBYNBTZs2jXqSNH/+fDU2NmrYsGFKT09Xe3u7li5dqvvvv18S/5Zs3bV49Nn0ylA77UIWI3XdnDlz9OGHH2rbtm2djqVyfR0+fFhz587V1q1blZ2dfdbzUrmOJKmjo0OjRo1SZWWlJGnEiBHat2+f1qxZo2nTpsXOS+V6euWVV/TSSy9pw4YNuvrqq1VbW6vy8nIVFhZq+vTpsfNSuY7OJNmLR59Nr2x+7N+/v9LT0zsluHcx0lT0yCOPaMuWLXr77bc1aNCg2H7v4q1eqVRfu3btUkNDg0aOHKmMjAxlZGSopqZGv/zlL5WRkRGrh1SuI0kaOHCgrrrqKt++K6+8UocOHZLEvyVJevzxx7VgwQLdd999uuaaa/Tggw/qscceU1VVlSTqyHY+9eFdPPps55yvXhlqWVlZGjlypKqrq337q6urz3v1bJcYYzRnzhxt2rRJb731loqLi33HvYu3nnZ68dZUqa9bbrlFe/fuVW1tbexn1KhRmjp1qmprazV06NCUryNJGjt2bKfHQQ4cOKAhQ4ZI4t+SJJ04cUJpaf7/daanp8eG9FNHfudTH97Fo087vXh0l+vsgoa3fA2cHtL/m9/8xnz88cemvLzc9OnTx/z73//u6aJdcj/60Y9MQUGBeeedd8yRI0diPydOnIid8+yzz5qCggKzadMms3fvXnP//fc7PcT4fHhHPxpDHRlz6nGHjIwMs3TpUvPPf/7T/O53vzO5ubnmpZdeip2T6vU0ffp0c/nll8eG9G/atMn079/fzJs3L3ZOqtVRU1OT2bNnj9mzZ4+RZFasWGH27NkTe8TqfOpj5syZZtCgQeaNN94wu3fvNt/73vdSa0i/Mcb86le/MkOGDDFZWVnmhhtuiA1hTzWSzvizfv362DkdHR3mqaeeMuFw2ASDQXPTTTeZvXv39lyhvwbsUKOOTvnjH/9ohg8fboLBoBk2bJhZu3at73iq11MkEjFz5841gwcPNtnZ2Wbo0KFm0aJFJhqNxs5JtTp6++23z/j/oOnTpxtjzq8+mpubzZw5c0zfvn1NTk6OueOOO8yhQ4e6XBbWUwMAOKNX9qkBAHAmhBoAwBmEGgDAGYQaAMAZhBoAwBmEGgDAGYQaAMAZhBoAwBmEGgDAGYQaAMAZhBoAwBn/B4WJAeOh+CQCAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(us[9500])\n",
    "plt.clim(-1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c4dc811-1f8d-4384-85ee-3d2974058cfa",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
