{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Short example of the advantage of iDQN over DQN"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Define the environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Transition: s' = As + Ba\n",
      "Transition: s' = 0.8s + -0.9a\n",
      "Reward: Qs² + 2 Ssa + Ra²\n",
      "Reward: -0.5s² + 0.4sa + -0.5a²\n",
      "P: -0.47176912283546646\n",
      "Optimal M: -0.882133 Optimal G: -0.8019322\n"
     ]
    }
   ],
   "source": [
    "from idqn.environments.lqr import LinearQuadraticEnv\n",
    "import numpy as np\n",
    "\n",
    "env = LinearQuadraticEnv(A=0.8, B=-0.9, Q=-0.5, R=-0.5, S=0.2)\n",
    "print(\"P:\", env.P)\n",
    "print(\"Optimal M:\", env.optimal_weights[2], \"Optimal G:\", env.optimal_weights[0])\n",
    "max_g = np.abs(env.optimal_weights[0] / 2)\n",
    "min_m = 2 * env.optimal_weights[2]  # always negative\n",
    "initial_point = np.array([0.5 * env.optimal_weights[2], -max_g / 2])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Compute the optimal itertaions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def optimal_bellman_iteration(point):\n",
    "    return np.array([env.R + env.B ** 2 * point[1], env.Q + env.A ** 2 * point[1]])\n",
    "\n",
    "def projection(point):\n",
    "    return np.array([min(point[0], 0), np.clip(point[1], -max_g, max_g)])\n",
    "\n",
    "def bellman_line(m):\n",
    "    return env.Q - env.R * env.A ** 2 / env.B ** 2 + env.A ** 2 / env.B ** 2 * m"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Run DQN and iDQN (offline)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import jax\n",
    "import jax.numpy as jnp\n",
    "\n",
    "def Q(params, s, a):\n",
    "    return params[\"G\"] * s ** 2 + params[\"M\"] * a ** 2\n",
    "\n",
    "def loss_dqn(params, target_params, batch_s, batch_a):\n",
    "    prediction = Q(params, batch_s, batch_a)\n",
    "\n",
    "    batch_s_prime = env.A * batch_s + env.B * batch_a\n",
    "    batch_reward = env.Q * batch_s ** 2 + 2 * env.S * batch_s * batch_a + env.R * batch_a ** 2\n",
    "    target = batch_reward + target_params[\"G\"] * batch_s_prime ** 2\n",
    "\n",
    "    return jnp.square(prediction - target).mean()\n",
    "\n",
    "def loss_idqn(params, target_params, batch_s, batch_a):\n",
    "    return loss_dqn(params[\"params_1\"], target_params[\"params_0\"], batch_s, batch_a) + loss_dqn(params[\"params_2\"], target_params[\"params_1\"], batch_s, batch_a)\n",
    "\n",
    "\n",
    "gradient_steps = 30\n",
    "lr = 0.05\n",
    "samples = jnp.linspace(0, jnp.pi, 10)\n",
    "batch_s = jnp.cos(samples)\n",
    "batch_a = jnp.sin(samples)\n",
    "dqn_params = {\"M\": initial_point[0], \"G\": initial_point[1]}\n",
    "target_dqn_params = {\"M\": initial_point[0], \"G\": initial_point[1]}\n",
    "idqn_params = {\"params_0\": dqn_params, \"params_1\": dqn_params, \"params_2\": dqn_params}\n",
    "target_idqn_params = {\"params_0\": dqn_params, \"params_1\": dqn_params, \"params_2\": dqn_params}\n",
    "\n",
    "project_params = lambda params: {\"M\": min(params[\"M\"], 0), \"G\": np.clip(params[\"G\"], -max_g, max_g)}\n",
    "\n",
    "for g in range(gradient_steps):\n",
    "    grad_dqn = jax.grad(loss_dqn)(dqn_params, target_dqn_params, batch_s, batch_a)\n",
    "    dqn_params = jax.tree_map(lambda x, y: x - lr * y, dqn_params, grad_dqn)\n",
    "    dqn_params = project_params(dqn_params)\n",
    "    \n",
    "    grad_idqn = jax.grad(loss_idqn)(idqn_params, target_idqn_params, batch_s, batch_a)\n",
    "    idqn_params = jax.tree_map(lambda x, y: x - lr * y, idqn_params, grad_idqn)\n",
    "    idqn_params[\"params_0\"] = project_params(idqn_params[\"params_0\"])\n",
    "    idqn_params[\"params_1\"] = project_params(idqn_params[\"params_1\"])\n",
    "    idqn_params[\"params_2\"] = project_params(idqn_params[\"params_2\"])\n",
    "    target_idqn_params = idqn_params  # update the target parameters\n",
    "\n",
    "extract_point = lambda params: np.array([params[\"M\"], params[\"G\"]])\n",
    "dqn_point = extract_point(dqn_params)\n",
    "idqn_point_1 = extract_point(idqn_params[\"params_1\"])\n",
    "idqn_point_2 = extract_point(idqn_params[\"params_2\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot results of DQN and iDQN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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FIDevXvz7bffyrxCQtgA2/u0EVVKYmIigHEtHVH+IiIijHOY9O3bl++//75UX+DPP/887du3L1HnXmtw69Yt6tatC0BgYCBbtmxBo9FYuCohRElIeBGiCouNjaVevXoABAcHs3nz5jJ9gTdo0IBHH320vMozm5SUFBo0aACAp6cnhw4dwt7e3sJVCSFKSsKLEFXU7du3jUPR/f392b9/P3Z2dqV+vp9//pmffvqJ0NDQ8irRLDIzM2nTpg3JycmAoc+Ls7OzhasSQphCwouwavPmzbN0CZVS3pYHFxcXTp06hZOTU5me89atWwB89NFHZa7PXHQ6Hf369SM8PByA69ev4+npaeGqhBCmkvAirFrHjh0JCgqiVq1ali6l0sjIyKB169bG/kRXr17F1dXVwlWZn6IojBo1ir179wJw4cIF+b0SwkZJeBFWbf369dSrV08WxSsnOTk59OzZk4sXLwJVq+XhlVde4eeffwYMw8IbNWpk4YqEEKUl87wIq7Z69WpSUlJITU2VfgllpNfrGTJkCAcPHgQMw9CrSsvDnDlzWLBgAWCYAfi+++6zcEVCiLKQlhdh1a5fv05UVBSHDh2ydCk2TVEUnn76aTZv3gxAWFgY9evXL9fX6NevH2q1Gi8vr3J93rJatmwZb775JgBbtmyha9euFq5ICFFWEl6EqAKmTJnCd999B8CRI0cICAgo99do1KgRjz76KJ9++mm5P3dprV27lueffx6AH3/8kYEDB1q4IiFEeZDwIkQl9/777xsDxd69e2nTpo1ZXufEiROcO3fOLM9dGtu3bzfOObNw4UJGjhxp4YqEEOVFwouwaoMGDbJ0CTZt8eLFzJgxA4CtW7fSrVs3s73WgQMHOHHiBBMnTjTba5TUwYMH6devHwBvv/02kyZNsnBFQojyJOFFWLXJkyej0WhkvZlSWLVqlfFL+5dffmHAgAEV8rpJSUkV8jqFOXPmDB07dgTgueee45133rFoPUKI8ifhRVg1vV7PM888Q8+ePS1dik357bffGD16NABff/01w4cPt3BFFePq1au0aNECgMGDB7N06VIJvkJUQjJUWli1yZMny5ePiXbu3MnDDz8MwPz583n22WctXFHFiI2NNY6gat++PevWrbPJla6FEMWTf9nCql2/fp3Q0FAOHz5s6VJsQkhICH369AHgzTffZMqUKRX2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lNx9kpKS+OmnnwpMFy9sW95OtqZe9klOTubPP/8EwNnZOd/Io1yHDh1i0KBBeHh44OzsTKdOnfjpp5/KVrQQolgSXoRV+/LLL00+5uzZs1y7dq1E+2o0GrRaLa+88grh4eEyq24lk3fOHlMvDS5btoyMjAwAHn300QKj0f766y+6du3Kvn37GDFiBBMmTCAmJobHH3+c+fPnl714IUShJLwIq+br68vjjz9uXHOoJEoyQ65Go0GlUvHEE09w4cIFPvnkE2rWrFnWcoWVybvidFRUVImPS05OZt68eQBotVqmT5+e7/GcnByee+451Go1e/bs4csvv2T+/PmcOHGCpk2b8uabb3L16tXyeRNCiAIkvAir9uSTTxIeHm6cpr0kNm7cWOjln9yhr/369ePEiRN8++230hGzEss7P1DezrvFmTp1KtHR0QBMmjTJuO5Vrp07d3Lx4kWeeOIJWrdubbzf3d2dN998k6ysLFauXFm24oUQhZLwIqzatWvXOHr0KBcuXCjR/omJifz9998FwktuS0ybNm3Ys2cPW7ZsoWXLluVer7AuQ4cONW4vXry4RKPWFixYwLJlywBo3bo1H374YYF9du3aBUD//v0LPJa79IApYUkIYRoJL8KqJSUlAZS4D8uff/6Zr29Dbh+WRo0asX79ekJCQujevXv5FyqsUnBwMA899BAAZ86cYfz48YX2fUlPT2fq1Km8/PLLADRo0IANGzbcc8mI8PBwAJo0aVLgMV9fX1xcXIz7CCHKn0xSJyqV3P4uer0elUqFt7c377//PmPHjr3n0GlR+X399de0a9eOyMhIvvnmGw4fPsyECRMIDg7G0dGR6Oho9u7dy8qVK42XioKDg9m4cWOho91yl5Uo7HKmm5ubcR8hRPmTT3NRaej1en777Tf0ej2urq7MmDGDF1980SyLOgrb4e3tzT///MOIESPYv38/J0+eZNKkSffc19nZmSlTpjBz5kxZXVwIKybhRVi1BQsW8Mwzz5R4/wkTJpCdnc306dOpXr26GSsTtqR27drs27ePzZs3s2bNGv7++29iY2NJTk427uPn58fRo0dLNOost8WlsNaVpKQk+f0TwowkvAir1qZNG1q1akXt2rWL3VetVvP+++9XQFWipHr16mVVE/8NGjSIQYMG5btv1KhRrF69msjISDZt2sTYsWOLfZ7cvi7h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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "dqn_color = \"#e41a1c\"\n",
    "idqn_color = \"#377eb8\"\n",
    "\n",
    "n_points = 10\n",
    "ms = np.linspace(min_m, 0, n_points)\n",
    "\n",
    "# Optimal point\n",
    "plt.scatter(env.optimal_weights[2], env.optimal_weights[0], color=\"black\", s=50)\n",
    "plt.text(-0.05 + env.optimal_weights[2], env.optimal_weights[0], \"$Q^*$\", fontsize=20)\n",
    "\n",
    "# Allowed parameter space\n",
    "plt.plot(ms, np.ones(n_points) * max_g, color=\"black\")\n",
    "plt.plot(ms, -np.ones(n_points) * max_g, color=\"black\")\n",
    "plt.fill_between(ms, -np.ones(n_points) * max_g, np.ones(n_points) * max_g, color=\"green\", alpha=0.3)\n",
    "plt.vlines(0, ymin=-max_g, ymax=max_g, color=\"black\")\n",
    "\n",
    "# Plot the first Bellman iteration and its projection\n",
    "plt.scatter(initial_point[0], initial_point[1], color=\"black\", s=50)\n",
    "plt.text(-0.09 + initial_point[0], initial_point[1], \"$Q_0$\", fontsize=20)\n",
    "x, y = initial_point[0], initial_point[1]\n",
    "first_iteration = optimal_bellman_iteration(initial_point)\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx / 1.2, dy / 1.2, head_width = 0.02, color=\"black\")\n",
    "\n",
    "plt.scatter(first_iteration[0], first_iteration[1], color=\"black\", s=50)\n",
    "plt.text(first_iteration[0], -0.1 + first_iteration[1], f\"$\\Gamma^*Q_0$\", fontsize=20)\n",
    "\n",
    "first_projection = projection(first_iteration)\n",
    "x, y = first_projection[0], first_projection[1]\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"black\", linestyle=\"dashed\")\n",
    "\n",
    "# Plot DQN point\n",
    "plt.scatter(dqn_point[0], dqn_point[1], color=dqn_color, s=200)\n",
    "plt.text(0.01 + dqn_point[0], 0.05 + dqn_point[1], \"$Q_1$\", color=dqn_color, fontsize=20)\n",
    "\n",
    "# Plot the first iDQN point\n",
    "plt.scatter(idqn_point_1[0], idqn_point_1[1], color=idqn_color, s=50)\n",
    "plt.text(-0.05 + idqn_point_1[0], 0.05 + idqn_point_1[1], \"$Q_1$\", color=idqn_color, fontsize=20)\n",
    "\n",
    "# Plot the second Bellman iteration and its projection from the first iDQN point\n",
    "x, y = idqn_point_1[0], idqn_point_1[1]\n",
    "second_iteration = optimal_bellman_iteration(idqn_point_1)\n",
    "dx, dy = second_iteration[0] - x, second_iteration[1] - y\n",
    "plt.arrow(x, y, dx / 1.2, dy / 1.2, head_width = 0.02, color=\"black\")\n",
    "\n",
    "plt.scatter(second_iteration[0], second_iteration[1], color=\"black\", s=50)\n",
    "plt.text(second_iteration[0], -0.03 + second_iteration[0], f\"$\\Gamma^*Q_1$\", fontsize=20)\n",
    "\n",
    "second_projection = projection(second_iteration)\n",
    "x, y = second_projection[0], second_projection[1]\n",
    "dx, dy = second_iteration[0] - x, second_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"black\", linestyle=\"dashed\")\n",
    "\n",
    "plt.scatter(idqn_point_2[0], idqn_point_2[1], color=idqn_color, s=50)\n",
    "plt.text(-0.05 + idqn_point_2[0], 0.05 + idqn_point_2[1], \"$Q_2$\", color=idqn_color, fontsize=20)\n",
    "\n",
    "plt.text(-0.95, -0.2, \"DQN\", color=\"red\", fontsize=20)\n",
    "plt.text(-0.95, -0.1, \"iDQN, with K = 2\", color=idqn_color, fontsize=20)\n",
    "\n",
    "plt.xlim(-1, -0.25)\n",
    "plt.ylim(-1, 0)\n",
    "plt.savefig(\"pratical_example.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot only DQN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "n_points = 10\n",
    "ms = np.linspace(min_m, 0, n_points)\n",
    "\n",
    "# Optimal point\n",
    "plt.scatter(env.optimal_weights[2], env.optimal_weights[0], color=\"black\", s=50)\n",
    "plt.text(-0.05 + env.optimal_weights[2], env.optimal_weights[0], \"$Q^*$\", fontsize=20)\n",
    "plt.text(-0.4, env.optimal_weights[0], \"$\\mathcal{Q}$\", fontsize=35)\n",
    "plt.text(-0.05 + env.optimal_weights[2], -0.2, \"$\\mathcal{Q}_{\\Theta}$\", fontsize=35)\n",
    "\n",
    "# Allowed parameter space\n",
    "plt.plot(ms, np.ones(n_points) * max_g, color=\"black\")\n",
    "plt.plot(ms, -np.ones(n_points) * max_g, color=\"black\")\n",
    "plt.fill_between(ms, -np.ones(n_points) * max_g, np.ones(n_points) * max_g, color=\"green\", alpha=0.3)\n",
    "plt.vlines(0, ymin=-max_g, ymax=max_g, color=\"black\")\n",
    "\n",
    "# Plot the first Bellman iteration and its projection\n",
    "plt.scatter(initial_point[0], initial_point[1], color=\"black\", s=50)\n",
    "plt.text(-0.09 + initial_point[0], initial_point[1], \"$Q_0$\", fontsize=20)\n",
    "x, y = initial_point[0], initial_point[1]\n",
    "first_iteration = optimal_bellman_iteration(initial_point)\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx / 1.2, dy / 1.2, head_width = 0.02, color=\"black\")\n",
    "\n",
    "plt.scatter(first_iteration[0], first_iteration[1], color=\"black\", s=50)\n",
    "plt.text(first_iteration[0], -0.1 + first_iteration[1], f\"$\\Gamma^*Q_0$\", fontsize=20)\n",
    "\n",
    "first_projection = projection(first_iteration)\n",
    "x, y = first_projection[0], first_projection[1]\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"black\", linestyle=\"dashed\")\n",
    "\n",
    "# Plot DQN point\n",
    "plt.scatter(dqn_point[0], dqn_point[1], color=\"black\", s=50)\n",
    "plt.text(0.01 + dqn_point[0], 0.05 + dqn_point[1], \"$Q_1$\", color=\"black\", fontsize=20)\n",
    "\n",
    "# Plot DQN loss\n",
    "x, y = dqn_point[0], dqn_point[1]\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"red\")\n",
    "plt.text(-0.01 + dqn_point[0], -0.12 + dqn_point[1], \"loss\", color=\"red\", fontsize=15, rotation=75)\n",
    "\n",
    "plt.xlim(-1, -0.25)\n",
    "plt.ylim(-1, 0)\n",
    "plt.xlabel(\"M\")\n",
    "plt.ylabel(\"G\")\n",
    "plt.savefig(\"pratical_example_dqn.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot only iDQN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAG2CAYAAACTTOmSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABv30lEQVR4nO3dd1gUVxcG8HcpgqKAKILEigWxo9g1ajAWjGJL1GisUWyJUVMkn0ZNYo1GYxRN7EaJJfZYorFjEMFesKFiAxSRBaWz8/0x7MAqZYFdlmXe3/Pss+PsndmzI7LHO+feqxAEQQARERGRDJkYOgAiIiIiQ2EiRERERLLFRIiIiIhki4kQERERyRYTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2WIiRERERLJldInQ8uXLUa1aNVhaWqJFixY4d+5cju23b9+OOnXqwNLSEg0aNMCBAwcKKVIiIiIq6owqEdq6dSsmT56MGTNm4MKFC2jUqBG6dOmCZ8+eZdn+v//+w8CBAzFy5EhcvHgRvXr1Qq9evXDt2rVCjpyIiIiKIoUxLbraokULNGvWDMuWLQMAqFQqVK5cGZ999hmmTp36Vvv+/fvj9evX+Pvvv6V9LVu2ROPGjbFy5cpCi5uIiIiKJjNDB6Ct5ORknD9/Hj4+PtI+ExMTdOrUCQEBAVkeExAQgMmTJ2vs69KlC3bv3p3t+yQlJSEpKUn6s0qlQnR0NMqVKweFQlGwD0FERESFQhAExMXFwcnJCSYm2d8AM5pEKCoqCmlpaXBwcNDY7+DggJs3b2Z5TERERJbtIyIisn2fuXPnYtasWQUPmIiIiAzu0aNHqFSpUravG00iVFh8fHw0epGUSiWqVKmCtSfWolTpUgaMjIiIiLQV/yoeIzqMQJkyZXJsZzSJUPny5WFqaorIyEiN/ZGRkXB0dMzyGEdHxzy1BwALCwtYWFi8tb9U6VJMhIiIiIxMbmUtRjNqrESJEmjatCmOHj0q7VOpVDh69ChatWqV5TGtWrXSaA8AR44cybY9ERERyYvR9AgBwOTJkzF06FC4u7ujefPmWLJkCV6/fo3hw4cDAIYMGYJ33nkHc+fOBQBMnDgR7du3x6JFi9C9e3ds2bIFwcHB+P333w35MYiIiKiIMKpEqH///nj+/Dm+++47REREoHHjxjh06JBUEP3w4UONyvDWrVvDz88P06ZNw7fffotatWph9+7dqF+/vqE+AhERERUhRjWPkCHExsbCxsYGW4K3sEaIiIjISMS/iscA9wFQKpWwtrbOtp3R1AgRERER6RoTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2WIiRERERLLFRIiIiIhki4kQERERyRYTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2WIiRERERLLFRIiIiIhki4kQERERyRYTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2WIiRERERLLFRIiIiIhki4kQERERyRYTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2WIiRERERLLFRIiIiIhki4kQERERyRYTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2WIiRERERLLFRIiIiIhki4kQERERyRYTISIiIpItJkJEREQkW0yEiIiISLaYCBEREZFsMREiIiIi2TIzdABERFQ0PX3wFMf2HMPVwKt4cv8JXse9hmVJS9hVsEM993ro4NUBdZvUNXSYRAXCRIiIiDTEvIjBmnlrcOrvUxAEQeO113Gv8TruNR6FPsKhrYfQ6v1WmDh3IkqVLmWgaIkKhokQERFJbl+5jR/H/YiYqBgAwDvV30FHr46o3bA2rMtaIz4uHjcv3cQBvwOIiohCwJEAPA9/jnmb56GERQnDBk+UD0yEiIgIAHDr8i1MHz4difGJMDM3w/CvhqP74O4wMdEsJ63fvD48P/bEj2N/xLWga7h77S42/rwRn/p8aqDIifKPxdJERITYl7H4cdyPUhI0zXcaegzp8VYSpFaqdCl8tfgrWJWxAgAc2nIIL6NeFmbIRDrBRIiIiLBi1gooXygBACO+HoEm7ZrkekzZ8mXRvkd7AEByUjLOnzyv1xiJ9IGJEBGRzF0LuoYzh84AAOq41UH3wd21PrZ+8/rS9u0rt3UeG5G+MREiIpK5XWt2SduDPh8EhUKh9bHlKpSTtmOiY3QZFlGhYCJERCRjURFRCD4ZDACo5FwJjVo1ytPxJqYZXyOpyak6jY2oMDARIiKSsUtnLklzBbXu3DrPx8fFxEnbpW1K6ywuosLCRIiISMauBV2Ttl2buOb5+LA7YdJ2BacKOomJ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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "n_points = 10\n",
    "ms = np.linspace(min_m, 0, n_points)\n",
    "\n",
    "# Optimal point\n",
    "plt.scatter(env.optimal_weights[2], env.optimal_weights[0], color=\"black\", s=50)\n",
    "plt.text(-0.05 + env.optimal_weights[2], env.optimal_weights[0], \"$Q^*$\", fontsize=20)\n",
    "\n",
    "# Allowed parameter space\n",
    "plt.plot(ms, np.ones(n_points) * max_g, color=\"black\")\n",
    "plt.plot(ms, -np.ones(n_points) * max_g, color=\"black\")\n",
    "plt.fill_between(ms, -np.ones(n_points) * max_g, np.ones(n_points) * max_g, color=\"green\", alpha=0.3)\n",
    "plt.vlines(0, ymin=-max_g, ymax=max_g, color=\"black\")\n",
    "\n",
    "# Plot the first Bellman iteration and its projection\n",
    "plt.scatter(initial_point[0], initial_point[1], color=\"black\", s=50)\n",
    "plt.text(-0.09 + initial_point[0], initial_point[1], \"$Q_0$\", fontsize=20)\n",
    "x, y = initial_point[0], initial_point[1]\n",
    "first_iteration = optimal_bellman_iteration(initial_point)\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx / 1.2, dy / 1.2, head_width = 0.02, color=\"black\")\n",
    "\n",
    "plt.scatter(first_iteration[0], first_iteration[1], color=\"black\", s=50)\n",
    "plt.text(first_iteration[0], -0.1 + first_iteration[1], f\"$\\Gamma^*Q_0$\", fontsize=20)\n",
    "\n",
    "first_projection = projection(first_iteration)\n",
    "x, y = first_projection[0], first_projection[1]\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"black\", linestyle=\"dashed\")\n",
    "\n",
    "# Plot the first iDQN point\n",
    "plt.scatter(idqn_point_1[0], idqn_point_1[1], color=\"black\", s=50)\n",
    "plt.text(-0.05 + idqn_point_1[0], 0.05 + idqn_point_1[1], \"$Q_1$\", color=\"black\", fontsize=20)\n",
    "\n",
    "# Plot iDQN loss for the first point\n",
    "x, y = idqn_point_1[0], idqn_point_1[1]\n",
    "dx, dy = first_iteration[0] - x, first_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"red\")\n",
    "plt.text(-0.01 + idqn_point_1[0], -0.12 + idqn_point_1[1], \"loss\", color=\"red\", fontsize=15, rotation=75)\n",
    "\n",
    "# Plot the second Bellman iteration and its projection from the first iDQN point\n",
    "x, y = idqn_point_1[0], idqn_point_1[1]\n",
    "second_iteration = optimal_bellman_iteration(idqn_point_1)\n",
    "dx, dy = second_iteration[0] - x, second_iteration[1] - y\n",
    "plt.arrow(x, y, dx / 1.2, dy / 1.2, head_width = 0.02, color=\"black\")\n",
    "\n",
    "plt.scatter(second_iteration[0], second_iteration[1], color=\"black\", s=50)\n",
    "plt.text(second_iteration[0], -0.03 + second_iteration[0], f\"$\\Gamma^*Q_1$\", fontsize=20)\n",
    "\n",
    "second_projection = projection(second_iteration)\n",
    "x, y = second_projection[0], second_projection[1]\n",
    "dx, dy = second_iteration[0] - x, second_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"black\", linestyle=\"dashed\")\n",
    "\n",
    "plt.scatter(idqn_point_2[0], idqn_point_2[1], color=\"black\", s=50)\n",
    "plt.text(-0.05 + idqn_point_2[0], 0.05 + idqn_point_2[1], \"$Q_2$\", color=\"black\", fontsize=20)\n",
    "\n",
    "# Plot iDQN loss for the second point\n",
    "x, y = idqn_point_2[0], idqn_point_2[1]\n",
    "dx, dy = second_iteration[0] - x, second_iteration[1] - y\n",
    "plt.arrow(x, y, dx, dy, color=\"red\")\n",
    "plt.text(-0.03 + idqn_point_2[0], -0.2 + idqn_point_2[1], \"loss\", color=\"red\", fontsize=15, rotation=75)\n",
    "\n",
    "plt.xlim(-1, -0.25)\n",
    "plt.ylim(-1, 0)\n",
    "plt.xlabel(\"M\")\n",
    "plt.ylabel(\"G\")\n",
    "plt.savefig(\"pratical_example_idqn.pdf\", bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env",
   "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.10.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
