{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b385bd68",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1ba0f2a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def distortion(x,pos,vals): \n",
    "    eps = 1e-7\n",
    "    pos = torch.nn.functional.softmax(pos, dim = 0) \n",
    "    vals = torch.nn.functional.softmax(vals, dim = 0)\n",
    "    pos = torch.cumsum(pos, dim =0)\n",
    "    vals = torch.cumsum(vals, dim =0)\n",
    "    vals = torch.cat((torch.tensor([0.0]),vals))\n",
    "    pos = torch.cat((torch.tensor([0.0]),pos))\n",
    "    result = torch.zeros_like(x)\n",
    "    pos[-1] = 1.0 + eps\n",
    "    \n",
    "    for i in range(x.shape[0]):\n",
    "        ind = int(torch.nonzero(x[i]<pos, as_tuple=True)[0][0])\n",
    "        result[i]  = vals[ind-1] + (vals[ind]-vals[ind-1])/(pos[ind]-pos[ind-1])*(x[i] - pos[ind-1])\n",
    "    \n",
    "    \n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4658b2b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 30\n",
    "linearScale = torch.linspace(0,1,n)\n",
    "grid_x, grid_y = torch.meshgrid(linearScale, linearScale, indexing='ij')\n",
    "\n",
    "number_of_kinks = 10\n",
    "crazyness = 0.5\n",
    "pos_x = crazyness*torch.randn(number_of_kinks)\n",
    "vals_x = crazyness*torch.randn(number_of_kinks)\n",
    "\n",
    "pos_y = crazyness*torch.randn(number_of_kinks)\n",
    "vals_y = crazyness*torch.randn(number_of_kinks)\n",
    "\n",
    "\n",
    "distroted_x = distortion(linearScale,pos_x,vals_x)\n",
    "distroted_y = distortion(linearScale,pos_x,vals_x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "06321501",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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An//NY548cUXzdixY80zzzxj2trazF133WVKSkrM559/njR+3759Zvz48eauu+4ybW1t5plnnjFjx441L7/8csiVB8/rsbnrrrvMww8/bP75z3+ajz76yKxevdqMHTvWvP/++yFXHiyvx+Wkr776ykyfPt3U1NSYSy65JJxiQ+bn2Fx//fXm8ssvNy0tLebTTz81//jHP8y7774bYtXB83pcWltbzZgxY8wf//hHs2/fPtPa2mouvvhi87Of/SzkyoPV3Nxs1qxZY1555RUjybz22msjxofx/utMc5s9e7apra0dsG7GjBmmvr4+afx9991nZsyYMWDd7bffbq644orAaswWr8cmmYsuusisXbs206Vlld/jsmjRIvPb3/7W3H///c42N6/H5i9/+YspKyszhw8fDqO8rPF6XH7/+9+b6dOnD1j32GOPmSlTpgRWY7al0tzCeP914rTk0aNHtWvXLtXU1AxYX1NTox07diTd5r333hsSv2DBAu3cuVPffvttYLWGzc+xGezEiRPq6enR6aefHkSJWeH3uDz77LP65JNPdP/99wddYtb4OTZvvPGGqqqq9Mgjj+jss8/WBRdcoHvuuUf//ve/wyg5FH6OS3V1tQ4cOKDm5mYZYxSLxfTyyy/r2muvDaNka4Xx/huJuwKMpqurS8ePH1d5efmA9eXl5ers7Ey6TWdnZ9L4Y8eOqaurS5MmTQqs3jD5OTaDPfroo+rt7dVNN90URIlZ4ee4fPzxx6qvr1dra6sKCpz4n05Sfo7Nvn379M4776i4uFivvfaaurq6tGLFCn355ZfOfO/m57hUV1dr69atWrRokb755hsdO3ZM119/vR5//PEwSrZWGO+/TnxyO2nwvd6MMSPe/y1ZfLL1LvB6bE564YUX9MADD6ipqUkTJ04MqrysSfW4HD9+XDfffLPWrl2rCy64IKzyssrL38yJEyeUl5enrVu3avbs2brmmmu0bt06bdmyxalPb5K349LW1qaVK1fqd7/7nXbt2qU333xTn376qWpra8Mo1WpBv/868X8/J0yYoPz8/CH/7+nQoUND/t/BSWeddVbS+IKCAp1xxhmB1Ro2P8fmpKamJi1btkwvvfSSrrrqqiDLDJ3X49LT06OdO3dq9+7duuOOOyR994ZujFFBQYG2bdumK6+8MpTag+bnb2bSpEk6++yzB9xr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",
      "text/plain": [
       "<Figure size 500x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "fig, axs = plt.subplots(2, figsize=(5,10))\n",
    "for i in range(n):\n",
    "    axs[0].plot(linearScale[i]*torch.ones(n), linearScale, 'k-')\n",
    "    axs[0].plot(linearScale,linearScale[i]*torch.ones(n), 'k-')\n",
    "    \n",
    "for i in range(n):\n",
    "    axs[1].plot(distroted_x[i]*torch.ones(n), linearScale, 'k-')\n",
    "    axs[1].plot(linearScale,distroted_y[i]*torch.ones(n), 'k-')\n",
    "    \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a2243a6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "941e638a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "l2s",
   "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"
  },
  "vscode": {
   "interpreter": {
    "hash": "bd2e4dcb18364cf6748816343f17347a14b50de30c2ca4007709e12fed921ebc"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
