{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "50f46b9a",
   "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": "9d373e9b",
   "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": 12,
   "id": "d0b2fd43",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-13T23:22:10.105850Z",
     "start_time": "2023-05-13T23:22:09.930649Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2aaaf2b697e0>]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\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(rq(d, 0.2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a1f649b",
   "metadata": {},
   "outputs": [],
   "source": [
    "integrate(lambda d: inv_se(rq(d, 0.2)), ())"
   ]
  }
 ],
 "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
}
