{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0491c2aa",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-13T23:21:08.862226Z",
     "start_time": "2023-05-13T23:21:08.834222Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<module 'ikd.evaluate' from '/storage/scratch1/1/cli726/b/ikd/ikd/ikd/evaluate.py'>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from scipy.special import kv, gamma\n",
    "import scipy.integrate as integrate\n",
    "\n",
    "import imp\n",
    "\n",
    "from ikd import utils, core, evaluate\n",
    "imp.reload(utils)\n",
    "imp.reload(core)\n",
    "imp.reload(evaluate)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c2853183",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-13T23:20:07.701099Z",
     "start_time": "2023-05-13T23:20:07.679978Z"
    }
   },
   "outputs": [],
   "source": [
    "def se(d):\n",
    "    return np.exp(-d/2)\n",
    "\n",
    "def inv_se(k):\n",
    "    return -2 * np.log(k)\n",
    "\n",
    "def rq(d, alpha):\n",
    "    return (1 + d/(2*alpha))**(-alpha)\n",
    "\n",
    "def inv_rq(k, alpha):\n",
    "    return 2*alpha * (k**(-1/alpha) - 1)\n",
    "\n",
    "def ge(d, gamma):\n",
    "    return np.exp(-d**(gamma/2))\n",
    "\n",
    "def inv_ge(k, gamma):\n",
    "    return (-np.log(k))**(2/gamma)\n",
    "\n",
    "def ma(d, nu):\n",
    "    return 2**(1-nu) / gamma(nu) * (np.sqrt(2*nu*d))**nu * kv(nu, np.sqrt(2*nu*d))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "55bc21b0",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-13T23:30:09.209300Z",
     "start_time": "2023-05-13T23:30:09.086787Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " /scratch/1915952/ipykernel_15169/2411713053.py:2: RuntimeWarning:invalid value encountered in divide\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2aaaf30e7880>]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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2e+iOXr0qMrLy5WamqpvvvlGb731lg4dOqRVq1bZ+5g1a5ZGjhypV199VePHj9fmzZu1bds2++koScrLy9PUqVOVkpKi4cOHa8mSJaqtrdWMGTOu5fwBAIAhfA41FRUVGjVqlP05Ly9PkjRt2jStXLlSdXV1Xu+OaWpq0ptvvqkjR44oICBAo0aN0p49e5SQkGDXpKWlqaioSM8995zmzp2rX/ziF1q3bp1SU1PtmokTJ+rMmTN64YUXVFdXp6SkJG3ZskXx8fHtOW8AAGCYa3pPTVfDe2oAAOh6bpr31AAAAFwPhBoAAGAEQg0AADACoQYAABiBUAMAAIxAqAEAAEYg1AAAACMQagAAgBEINQAAwAg+/5mEruzHlyd7PJ4bPBMAANBWP35vX+2PIPysQs3Zs2clSXFxcTd4JgAAwFdnz56V0+lsdfvP6m8/Xb58WV999ZVCQ0PlcDjavR+Px6O4uDidPHmSvyHVyVjr64e1vn5Y6+uHtb5+OnOtLcvS2bNnFRMTo27dWr9z5md1paZbt26KjY3tsP2FhYXxH8l1wlpfP6z19cNaXz+s9fXTWWt9pSs0P+JGYQAAYARCDQAAMAKhph2CgoL029/+VkFBQTd6KsZjra8f1vr6Ya2vH9b6+rkZ1vpndaMwAAAwF1dqAACAEQg1AADACIQaAABgBEINAAAwAqHGR4sWLVJiYqKCg4OVnJysXbt23egpdXkFBQUaOnSoQkNDFRkZqaysLB05csSrxrIszZs3TzExMQoJCdH999+vzz777AbN2BwFBQVyOBzKzc21+1jrjnPq1ClNmTJFPXv21C233KK7775blZWV9nbWumNcunRJzz33nBITExUSEqI+ffrohRde0OXLl+0a1rp9du7cqXHjxikmJkYOh0ObNm3y2t6WdW1oaNDMmTMVERGh7t276x//8R/15Zdfds6ELbRZUVGRFRAQYC1dutT661//as2aNcvq3r279cUXX9zoqXVpY8aMsVasWGEdOnTIqq6uth566CGrd+/e1rlz5+yaV155xQoNDbXWr19vHTx40Jo4caLVq1cvy+Px3MCZd23l5eVWQkKCddddd1mzZs2y+1nrjvG///u/Vnx8vDV9+nRr3759Vk1NjbVt2zbr888/t2tY647xu9/9zurZs6f13//931ZNTY31pz/9ybr11lutt99+265hrdtny5Yt1pw5c6z169dbkqyNGzd6bW/Lus6YMcO6/fbbrZKSEuvTTz+1Ro0aZQ0aNMi6dOlSh8+XUOODe+65x5oxY4ZXX79+/axnnnnmBs3ITKdPn7YkWaWlpZZlWdbly5et6Oho65VXXrFrvv/+e8vpdFqLFy++UdPs0s6ePWvdcccdVklJiXXffffZoYa17jhPP/20NWLEiFa3s9Yd56GHHrL+9V//1avv4YcftqZMmWJZFmvdUf421LRlXb/99lsrICDAKioqsmtOnTpldevWzfroo486fI78/NRGFy9eVGVlpTIyMrz6MzIytGfPnhs0KzO53W5JUnh4uCSppqZGLpfLa+2DgoJ03333sfbtlJ2drYceekijR4/26metO05xcbFSUlL06KOPKjIyUoMHD9bSpUvt7ax1xxkxYoT+8pe/6OjRo5Kk/fv3a/fu3XrwwQclsdadpS3rWllZqcbGRq+amJgYJSUldcra/6z+oOW1qK+vV1NTk6Kiorz6o6Ki5HK5btCszGNZlvLy8jRixAglJSVJkr2+La39F198cd3n2NUVFRXp008/1f/8z/8028Zad5zjx4+rsLBQeXl5evbZZ1VeXq4nn3xSQUFBevzxx1nrDvT000/L7XarX79+8vPzU1NTk1566SVNnjxZEv+uO0tb1tXlcikwMFA9evRoVtMZ352EGh85HA6vz5ZlNetD++Xk5OjAgQPavXt3s22s/bU7efKkZs2apa1btyo4OLjVOtb62l2+fFkpKSl6+eWXJUmDBw/WZ599psLCQj3++ON2HWt97datW6d3331Xa9as0Z133qnq6mrl5uYqJiZG06ZNs+tY687RnnXtrLXn56c2ioiIkJ+fX7Nkefr06WYpFe0zc+ZMFRcX65NPPlFsbKzdHx0dLUmsfQeorKzU6dOnlZycLH9/f/n7+6u0tFTz58+Xv7+/vZ6s9bXr1auXBgwY4NXXv39/1dbWSuLfdUf693//dz3zzDOaNGmSBg4cqKlTp+qpp55SQUGBJNa6s7RlXaOjo3Xx4kV98803rdZ0JEJNGwUGBio5OVklJSVe/SUlJUpLS7tBszKDZVnKycnRhg0btH37diUmJnptT0xMVHR0tNfaX7x4UaWlpay9j/7+7/9eBw8eVHV1td1SUlL0z//8z6qurlafPn1Y6w5y7733Nns1wdGjRxUfHy+Jf9cd6cKFC+rWzfvrzM/Pz36km7XuHG1Z1+TkZAUEBHjV1NXV6dChQ52z9h1+67HBfnyke9myZdZf//pXKzc31+revbt14sSJGz21Lu3f/u3fLKfTae3YscOqq6uz24ULF+yaV155xXI6ndaGDRusgwcPWpMnT+ZxzA7y06efLIu17ijl5eWWv7+/9dJLL1nHjh2z/vjHP1q33HKL9e6779o1rHXHmDZtmnX77bfbj3Rv2LDBioiIsP7jP/7DrmGt2+fs2bNWVVWVVVVVZUmy3nrrLauqqsp+lUlb1nXGjBlWbGystW3bNuvTTz+1/u7v/o5Hum8WCxcutOLj463AwEBryJAh9mPHaD9JLbYVK1bYNZcvX7Z++9vfWtHR0VZQUJA1cuRI6+DBgzdu0gb521DDWnec999/30pKSrKCgoKsfv36WUuWLPHazlp3DI/HY82aNcvq3bu3FRwcbPXp08eaM2eO1dDQYNew1u3zySeftPj/52nTplmW1bZ1/e6776ycnBwrPDzcCgkJscaOHWvV1tZ2ynwdlmVZHX/9BwAA4PrinhoAAGAEQg0AADACoQYAABiBUAMAAIxAqAEAAEYg1AAAACMQagAAgBEINQAAwAiEGgAAYARCDQAAMAKhBgAAGIFQAwAAjPB/5ZRhZ1LKdeEAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "d = np.linspace(0, 100, 100)\n",
    "plt.plot(d, inv_se(ge(d, 2)) / d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "30306c1c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-13T23:22:51.432922Z",
     "start_time": "2023-05-13T23:22:51.310380Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " /scratch/1915952/ipykernel_15169/432864748.py:1: IntegrationWarning:The integral is probably divergent, or slowly convergent.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-3.078384539607214, 0.998135196183583)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integrate.quad(lambda d: inv_se(rq(d, 0.2)), 0, np.inf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c9a889e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:.conda-cli726]",
   "language": "python",
   "name": "conda-env-.conda-cli726-py"
  },
  "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.10.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
