{
 "cells": [
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "import numpy as np"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-02-27T16:13:35.744380Z",
     "start_time": "2024-02-27T16:13:35.706022Z"
    }
   },
   "id": "1c621b11717c7718",
   "execution_count": 1
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Simulation nº1\n",
    "\n",
    "Fix $\\epsilon = 0.05$, $p(x) \\sim \\mathcal{N}(0,1)$ and generate $n$ samples from the following data generative process:\n",
    "$\n",
    "\\begin{align}\n",
    "    x &\\sim p(x)\\\\ \n",
    "    b &\\sim \\mathcal{U}(\\{-1, 1\\})\\\\\n",
    "    y | x, b &\\sim \\mathcal{N}(bx, \\epsilon^2) \\\\\n",
    "\\end{align}$\n",
    "\n",
    "From now on, all distributions are defined conditionally on $x$."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "ebce5a6fe33dab01"
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Simulation nº1 with VE-SDE\n",
    "\n",
    "The diffusion process for $y_t$ defined by the VE-SDE is:\n",
    "$ \\left\\{ \\begin{array}{l}\n",
    "    d y_t = \\sqrt{ \\frac{d [\\sigma(t)^2]}{dt} } dW_t \\\\\n",
    "    y_0 = y_0 \n",
    "    \\end{array}\\right. \\\\\n",
    "     $, which implies the distribution of $y_t$ is: $ p(y_t | y_0) = \\mathcal{N}(y_0, \\sigma(t)^2) $.\n",
    "\n",
    "So we have:\n",
    "- $p_t(y_t | y_0) = \\mathcal{N}(y_0, \\sigma(t)^2)$\n",
    "- $p(y_0 | x, b) = \\mathcal{N}(bx, \\epsilon^2)$\n",
    "- $p(b) = \\mathcal{U}(\\{-1, 1\\})$\n",
    "\n",
    "Hence $$p_t(y_t | x) = \\frac{1}{2} \\sum_{b \\in \\{-1, 1\\}} \\mathcal{N}(y; bx, \\epsilon^2 + \\sigma(t)^2).$$\n"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "ccc66f647449144d"
  },
  {
   "cell_type": "markdown",
   "source": [
    "The score function is:\n",
    "\\begin{align}\n",
    "  \\nabla_y \\log p_t(y | x) &= \\frac{\\nabla_y p_t(y | x)}{p_t(y | x)} \\\\\n",
    "  &= \n",
    "  \\frac{\n",
    "    \\sum_{b \\in \\{-1, 1\\}} \n",
    "      \\exp( - \\frac{1}{2} \\frac{(y - bx)^2}{\\epsilon^2 + \\sigma(t)^2}) \n",
    "      \\cdot - \\frac{y - bx}{\\epsilon^2 + \\sigma(t)^2} \n",
    "    }{ \n",
    "      \\sum_{b \\in \\{-1, 1\\}} \\exp( - \\frac{1}{2} \\frac{(y - bx)^2}{\\epsilon^2 + \\sigma(t)^2}) \n",
    "    } \\\\\n",
    "  &= \\frac{-1}{\\epsilon^2 + \\sigma(t)^2} \\left(\n",
    "    y - x \\frac{\n",
    "        \\sum_{b \\in \\{-1, 1\\}} b\\exp( - \\frac{1}{2}\\frac{(y - bx)^2}{\\epsilon^2 + \\sigma(t)^2})\n",
    "      }{\n",
    "        \\sum_{b \\in \\{-1, 1\\}} \\exp( - \\frac{1}{2}\\frac{(y - bx)^2}{\\epsilon^2 + \\sigma(t)^2}) \n",
    "      }\n",
    "    \\right)\n",
    "\\end{align}\n",
    "\n",
    "We can further simplify this since $[\\exp(a) - \\exp(b) ] / [\\exp(a) + \\exp(b)] = \\tanh((a - b)/2)$, and we have:\n",
    "\\begin{align}\n",
    "  \\nabla_y \\log p_t(y | x) &= \\frac{-1}{\\epsilon^2 + \\sigma(t)^2} \\left(\n",
    "    y - x \\tanh\\left(\\frac{4xy}{\\epsilon^2 + \\sigma(t)^2}\\right)\n",
    "    \\right)\n",
    "\\end{align}\n"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "8ea7752a23737577"
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2024-02-27T16:16:42.575189Z",
     "start_time": "2024-02-27T16:16:42.572016Z"
    }
   },
   "outputs": [],
   "source": [
    "n = 1000\n",
    "X_train1 = np.random.rand(n, 1)\n",
    "y_train1 = X_train1 + np.random.randn(n, 1) * 0.05\n",
    "\n",
    "X_train2 = np.random.rand(n, 1)\n",
    "y_train2 = -X_train2 + np.random.randn(n, 1) * 0.05\n",
    "\n",
    "\n",
    "X_train = np.concatenate([X_train1, X_train2], axis=0)\n",
    "y_train = np.concatenate([y_train1, y_train2], axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "data": {
      "text/plain": "<matplotlib.collections.PathCollection at 0x17532fdd0>"
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.scatter(X_train, y_train)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-02-27T16:17:05.142431Z",
     "start_time": "2024-02-27T16:17:03.909738Z"
    }
   },
   "id": "eed3aff2344e384d",
   "execution_count": 5
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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ixeLR44cEc+cOSNu3bpVDAsLE4cMGWL6HuP05BEjRojJycnijh07RD8/P8mmJ7fm/HQ6nThw4EAxKipKzM7ObjIdsq6uThRFaV/D9evXi2q1Wvz888/FzMxM8fnnnxe9vLxMM6yeeuopce7cuabjf/31V1GhUIgJCQnisWPHxIULFzY7Pfl270lrae35LV++XFSpVOLGjRubvFbGz6DS0lJx1qxZYmJionjmzBnxxx9/FPv37y/26NHDqqG5ref31ltviTt37hRPnTolJiUliY8//rio0WjEjIwM0zG29PqJYuvP0ejee+8VH3vssRvut7XXsLS01PS7DoC4atUq8ejRo+K5c+dEURTFuXPnik899ZTpeOP05NmzZ4vHjh0T16xZ0+z05Fv9mbWXUweVZ555RgRww+2nn34yHYOG9SaM9Hq9+Oabb4oBAQGiWq0Whw8fLh4/frzJ8165ckV84oknRHd3d9HT01N89tlnm4Qfa7ldHWfOnLnhfEVRFOPj48WQkBCxvr7+huf84YcfxL59+4ru7u6im5ubGBMTI3700UfNHmsNrT3HnJwccciQIaKPj4+oVqvF7t27i7Nnz26yjoooiuLZs2fF0aNHiy4uLqKvr684c+bMJtN7raW15/fTTz81+3cagHjmzBlRFKV/DT/44AMxNDRUVKlU4l133SUeOnTI9NjQoUPFZ555psnxX3/9tdizZ09RpVKJffr0Eb///vsmj7fkPWlNrTm/zp07N/taLVy4UBRFUayoqBBHjBgh+vn5iUqlUuzcubP43HPPme0XQFu05vxeffVV07EBAQHigw8+KP7xxx9Nns/WXj9RbP3f0aysLBGAuGvXrhuey9Zew5t9RhjP6ZlnnhGHDh16w/f07dtXVKlUYlhYWJPfiUa3+jNrL0EUJZhXSkRERNQCXEeFiIiIbBaDChEREdksBhUiIiKyWQwqREREZLMYVIiIiMhmMagQERGRzWJQISIiIpvFoEJEREQ2i0GFiIiIbBaDChEREdksBhUiIiKyWQwqREREZLP+H2zAqr2XVRuJAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def score_function(y, x, sigma):\n",
    "    return -1 / (0.05**2 + sigma**2) * (y - x * np.tanh(4 * x * y / (0.05**2 + sigma**2)))\n",
    "\n",
    "x = 0.5\n",
    "t = 0.1\n",
    "sigma_min = 0.01\n",
    "sigma_max = 0.02\n",
    "sigma = sigma_min * (sigma_max / sigma_min)**t\n",
    "y = np.linspace(-1, 1, 1000)\n",
    "plt.plot(y, score_function(y, x, 0.1), label=f\"x={x}\")\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-02-27T17:09:50.248130Z",
     "start_time": "2024-02-27T17:09:50.191583Z"
    }
   },
   "id": "ca7f99e5a02e6dce",
   "execution_count": 30
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
