{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b2672f55",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/lib/python3/dist-packages/ipykernel_launcher.py:8: MatplotlibDeprecationWarning: Support for setting the 'text.latex.preamble' or 'pgf.preamble' rcParam to a list of strings is deprecated since 3.3 and will be removed two minor releases later; set it to a single string instead.\n",
      "  \n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append(\"code\")\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['text.latex.preamble'] = [r'\\usepackage{lmodern}']\n",
    "\n",
    "from sklearn.metrics.pairwise import euclidean_distances\n",
    "from scipy import optimize\n",
    "    \n",
    "%matplotlib notebook\n",
    "\n",
    "%matplotlib notebook\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb28218f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "591e86db",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0708886424405295\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f9747e23400>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAEICAYAAABS0fM3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAug0lEQVR4nO3deXQb130v8O/lAm4SCZJaLZmSwVhyvCQyCKW227jME+gsXs6rTUpO7aZ2EoHNS3vqNo4QN2le29SVyTo5yWuzEM5rmTy7jkTadSKncUIosZtYSiwAlm3ZsSwR1h4tXCCJBFfgvj8wAEESBAFygBlgvp9zcMgBMMCPQ+D+5i5zr5BSgoiIjKtA6wCIiEhbTARERAbHREBEZHBMBEREBsdEQERkcEwEREQGV6R1AAuxbNkyuX79eq3DICLKKV6vt09KuXzm/TmZCNavXw+Px6N1GEREOUUIcTzR/WwaIiIyOCYCIiKDYyIgIjI4JgIiIoPTTWexEKIZQACAVUrZrnE4RESGoYsagRDCCgBSSjeAQHSbiIgyTxeJAMA2RGoDAOAHYNcuFCIiY9FLIjADGIjbrtUoDiIiw9FLIpiXEMIhhPAIITwXLlzQOhxDa+zsRGNnp9ZhEJFK9NJZHABQo/xuBtA/8wlSShcAFwDYbDYuq0ZEeSUUlpgIhTEZlgiFJCbCYUyGpu6bDIVRZirE2upy1d9bL4lgFwCb8rsFgFvDWIgoz0yEwhibDGNsIhT5ORnG2GQIE5MS46EQxicjBW70Nh6SGJ+M254MY0IplKP3j0efr+w7HvfYREhOPR63//hkGJOzCvhIoZ/KqsH2967Ed//UNv8T06SLRCCl9AkhbEIIO4CAlNKndUxElBnhsMTIRChyGw8hOB75PTg+idGJyHZwPDSt0B6N/j6jIB+bmPH4ZPR5cb9PhhEK50YjQnGhQFFBAYoKBYoLC1BUoPwsFCgqEFhVVZKR99VFIgBiTT9EpCPjk2EMj01iaMZteGwSQ6PTt4PjkYJ9RCnMR6YV8GEExyPPGZsMZ/3vKCoQKCkqQElxYeRnUQFKigphKipAsVLoRn4vgKmwAMXK/abCyH3FhQUoLopsTz1eAJOyb7Fyn6lQxF4nejMp+xYXFqC4IPJ7UUHk9YviCvvCApH14xI7Ppq9MxFlVCgscWlkApdGJ3BxZOp2aWRy2vbl0Ym4wj6EobEJDI+FMDQ6ifFQZgrtsuJClJkKYz/LZ/xeWhzZLo0V3IUoKZ4qwEuLlfuKCpT7E98XLfSLCnNmXIwmmAgobR133KF1CIYipcTweAiDw+PoHx6f9nMgOI6BoXEERsaVgn0yUviPTODy2OSi37uoQKCipAhLorfSIlSUFGFpSREqSgrjfi+KFOamommFelnxVMFebipEuakIJUUFKNDw7JdmYyKgtG1ctkzrEHJeOCwxEBzH+UtjOH95FOcvj+GCchsYHp9+C45jfAHNKUIAS0uKUFVejKqyYlSWRn5Gb5XRW+lUQV9RUoSlSmG/pCRSaAvBQjvfMRFQ2vYcPgwAuHPjRo0j0adLoxM4ExjBmcAIfndxVCnsx3BBKfDPXxpD39AYJtPowCwrLkRNhQk1FSZUV5hQW2FCdbkJtUsiP6vLpwr36M+lJUU886aUMBFQ2r66fz8AYyaCyVAYZy+N4kxgFGcCIzitFPiRW+S+VJtkzOXFWLG0BCuWlmLF0hIsryzB8iUlqF1iQk1FCWrKTahZYkJNuQllpsIM/2VkZEwElLburVu1DiGjxiZDODkwghMDwzjWF8SJgSCO9Q/jeH8QpwaDmAglP5MvKy7EmuoyXGEuw+rKUqyoLIkU9Evjfy9BSRELd9IHJgJK27Jy9a9szDYpJfqHx3Hk3BCOnr+MI+eH0HthCMf6gjhzcSTpxT0rlpZgrVLQrzFHfkZupVhjLkNVWTHb1SmnMBFQ2joPHgQAPLBpk6ZxpCoQHMdbZy7h7bNKgX9+CEfOX8ZgcCLh8wsEsLamDOtqKrCuthzraytQF/1ZU85mGso7TASUNr0mAiklTgdG8OaZS3jrzCW89bvIz9OBkYTPX1JShPesWIKrVyzB1SuX4D0rlmB9bQXWVpfDVMRx52QcTASUswLBcRw8GcCrJwJ49WQAr58KIJDgLL+0uADXrKrEe1cvxdUrluLqlUtw9YqlWFlZwiYcIjARUI4IhyUOn7sM7/FBpeAfhP/C8Kzn1VaYcO0VlZHb6kpcd0Ulrlq2RNPL94n0jomAdCla8P/a349f+/vxm3cHZp3tlxQV4IY1Vbixzowb66qx6UozVleV8iyfKE1MBKQbJweCePHwebx8tB+/ebd/VmfuFVWl2HxVDax11bixzoxrVlWyLZ9IBUwEpJmxyRAOvDuIXxw+jxcPn0fvjKae1VWluNlSi5uU25U1ZTzbJ8oAJgLKqkujE9j723P4yRtn8aujfQiOh2KPLS0pwh9cvQy3bliOW+prUVdTzoKfKAuYCCjjBofH0fPWOfzXod/h5aN9067MvWbVUjRuXIEPbVwO67pqFHO6YKKsYyKgjAiOT+Knb57Fs77T2NfbH1shqkAAN1lq8NHrV+O261ZidVWZxpESka4SgRDCymUq9W+uuYbCYYlf+/vxjO80fnLod7Fmn6ICgQ9evSxW+C9bkpnl9ohoYXSTCJT1itsANGgdCyU3c66hc5dG8YNXTmLXgRM4c3E0dn/DumrcbV2D229YDXO5KdthElGKdJMIpJRuIcSA1nFQck+98RT+8iefR//IWaysWIPrK1px7KQ1Nrf+2uoy3G1diz+6cQ2uWlahcbRElArdJALSv6feeArbf+TAyGQQAHBu+BTOD/0jlhX8Be659l7cf9M63Gyp5WIoRDnGcEM0Gjsb0XmwEwAwEZpAY2cjnnz9SQBAcCKIxs5G7Dq0CwBwcfQiGjsb8exvnwUA9AX70NjZiD2H9wAAzg6dRWNnI144+gIA4OTFk2jsbITb7wYA+Af9aOxsxEvHXgIAHO47jMbORuw7uQ8AcOj8ITR2NuLA6QMAgINnD6KxsxEHzx4EABw4fQCNnY04dP4QAGDfyX1o7GzE4b7ICmEvHXsJjZ2N8A/6AQBuvxuNnY04efEkAOCFoy+gsbMRZ4fOAgD2HN6Dxs5G9AX7AADP/vZZNHY24uLoRQDArkO70NjZiOBEpKB/8vUn0djZiInQBAaGx+H40Z/HkkCUFGMoqdmFb9/fgNcGd+P2pz8We+wbv/4G7nr6rtj24/sexz2774ltP/arx3Bv972x7a+89BXc/+z9se0v/+LLePCHD8a2H3E/AsceR2z74Z89jM/++LOx7YdeeAgPvfBQbPuzP/4sHv7Zw7Ftxx4HHnE/Ett+8IcP4su/+HJs+/5n78dXXvpKbPve7nvx2K8ei23fs/sePL7v8dj2XU/fhW/8+hux7Y8+9VF868C3Ytv279vxhPeJ2DY/ewv77AFA58FONHY2xo7lE94nYP++Pbb9rQPfwkef+mhsO98/e2rLWo1ACOFIcLdfSulOY38HANTV1akZGiUxPhnG3+85hG7vWQQLA0CCk/3Tl09lPS4iUo+QyVbgyDIhRI+Usmm+59lsNunxeLIRkmGdvzSKb73Yi//4zQmMhyILp/ct+TSGQ2dnPXdd1Toce+hYliMkonQJIbxSStvM+3XTRyCEaAZgE0I0Sym7tY7HqPqHxvCdl3rx/f3HMTYZSQC3v281/uJ/vAfeC4/DsccRq74DQHlxOR7d8qhW4RKRCnSTCJTCnwlAI6MTIfz7y8fwzV8cxZCy+PqHr1uJv2ragGtWVQIArll1HwDgUz/8S4yF+rGuah0e3fIo7rvhPs3iJqLF000iIG1IKfFfb5zFYy/8FicHIit5NW5cjodv24jr11TNev59N9yHJ7yRDrwXH3ggm6ESLZrT6URtbS3MZjMcjkTdltpqampCT09P1t+XicDA3jpzCf/7R4dw4NggAGDDyiX40u3X4tYNyzWOjEh9bndkXIoeE4Db7Ybf74/FmG1MBAY0Mh7C1/e+g+/+8l2EwhK1FSb89W0bsM12JYo46Rvlqa6uLrS2tsJsNmsdyix2e2QorNPp1OT9mQgM5qV3LuBLz72BkwMjEAL405vX4XMf3ojK0mKtQyPKmO7ubuzevRsNDZEZbKxW67z7BAIBuFyupM/RaxNTunQ1fDRVHD6avkBwHH/3ozfx3MEzAID3rq7EzrtvwKYrzWm/VmNnJwD2EVBuqa+vR29vr9ZhJFVdXY3BwcGMvb7uh49S5vz3Oxfw+e7XcO7SGEqLC/BX9g345B9cxbn/yTB8Pl9KtQA1uVyupImnqakp1iSkNSaCPDYyHsJjP/ktvrf/OADAWmfG17ZuwnpOBkcG4/F4sHnz5rT2WWzTUC41GTER5Kkj5y7jfz3lw5HzQygqEPirpg1ovdWiSmcwm4Qo13i9XrS0tEy7z+VywWKxoKenB9u2bZtVYzCbzdixY0c2w9QM2wby0H++egp3/evLOHJ+CPXLK/DcZ38fn/3QezgiiAzL4/HAZptqGne73QgEArDb7QgEAllvNprJ5/Ohvb0dgUAATqcz68NIWSPII6MTIfz9njfx9CuRGSD/6MY1+Mf/eT0qStT9Nz++LzKD5cO33KLq6xJlSk1NzbRho9FaAAAMDAwgEAhoOqzUarXCarVqVgPhKWKeOHtxFFs79uPpV07CVFSAx+6+AV/b+n7VkwAA7D91CvtPccZR0rfo2bXP55vVLLRt2zYMDAzA7XbDYrHA6KMQWSPIA6+dDGD79z04f3kMV9aU4Tv3N+C6K2ZPD6GWZ+ZYs5hIjzwez6yO2/imIL2M3NESE0GO++HB09jR/TrGJsP4vatq8O37G1BTwfWBicxmM9ra2rQOIycwEeQoKSW++YujePxn7wAAPv6BK/H3d10PU1HmW/seUTqydvJMiigvMBHkoFBY4h/2vInv7T8OIYC/vf1aPPj76yFEdtYKZv8AUX5hIsgxY5Mh/PWu1/DjN34HU2EBvn7vJnzshtVah0VEOYyJIIcMjU3C8X0P9vX2Y2lJEVyfsOHm+lqtwyKiHMdEkCMuj07gwX8/AM/xQSxfWoLvPfgBXHtFpdZhEVEeYCLIAZdHJ/Cn//YKfCcCWF1Viqe338T5gohINbpJBEKI6EDfeimlNqsz6NAlJQm8eiKANeYyPL39JtTVlmsdFhHlEV1cWSyEsANwSyldACzKtuENjU3iT/7vVBL4gYNJgIjUp4tEAMACIFr4+5VtQxudCMHxfQ9eOxnA2uoy7Gq9CVfWMAkQkfp00TSk1ASirAB2zXyO0nTkAIC6urosRaaNyVAYf/mDV7Gvtx/Ll5bgqU//HtZW6ycJ1JbrJxYiWjxdLVUphLACsEsp25M9L5+XqpRSwvnM69jtOYXK0iLsar0Z713N0UFEtHiaL1UZ1xkczy+ljJ94e94kkO/aXjiM3Z5TKC0uwL89sJlJgIgyLmuJYEbzzyxCCEc0CQgh7DMShCH84JUT+M5LvSgqEPj2/Q2wra/ROqSEONcQUX7RRWexMkqoTQjRK4QY1DoeLbx8tA9feu4QAODRP7oeH9q4QuOI5tY/MoL+kRGtwyAileils9gNoFrrOLRy9PwQPvOkF5NhidZbLdi2Wd+d4a4779Q6BCJSkS5qBEY2MDyOT33vAC6NTuK2a1fC+ZFrtA6JiAyGiUBDk6Ew/vw/fDjeH8T1ayrx9Xs3oaAgO1NJL4Zjzx449uzROgwiUokumoaM6qs972Bfbz+WLSnBdz+xGeWm3Ph3vNPfr3UIRKQi1gg08rM3z+LbL/aisEDgX//4RqyqKtU6JCIyKCYCDbzbN4zP7X4NAOD8yEbcZOGaAkSkHSaCLBsZD+EzT3pxeWwSH7luFbZ/0PDTKhGRxpgIsuwfnn8Tb5+9DMuyCvxzy/uyts4wEdFcmAiy6IVDZ/H0KydhKirAN++zYmlpsdYhERExEWTLuUuj+MKzrwMAvvCRaziHEBHpBhNBFoTDEp/b/RoCwQncumE5HrhlvdYhERHF5MbA9Rz3by+/i18d7UNNhQmPN78vJy4aS2ZDLUc5EeUTJoIMe/vsJbS/cBgA0H7P+7CiMvevF+BcQ0T5hU1DGTQZCmNH9+sYD4Xx8Q/UwX7tSq1DIiKahYkgg777q3fx+qmLuKKqFH/zsfyZTI5zDRHlFzYNZUjvhSF8recdAMA/3X1DXg0VrS0r0zoEIlIRE0EGhMIy0iQ0GUZzw1o06niRmYXgymRE+YVNQxnw9Csn4D0+iOVLS/C3t1+rdThEREnppkagLFcJAE1SSqemwSxC39AY2l94GwDwd3deh6ry/GkSirpn924AwDNbt2ocCRGpQRc1AiGEFZEE4AZgVbZz0s7/ehuXRidx64bl+NgNq7QOJyP6g0H0B4Nah0FEKtFFjUBK6QPgUzZrlO2c88q7A3jGdwqmogL8w13XcUI5IsoJuqgRRAkhdgDYqXUcCzERCuNvnzsEAPjMH9Zj/bIKjSMiIkqNrhKBlLIdQKsQYtYk/UIIhxDCI4TwXLhwQYPoknvq18dx+NxlrKstx2ca67UOh4goZVlrGhJCOBLc7ZdSuqN9AnFNRM0A2uOfKKV0AXABgM1mkxkONy0XgxP4+t4jAIAvfuy9KC0u1DgiIqLUZS0RKAX5XOyY6iMwAziQ8YBU9C8/P4JAcAI3WWrQxGkkiCjH6KVpyAXAIoRoBhCQUnZrHVCqjvcP43v7j0EI4Eu3X8sOYiLKOXoZNRSA0uwDIGeSAAA89pO3MRGSuMe6FtevqdI6HCKitKWcCIQQ6wG0AGgCEN9GHwCwS0r5rKqR5QDv8QH85NBZlBYX4PMf3qh1OFlz89q1WodARCqaNxEIIaoAPALgKIBuKeU/J3jOFiHEdwD8zEgJ4fGfRiaV2/5BC1ZV5f46A6niXENE+SVpIlCSQIuU8gvJniel3AtgrxDiKiHE3UZIBvt6+7Df34/K0iJ8+oOzRrsSEeWMpIlASnkRwHdTfTEp5bsA3l1sUHonpcTXfjZVG6gqy7/5hJLhXENE+UUXncW55pdH+uA5Pojq8mI8+AdXaR1O1rGPgCi/pJQIhBCbEBnWeSyj0eQAKSW+qiw40/qH9VhSYrxc+vAtt2gdAhGpKNXrCGoAzNsQrowsymsvHr6A104GsGyJCZ+4eZ3W4RARLVqqieA2zJMIhBA/BdAmhHh40VHp2LdePAoAaL21HuUm49UGAKCxsxONnZ1ah0FEKkmpJJNSfkEZEbRJSnlw5uNCiKsA1Esp3yOE2KJ2kHrhPT6AA8cGUVlahI//Xp3W4RARqSLlKSaUEUFCCHF3gocdADqU3/1qBKZH33kp8qf9yc3rDNk3QET5Ka3STEr5qhAiIIR4DJGri3sB2ABskVJerTwnL4ePHj1/GT1vnYOpqAAP3GK8kUJElL/SPq1VCvovKBeb2QC8K6X8M9Uj05kn/juS31oa1mL50hKNoyEiUs98Vxavn2vIqHKx2d509slVgeA4njt4GgDwKQNeN0BE+S1pH4GU8pgQ4vOpDgsVQmxHZD2BvNLlOYWxyTBu3bAcluVLtA6HiEhV8zYNSSn/WQixXVlFrBeRBWSiHcJmRIaVfgBAFQCnlPJShmLVRDgs8eRvjgMAPnETrxsgovyT6vDRJwBACHEjIquJ3YZIEgggsprYTqWpKO+8dOQCjvcHscZchg9ds0LrcIiIVJf2qCEAr2YoFl36f/sjtYH7b1qHwgKuPgYAd2zYoHUIRKSiRQ+Gj15kJoSoBGCTUv58ka+3Q0rZPv8zM+/sxVH84vB5mAoLsG3zlVqHoxuca4gov6hxVdS9Qog/Q2Q+ol4AC04EQgg7gM0qxKSK5w6ehpSA/doVqKkwaR0OEVFGqJEIepSFaZBP00tIKfGM9xQA4O4bOe1yvOg8Qy8+8ICmcRCROtRIBBalE9mN6WsZp0UIYZVSuoUQrSrEtGhvnrmEI+eHUFNhwh9uXK51OLrywKZNWodARCpKdT2CTwPYnWhoqJTyCaUmcC+AHywilppF7Ku6Z32RC8juev8VKC5MeUomQ2AiIMovqdYIzNFfEs1AGl2zONkLCCEcCe72K7UAq5TSncL+DgCoq8vszJ8ToTB+9FokEdxtXZPR98pFfcEgAGBZebnGkRCRGlJNBMsAPCKE2IXI/EIH030jKaUrycMWIYQl7nerlNKXYH8XANhstgU3QaViX28/+obGUb+8AjesqcrkW+WkZmXNYvYREOWHdNYj2ALgzwBsFUI4EbnC+IDy07OYK4qllN1A7KzfvNDXUcsLh84CAG5/3xUQgtcOEFF+S2c9gr3KLKPblSmnHwNwEcBWAD8XQvxU6UtYMCmlS0pZP7M2kE2hsETPW5FE8JHrVmkVBhFR1ixkGupnlJ/Rq4yfiD4mhLhRCPFpKeV31Qsxu3wnBtE3NI4ra8rw3tVLtQ6HiCjj1F5maxsWMYRUD36qNAt9+NpVbBYiIkNQOxHsVPn1su7nb58HANzGZiEiMghVE0Guz0B6ciAIf98wlpYWwVpn1jocIqKs4JVScX55pA8A8Pv1y1DEi8iIyCBY2sX55ZELAIAPblimcSRERNmjdh9BzpoMhfHy0UiN4NarObdQMpxigii/sEageP30RVwancT62nJcWTP/1AlNTU0QQqC6unrarbu7OwvRauuBTZsWnAxcLhcaGhpix87pdKobHBGljYlA4Tk2AAC4ub425X3a2towODg47dbc3JypENMihIDPl5nr8vqCwdh8Q+lobW1FR0cHurq6IKWE1+tFbW3qx1svMnlsibTARKDwHh8EADSs09UkqAvm9XphtVoz8trNu3fH5htKldvtxu7du+H1emGxRKaVslgs2LFjx6LjaW1thcuVbCordV87k8eWSAvsI0BkERrv8QAAoGFdtbbBqCSTBdXnbr457X3a2trwyCOPZCCa7GMSoHzDGgGAkwMj6BsaQ02FCetrFz+1cmtrK1pbp9bXcTqdaGlpAQBUV1ejvb0d9fX1s/oU4u+P3z+6X3d3d+xxtzsya3cgEEBTU1OsjyJ69lpdXY1AIAAA8Pv9aGhoQHV1NVpaWmL3J3vdZO7cuBF3btyY1jHxeDyw2+1Jn7OQOFtaWuByueB0OlFfXx+7v7q6Gj6fDw0NDbFjkuz4+v3+WL9P9HWSvXamji2RJqSUOXdraGiQavpP3ym5zvm8/FTngZT3sdvtEoA0m83TblFWq1V2dXVJr9crLRZL7H6z2Szb2tqklFJ2dXVJAHJwcDC2PXP/+P0cDoeUUsqOjg5pt9tjv+/YsSP2vN7e3tjzo69rNptlT09P7PlWq3Xe103m7QsX5NsXLsz7vHgAYrHNZaFxOhwO2dHRMeu1LBZL7PWknP/4Rrd7e3ul1+tN+tqZOrZEmYTITNGzylTWCDDVP2BdZ05rv0SdxVFdXV2xmkBXV9e0/aIdys3NzbBarbEzxfiOZrvdjp6enmn7RWsVdrsdHo8ndr/b7Y51Xkbb36NcLhfsdnvsbNzhcCAQCEzr7JzrdefS+vzzaH3++XmfF89sNk87W54pE3E6nc5ptZC5jm93dzdsNlvscYvFklLzTyZiJtICEwGAV08qiaBOvf4Bi8UCu90+b6Fis9ng9/sBRJoZWltb0dDQkHAY6sxCHogUPna7HVu2bEnY/NDb2ztrP4vFEnvPuV5XbTabLWnTSCbinNkUNdfx9fv9CzoGejm2RItl+EQwGQrjnXNDAIDrrqhU7XV9Ph88Hg/MZnPSaws8Hk+ssGhoaEBLSwu8Xu+sNuxkojWTJ554Yta4/Pr6+mkFE7Dwgm8xnE4ndu7cOWetIBNx1tRMHwE21/GdWXinSi/HlmixDJ8IjvUHMT4ZxhpzGZaWFqv2utEmoWgTUXyBEU0MLpcLfr8fzc3NscdtNhsCgcCsZqG5xDcLmc3mWY9v3boVbrc7djbe3t4Os9mc9ZEvdrsdW7duxZYtW2LxBgKBWIG8mDjNZjN6e3sRCATmLNCTHd/m5mZ4PJ7Y/8Xv98c6mJO9tl6OLdFiGT4RHD57GQBwzar0F6FxOp0QQky7RfsFWltbY2eGHR0daGpqiu3X39+P+vp6tLW1Ye/evQCmmpKqq6uxZcuWhIX6XLZv3x4bCdPW1jbtMbPZjL1798LpdKK6uho9PT2x98y2jo4OtLa2Yvv27RBCoKGhAQ0NDYuOs6mpKXbF8lyJYL7j6/V6sXPnTggh0NLSEvvfJXttPR1bosUQkY7k3GKz2aRaHW9f63kH/2fvEXymsR7Oj1yjymsmU11dPe2iqlzU2NkJgIvXE+UaIYRXSmmbeb9uagRCiDblpyOb73v47CUAC6sREBHlA90kAgAOIUQvgPR77RYh2jS0kYmAiAxKT1NMtEgpM3rp5UMPPYSDBw/GtsNS4pV3ByCEQOv+GmRjieL3v//9+OQnP5n5N8qgC+dex6Z1ANZ2ah0KkbFUbwIavq76y+opEViVxeKtUsr2mQ8qTUYOAKirq1PlDUfGQwCAsuKCrCSBfLHUZMISk9ZREJFadNdZrPQV9CSrHajVWfyM9xQ+1/Uabn/fanzzjznkj4jy21ydxVmrEczRCeyXUrqFEM0AIKXsBtAPICtDao4PRObUV2OiOSM53BdZyW3jMi7pSZQPspYIpJTJJoz3Y6qTuB5AR+YjAk4qiWBdTUU23i5vROcZ4vBRovygiz4CKaVPCOEQQgwA6JVSZmX5p+P9wwCQ0tKUNOWftmzROgQiUpEuEgEwb40hI04MjAAA1rFpKC23XHml1iEQkYr0dB1BVgXHJ9E3NAZTYQFWVpZqHU5O2XfyJPadPKl1GESkEsMmgjOBSG1gtbkUhQUcO5qOv9m7F3/DOXWI8oZhE8HvLo4CAFZXsTZARMZm2ERwVkkEq9gsREQGx0RQVaZxJERE2jJuIrgUrRGUaBwJEZG2jJsIWCMgIgJg5EQQrRGws5iIDM6wieDC5TEAwIqlbBoiImMzZCKQUmIwOA4AqKngfMpEZGy6mWIimy6PTWIiJFFhKkRpcaHW4eQczjVElF8MmQgGhpTaAFdXWRDONUSUXwzZNNQ/rCSCciaCheBcQ0T5xZCJYHCY/QOLwbmGiPKLMZuGYomAI4YWouOOO7QOgTQUDofR19eHQCCAUCikdTikKCwshNlsxrJly1BQkN45viETQaxpqKJY40hyE5eoNLZTp05BCIH169ejuLgYQnD2Xq1JKTExMYFz587h1KlTqKurS2t/YzYNBVkjWIw9hw9jz+HDWodBGhkeHsaaNWtgMpmYBHRCCAGTyYQ1a9ZgeHg47f11UyMQQlihLFqvLGKfMQOsESzKV/fvBwDcuXGjxpGQVtJteqDsWOj/RU//zVYlAViUpJAxQ6OTAIClpUwERES6qBEIIZoB9AKAlLI90+83NBZJBEtKdPHnExFpSi81gs0AaoUQViHEjky/2eVoIihlIiAi0ksiAIB+KaUPiNUQphFCOIQQHiGE58KFC4t6o6HRCQDAUtYIiEjR2tqKlpYW+P1+AIDL5YLT6UQgEJj13Ohz5pNoXz3KWiJQCvKZN7vycC+A6JH1I1JDmEZK6ZJS2qSUtuXLly8qluGxyNjnCiYCIorzyCOPwGKxAAAsFgva2tpgNpunPae9vT32nPns3r07J5JB1kpCKaUrycNuANFagAXAgUzGMsSmISLDczqdqK2thdlshsPhgNvtRkdHR9J9XC4XmptnNVjEXq+pqQk1NTWwWiPjXRwOB5xOJ9ra2lSPX026aBqSUvoBBKJNQpkcPhoOy1giqDAxERAZkdvtBhApqLdu3Qq/3x8rvJPxer0JawN+vx/19fUAMKsGUV9fn3JTklZ0UxLOU2NQzfB4JAmUmwpRWMCLYYjUsP4LP9bkfY89dvuC9uvq6kJra2us0PZ4PNi8eapF2u12w263T9vH5/PFCvuZ9wORpJKI3W5Hd3c3duzI+DiYBdNFjSCbov0DHDq6cB133MH5hihndXd3Y/fu3fB4PLFCPFrou91udHd3Jzzrd7vds2oNfr9/3tqExWJBT0+Pin+B+gxXGg6NRUYMsX9g4TjXEM200DNzLTQ3N8PpdM46g5/vjL2/v39Wgujo6NB9+38qDFcjuBy9qpg1ggXjXEOUy3w+X0r9ATPNHP2TC6OBUmW40jDWUcxEsGCca4hy2cz+gFSZzeZphb/H40nYZ5CLDFcaDnN6iUXr3rpV6xCIFszr9aKlpSXt/TZv3jyrP8Dr9aa078yRRHpj2KYhJoKFW1ZejmXl5VqHQbQgHo8HNptt2n0ulwtutxtOpzPWgTyT3W7HgQMHpm1H90k2PNTtdmPbtm3qBJ8hhksEo5NhAEBJcaHGkeSuzoMH0XnwoNZhEC1ITU3NtDN0t9uNQCAAu92OQCAwZ//BzKYhAOjt7UVtbS2amprQ1NSUcL+urq45L0LTC8MlgvFoIigy3J+uGiYCyjWBQCB2tj+zWainpyc2fHRgYCBpJ3BbWxtcrumXPO3YsQO9vb0wm82zagZ+v3/OBKEnhisNmQiIjMvj8cwaNrpt2zYMDAzA7XbDYrHA4/HMub/ZbIbNZptW4Pv9frjdbmzevHnW8FKfz6f72gBgwM7iaCIwMREQGYbZbJ5zvH98U9DMq4nnez4QuWDMYrEk3DcXkgBgwBrB2GTkymJToeH+dCKihAxXGsaahooN96dTAouZDGwhFxT5fD40NDRkJJ5E8umiJ8ocw5WG4yGlaYg1AsNLZ175RBYy17zVakVNTU1G4kkkV+bDJ20ZrjSc6iPg8NFsczqdcLvdc47TzqZk88oDkVjb29tnjRCJ53A4sHPnzqzEk4pEo1PUjJHyl+E6i8fYWayJZPO1a8Hr9c45bXD8XPXzic41Hz2TT5Q4bDbbvHPbJItnPm63OzZyJZUYiWYyXCLg8NHsm2++9myba175qJlz1Sczc675hfyN88WTSgxApBaTSoxEMxkuEbBGsHjpzDUUna9d7WF0gUAgabMNgNgShDMlmlc+KjpXfbRDd74z+ehc86kWsvFn7/Fz4C9kNsxUpRtjvsvF2lEgEMhoTdpwiSDWWcxEsGDpzDOUqfnazWbzggu2RPPKR801V71a7HY7ent7U46H1NXe3p6TCXH37t3YunVrxpKBLhKBEMIKwAsgOnbOLaVszcR7jU1EriMo4aihBYtOL/HApk1Jn7eY0So+nw/bt29PeXbHdCSLa6Fz1S9GonhcLteshBGvqakppYufaEq6C89rpampadaKZg6HA06nM2OL4OgiEQCokVIKIJYUApl6I9YIFi/VRLCY+dqTDbMEFtc0lGjysKiFzlW/GIni0Ut/SiY99cZT+OLeL+LExROoq6rDo1sexX033Jex95urQ14vAxm07PTXRSKQUsb/5RYpZXem3muqs5jDRxfqxQceSPm5mTijBxbXNJRoXvmoRHPVu1yuWDv7tm3bZu232MIjWTxq0cNIrXhPvfEUHHscCE4EAQDHLx6HY0+kkM5EMljowvPZpGWnv65Oi4UQdgCJ06FKONdQ9iSbr93lcs26Zev6gpnzysebOVf9fFMUqzHXfLJ4UuHz+dDe3h6bYXPmGaUe58P/4t4vxpJAVHAiiC/u/WJG3m+hC8/rSfRkJBN0USOI0zSjdhAjhHAAcABAXV3dgt+ATUOL9/i+fQCAh2+5Zd7n9vb2or29HU1NTdM+yFqegSVrGpo5V320FgBMTVEc/3hXVxc6OjoyFk8qrFYrrFbrnGeKasSothMXT6R1/2Ll88LzashaIlAK8pn8Mwr+OVOzlNIFwAUANptNLjSOsQkmgsV6/p13AKSWCIDIfO07duxAS0tLym2ciYZZqik6r7zD4UAgEMDOnTuxbdu2Wc1CiaYojsaj5lzz8fGoSa/z4ddV1eH4xeMJ788ENReeT2cgQ650+mctESgF+ZyEEBZksJM4Kloj4AVl2ROtgiear30uiYZZqil+Xvlop3SiueqTTVGs5lzz8fGo2Rmo1/nwH93y6LQ+AgAoLy7Ho1sezcj7qbnw/HwDGeLpoe8hFXprGhrI9BuwjyD7ks3XrqX4Qn4hTQRqF7CZaKvWYxIApjqEszVqaDELz6ciWxep5fV1BAAgpfQDyMi1A/FiiYDXERBp6r4b7svocNF4drsdO3fujCVGu92O1tZWOJ1OtLa2TivEFzJflNPphMViWVSfg8/niw1OiF7XEH/ylMlOf90kgmwIhyWnoSYyoLkWnldrIENXV9ec4/9TpWWnv6FKw/gkUFAgNI6GiLIp3YXn5zLXhV+ZXPch053+hqoRcOgokXEl6pBXayBDpka3RWW6099YiYAdxUSGls7C8+nI9ECITHf6G6pEZEcxEdFshqoRcC0CdaQz1xAR6Z+hEkFZcSHufP8VqK0waR0KUU6TUkIIDrjQGykXNumCoRLBqqpS/MvHb9Q6DKKcVlxcjJGREZSnsUARZcfIyAiKi4vT3o9tJESUlhUrVuD06dMIBoMLPgMldUkpEQwGcfr0aaxYsSLt/Q1VIyCixausrAQAnDlzBhMTExpHQ1HFxcVYuXJl7P+TDiYCIkpbZWXlggoc0ic2DRERGRwTARGRwTEREBEZHBMBEZHBMREQERmcyMVxwEKICwBmL3iammUA+lQMRy2MKz2MKz2MKz35Gtc6KeXymXfmZCJYDCGER0pp0zqOmRhXehhXehhXeowWF5uGiIgMjomAiMjgjJgIZq9MrQ+MKz2MKz2MKz2GistwfQSUnBDCKqX0zfFYM4AAAKuUsl1HcbVJKZ1CCIeUUq9fYKIFEULsSPR9U/P7mNc1AiFEsxDCLoTYsZDHNYyrTfnpyHJcdgBPzPGYFQCklG4Agei21nEpHEKIXgCprT6uEiGEQ7m1zfG4Vp+v+eLS7POl3PR2vOaLS5PjpbynHcDmBPer+n3M20Qw34HSqmBL8X01KdiUmAbmeHgbImcfQCSuzC7SGmeeuACgRUpZrzwvK5QvqFupgViU7fjHtfp8JY1LkfXPl/L3NynHw6qz7+OccSk0+T7OQ9XvY94mAsx/oLQq2FJ536wXbCkwY3phXKtRHIlYNTiTtGDqf+dXtuNp9fmaLy5Ag8+XlNInpXQqmzUJmvk0OV4pxAVo9H1UmkPnek8zVPw+5vM01GYkP1DzPZ4pqbyvVVkGMOtt8bkoeoyEEE1CCHs2vrAz+iKsAHbNeIoZGny+UogL0PDzpSTrnQkeMkPDE40kcQHaHa+abL1RPtcIcpaUsl0pzGrnqNprIYCpD6YZQL9mkcRR2pWblc1+JD4DzuT7WwH0zNWRrZVkcWn5+VIK0lYhRFb/T/NJFpcWx2ue2gCg8vcxnxNBAMkP1HyPZ0rS99W6YJtJCGFWft2FqVgsADRttoqLy4+pWOoBeLIcin2Os8QAtE2cCePS6vMlhIhvf/cBaJ7xlAA0OF7zxaXh99ES996WaIyZ+j7mcyJIeKB0ULDNF5dmBZvyobPFffABYC8QaUtVnmMHEMjmGXAKcW1VHuvNclyOuGYpu/LTrDysWeKcJy6tPl92TC/o/TPi0up4zReXJsdLStktpexWYjPHPZSR72NeX0egDPfyA7BE206FEF4pZcNcj+sorgHlcfYR6JDyBexC5P9Ug0iHolvrz1cacWX186UUrFuV990c7aDVwfFKNa68/j7mdSIgIqL55XPTEBERpYCJgIjI4JgIiIgMjomAiMjgmAiIiAyOiYBIZUKINmXuo6zN0Eq0GEwERCpSpijoVTYDGoZClDJeR0CkkriplHU17xDRfFgjIFKBUhOwMAlQLmIiIFJHqzI3DFHOYSIgWqS4CcqIchITAdHi2TDVQUyUc5gIiNTRoHUARAvFUUNEKlAWN+8G0CGl1NMi50TzYo2ASAVSynpEVrDqEUL0aB0PUTqYCIhUoqxtWw8goLc1eYmSKdI6AKJ8Eb2WAMABNg9RLmEfARGRwbFpiIjI4JgIiIgMjomAiMjgmAiIiAyOiYCIyOCYCIiIDO7/A4Ixf92yogZLAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.optimize import newton\n",
    "\n",
    "a = 1.576943460405378\n",
    "b = 0.8950608781227859\n",
    "\n",
    "grad_coeff = lambda dist: -2*a*b*dist**(2*(b-1)) / (1+a*dist**(2*b))\n",
    "\n",
    "def umap_eq(x):\n",
    "    return grad_coeff(x)+1.0\n",
    "def humap_eq(x):\n",
    "    return grad_coeff(x)+4/3\n",
    "\n",
    "umap_a = [-1, -1]\n",
    "umap_x = [0.0, 4.0]\n",
    "\n",
    "umap_point = newton(umap_eq,0.5)\n",
    "print(umap_point)\n",
    "\n",
    "humap_a = [-4/3, -4/3]\n",
    "\n",
    "dists=np.arange(0.01,4,0.01)\n",
    "gcs = grad_coeff(dists)\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(dists,gcs, lw=2.0, label=r'$f_a^U(\\zeta)$')\n",
    "plt.plot(umap_x,umap_a, c='g', ls=':')\n",
    "plt.plot([umap_point,umap_point], [-7.4, 0], c='teal', ls='-.') \n",
    "plt.plot(umap_point,-1.0,'go', label=r'$(\\zeta_{-1}, -1)$')\n",
    "\n",
    "loc_umap = -5\n",
    "plt.plot([umap_point, 4.0], [loc_umap, loc_umap], c='orange')\n",
    "plt.text(umap_point+.15, loc_umap+0.15, 'Contraction', fontsize=14)\n",
    "\n",
    "plt.plot([0, umap_point], [loc_umap, loc_umap], c='black')\n",
    "plt.text(0+0.24, loc_umap+0.15, 'Expansion', fontsize=14)\n",
    "\n",
    "\n",
    "plt.text(3.3, -1.5, r'$f_a=-1$', fontsize=14)\n",
    "plt.text(1.2, -7.0, r'$\\zeta_{-1}=(f_a)^{-1}(-1)$', fontsize=14)\n",
    "\n",
    "\n",
    "plt.xlabel(r'$\\zeta$', fontsize=14)\n",
    "plt.ylabel(r'$f_a(\\zeta)$', fontsize=14)\n",
    "plt.legend(loc='lower right', fontsize=14)\n",
    "#plt.grid('on')\n",
    "#plt.ylim([-4,1])\n",
    "#plt.savefig('Fig_1/f_a_umap_plot.svg', dpi=400, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "29306acf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0708886424405295\n",
      "0.853891421666223\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-7.7, 0.33)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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R6j9bhW+714OT38XT6CD2vwcTt/2S/jk//CYTVP787fT3N0MwMPHHqZ2Zy0t5phDD7zyALU7a+noN6aS3HVkF7U7a+k1G51/8eIvqN1ZSyBoDAr3797/4Kof3sCtP3ia23/6PHuO/ozmnP/Du69eyH2bruc9NxzmHt/nIsHg+899n/f+6r2Rz/47z3yHD933ocj23U/fzW17botsf/sP3+ajD3w0sv2N332DTz30qcj2XZ67aHi4IbL9lSe+whce+UJk+8uPfZkvP/blyPYXHvkCX3niK5HthocbuMtzV2T7Uw99im/87huR7Y8+8FG+/YdvR7Zv23Mbdz99d2T7Q/d9iO88853I9nt/9V6+/9z3I9u3/PIWfrzvx5Htup/XsePAjsj2yO9e7c5afvHiLwDjh0ntztqZ8907+Qdqd9biazcexfb4PNTurOV0x2kAHjv+GLU7ay377u08tJPanbWRz3LHgR3U/bwusv3jfT/mll/eEtme7d+9ZMioEsJElFINQANAZWWlJdd8/OTjXOy7yLzSefzo5h+xqGiRJddNulDAKA08+U0YuAjkw8p3wqq3wSu7jZFELdQfCLJr3zm2PXmM1/u76BrspKIol+uq5vPGYBk/vL0agP0t0j4gxEyl9Hizf1h9MyNDH8mntfZEnbNXa10/0bVqamr0/v37JzptXD2BHv7igb+grb+Nv3vz3/HhSz88reulhNbGmEJ7v2FMJQnGGEL134al11p+u4GhILv2neaHTx7nQtcAAMvKC2h4q5sPVS8hzymPigoxkyilDmita+IdS2kJQWvdmMr7TeSeV+6hrb+NNXPXsOGSDelOzsRam+CRvzVGGgVjILn6bxmPjlr85M5QMMQD3rN8/7evcdZvzN+welEJn6tdwS1XLsQuj4sKMetkVJWRUmo9UKOUWq+13pPMewVDQe579T4APr/m85n9KOTQADz9PXjqXyA4AHkuqL0Lav7K0kllwGgsfuxIM9seP8aJFqNx+pL5RfxN/aW8c/X8zP6chBDTklEBwQwCSQ0EYc83P09zTzNLipbw5kVvTsUtE3Pij/A/fz1cPbTmdnjHt6GwwvJbvXSug2//z8s85zMe9FpWXsBf113Ce9YskhKBmNF8Ph+bNm1i9+7duFyucc/dvHkz5eXluFwuGhri1XKnV319PXv37k3KtTMqIKTS02ef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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.optimize import newton\n",
    "\n",
    "a = 1.576943460405378\n",
    "b = 0.8950608781227859\n",
    "\n",
    "grad_coeff = lambda dist: -2*a*b*dist**(2*(b-1)) / (1+a*dist**(2*b))\n",
    "\n",
    "def umap_eq(x):\n",
    "    return grad_coeff(x)+1.0\n",
    "def humap_eq(x):\n",
    "    return grad_coeff(x)+4/3\n",
    "\n",
    "\n",
    "\n",
    "umap_a = [-1, -1]\n",
    "umap_x = [0.0, 4.0]\n",
    "\n",
    "umap_point = newton(umap_eq,0.5)\n",
    "print(umap_point)\n",
    "\n",
    "humap_point = newton(humap_eq,0.5)\n",
    "print(humap_point)\n",
    "\n",
    "humap_a = [-4/3, -4/3]\n",
    "humap_x = [0.0, 4.0]\n",
    "\n",
    "dists=np.arange(0.01,4,0.01)\n",
    "gcs = grad_coeff(dists)\n",
    "\n",
    "dists6=np.arange(0.0005,4,0.01)\n",
    "gcs6 = 0.6*grad_coeff(dists6)\n",
    "\n",
    "dists2=np.arange(0.000005,4,0.01)\n",
    "gcs2 = 0.2*grad_coeff(dists2)\n",
    "\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(dists,gcs, lw=2.0, label=r'$\\lambda=1$')\n",
    "plt.plot(dists6,gcs6, lw=2.0, label=r'$\\lambda=0.6$')\n",
    "plt.plot(dists2,gcs2, lw=2.0, label=r'$\\lambda=0.2$')\n",
    "plt.plot(umap_x,umap_a, c='g', ls=':')\n",
    "\n",
    "plt.text(3.3, -1.5, r'$\\lambda f_a=-1$', fontsize=14)\n",
    "\n",
    "plt.xlabel(r'$\\zeta$', fontsize=14)\n",
    "plt.ylabel(r'$\\lambda f_a^U(\\zeta)$', fontsize=14)\n",
    "plt.legend(loc='lower right', fontsize=14)\n",
    "#plt.grid('on')\n",
    "plt.ylim([-7.70,0.33])\n",
    "#plt.savefig('Fig_1/f_a_umap_plot_var_lambda.svg', bbox_inches='tight') #, dpi=200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a8dba2f1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dx = 0.01\n",
    "lambdas = np.arange(0.07,1+dx,dx)\n",
    "\n",
    "upts = []\n",
    "\n",
    "for lr in lambdas:\n",
    "\n",
    "    grad_coeff = lambda dist: lr * -2*a*b*dist**(2*(b-1)) / (1+a*dist**(2*b))\n",
    "\n",
    "    def umap_eq(x):\n",
    "        return grad_coeff(x)+1.0\n",
    "    \n",
    "    umap_point = newton(umap_eq, 0.001)\n",
    "    upts.append(umap_point)\n",
    "\n",
    "upts = np.array(upts)\n",
    "plt.figure()\n",
    "plt.plot(lambdas, upts)\n",
    "\n",
    "plt.ylabel(r'$\\zeta_{-1}(\\lambda f_a^U)^{-1}(-1)$', fontsize=14)\n",
    "plt.xlabel(r'$\\lambda$',fontsize=14)\n",
    "plt.gca().invert_xaxis()\n",
    "#plt.savefig('Fig_1/lambda_f_inv.svg', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "01566009",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0708886424405295\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f98015e1a20>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.optimize import newton\n",
    "\n",
    "a = 1.576943460405378\n",
    "b = 0.8950608781227859\n",
    "\n",
    "grad_coeff = lambda dist: -2*a*b*dist**(2*(b-1)) / (1+a*dist**(2*b))\n",
    "\n",
    "def umap_eq(x):\n",
    "    return grad_coeff(x)+1.0\n",
    "\n",
    "umap_a = [-1, -1]\n",
    "umap_x = [0.0, 4.0]\n",
    "\n",
    "umap_point = newton(umap_eq,0.5)\n",
    "print(umap_point)\n",
    "\n",
    "dists=np.arange(0.01,4,0.01)\n",
    "gcs = grad_coeff(dists)\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(dists,gcs, lw=2.0, label=r'UMAP (default)')\n",
    "plt.plot(dists,gcs-0.2*dists, lw=2.0, label=r'UMAP (modified)')\n",
    "plt.plot(umap_x,umap_a, c='g', ls=':')\n",
    "\n",
    "plt.text(3.3, -1.5, r'$f_a=-1$')\n",
    "\n",
    "plt.xlabel(r'$d$')\n",
    "plt.ylabel(r'$f_a(d)$')\n",
    "plt.legend(loc='lower right')\n",
    "#plt.savefig('Fig_1/f_a_umap_modified_plot.png', dpi=200)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ade3c32",
   "metadata": {},
   "source": [
    "<h1> Choice of Min Distance</h1>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "321a90ec",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9921756197688717 1.1122533842193434\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.optimize import curve_fit\n",
    "\n",
    "def find_ab_params(min_dist):\n",
    "    \"\"\"Fit a, b params for the differentiable curve used in lower\n",
    "    dimensional fuzzy simplicial complex construction. We want the\n",
    "    smooth curve (from a pre-defined family with simple gradient) that\n",
    "    best matches an offset exponential decay.\n",
    "    ####code adapted from UMAP github repo\n",
    "    \"\"\"\n",
    "\n",
    "    def curve(x, a, b):\n",
    "        return 1.0 / (1.0 + a * x ** (2 * b))\n",
    "\n",
    "    xv = np.linspace(0, 3, 300)\n",
    "    yv = np.zeros(xv.shape)\n",
    "    yv[xv < min_dist] = 1.0\n",
    "    yv[xv >= min_dist] = np.exp(-(xv[xv >= min_dist] - min_dist))\n",
    "    params, covar = curve_fit(curve, xv, yv)\n",
    "    return params[0], params[1]\n",
    "\n",
    "def derivative_f_zeta(zeta,a,b):\n",
    "    pass\n",
    "\n",
    "a_1,b_1 = find_ab_params(0.1)\n",
    "\n",
    "min_dists = np.linspace(0,1.01,300)\n",
    "\n",
    "a_s = []\n",
    "b_s = []\n",
    "\n",
    "for md in min_dists:\n",
    "    a_x, b_x = find_ab_params(md)\n",
    "    a_s.append(a_x)\n",
    "    b_s.append(b_x)\n",
    "    \n",
    "plt.figure()\n",
    "plt.plot(min_dists, a_s, label='a')\n",
    "plt.plot(min_dists, b_s, '-', label='b')\n",
    "plt.plot([0,1.01], [1,1], '--', label='1.0')\n",
    "\n",
    "plt.xlabel(r'$m_d$')\n",
    "\n",
    "plt.xscale('log')\n",
    "\n",
    "plt.legend()\n",
    "\n",
    "plt.savefig('ab_plot.eps')\n",
    "\n",
    "a_m,b_m = find_ab_params(0.3)\n",
    "print(a_m,b_m)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "71e73812",
   "metadata": {},
   "source": [
    "<h1>Kernel</h1>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7250e19c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f9801773ba8>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def kernel_fn(a,b,d):\n",
    "    return 1/(1+a*d**(2*b))\n",
    "\n",
    "af = 1\n",
    "bf = 1\n",
    "df = np.linspace(0,3,300)\n",
    "kf_1 = kernel_fn(af,0.5,df)\n",
    "kf_2 = kernel_fn(af,1,df)\n",
    "kf_3 = kernel_fn(af,1.5,df)\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(df,kf_1,label='0.5')\n",
    "plt.plot(df,kf_2,label='1.0')\n",
    "plt.plot(df,kf_3,label='1.5')\n",
    "plt.xlim([0,3])\n",
    "plt.ylim([0,1.1])\n",
    "\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f3778554",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f98016eeac8>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def kernel_fn(a,b,d):\n",
    "    return 1/(1+a*d**(2*b))\n",
    "\n",
    "af = 1.5\n",
    "bf = 1\n",
    "df = np.linspace(0,3,300)\n",
    "kf_1 = kernel_fn(0.5,bf,df)\n",
    "kf_2 = kernel_fn(1.0,bf,df)\n",
    "kf_3 = kernel_fn(1.5,bf,df)\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(df,kf_1,label='0.5')\n",
    "plt.plot(df,kf_2,label='1.0')\n",
    "plt.plot(df,kf_3,label='1.5')\n",
    "plt.xlim([0,3])\n",
    "plt.ylim([0,1.1])\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e708bfca",
   "metadata": {},
   "source": [
    "<h1>Repulsion Force</h1>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "da9a87ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, '$f_r(\\\\zeta)$')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "a = 1.576943460405378\n",
    "b = 0.8950608781227859\n",
    "\n",
    "def rep_ceoff_fun(dist,a,b):\n",
    "    return 2*b / (dist**2 * (1 + a*dist**(2*b)))\n",
    "\n",
    "dists=np.arange(0.01,4,0.01)\n",
    "rcs1 = rep_ceoff_fun(dists, a, b)\n",
    "rcs2 = rep_ceoff_fun(dists, a, 1.5)\n",
    "rcs3 = rep_ceoff_fun(dists, a, 0.1)\n",
    "rcs4 = rep_ceoff_fun(dists, a, 10)\n",
    "\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(dists, rcs1, label=r'$f_r^U(\\zeta)$')\n",
    "plt.ylim([-2, 60])\n",
    "\n",
    "loc_umap = 30\n",
    "\n",
    "plt.plot([0, 4], [loc_umap, loc_umap], c='black')\n",
    "plt.text(0+1.5, loc_umap+0.8, 'Expansion', fontsize=14)\n",
    "\n",
    "\n",
    "#plt.grid('on')\n",
    "plt.xlabel(r'$\\zeta$', fontsize=18)\n",
    "plt.ylabel(r'$f_r(\\zeta)$', fontsize=18)\n",
    "#plt.legend()\n",
    "#plt.savefig('Fig_1/f_r_umap_plot.svg', bbox_inches='tight') #,dpi=400, transparent=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ff367cf",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
