{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBO optimal on LQR\n",
    "\n",
    "## Define paramters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:17:00.492402Z",
     "iopub.status.busy": "2022-09-19T14:17:00.492203Z",
     "iopub.status.idle": "2022-09-19T14:17:01.076208Z",
     "shell.execute_reply": "2022-09-19T14:17:01.075677Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import warnings\n",
    "warnings.simplefilter(action='ignore', category=FutureWarning)\n",
    "import jax\n",
    "import os\n",
    "import json\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "env_seed = parameters[\"env_seed\"]\n",
    "\n",
    "dummy_max_discrete_state = parameters[\"max_discrete_state\"]\n",
    "\n",
    "# Q function\n",
    "dummy_max_action_on_max = parameters[\"max_action_on_max\"]\n",
    "dummy_n_actions_on_max = parameters[\"n_actions_on_max\"]\n",
    "\n",
    "# Visualisation of errors and performances\n",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 5\n",
    "dummy_learning_rate = {\"first\": 0, \"last\": 0, \"duration\": 0}\n",
    "\n",
    "# keys\n",
    "env_key = jax.random.PRNGKey(env_seed)\n",
    "dummy_q_network_key = env_key.copy()\n",
    "dummy_pbo_network_key = env_key.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:17:01.079239Z",
     "iopub.status.busy": "2022-09-19T14:17:01.078993Z",
     "iopub.status.idle": "2022-09-19T14:17:01.311763Z",
     "shell.execute_reply": "2022-09-19T14:17:01.311297Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Transition: s' = As + Ba\n",
      "Transition: s' = 0.7204725742340088s + -0.5264108180999756a\n",
      "Reward: Qs² + Ra² + 2 Ssa\n",
      "Reward: -0.13297832012176514s² + -0.8039400577545166a² + 0.2581009864807129sa\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.linear_quadratic import LinearQuadraticEnv\n",
    "\n",
    "env = LinearQuadraticEnv(env_key, max_init_state=dummy_max_discrete_state)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Optimal PBO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:17:01.315891Z",
     "iopub.status.busy": "2022-09-19T14:17:01.315689Z",
     "iopub.status.idle": "2022-09-19T14:17:01.789860Z",
     "shell.execute_reply": "2022-09-19T14:17:01.789386Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0. 0. 0.]\n",
      "[-0.13297832  0.12905049 -0.80394006]\n",
      "[-0.19125178  0.1716278  -0.83504903]\n",
      "[-0.21394302  0.18820707 -0.8471626 ]\n",
      "[-0.22232801  0.19433354 -0.85163891]\n",
      "[-0.22536612  0.19655332 -0.85326076]\n",
      "[-0.22645904  0.19735186 -0.85384423]\n",
      "[-0.2268512   0.19763839 -0.85405356]\n",
      "[-0.22699177  0.19774109 -0.8541286 ]\n",
      "[-0.22704215  0.19777791 -0.85415548]\n",
      "Optimal weights\n",
      "[-0.22707027  0.19779846 -0.8541705 ]\n"
     ]
    }
   ],
   "source": [
    "from tqdm.notebook import tqdm\n",
    "\n",
    "from pbo.networks.learnable_q import LQRQ\n",
    "from pbo.networks.learnable_pbo import CustomLinearPBO\n",
    "\n",
    "q = LQRQ(\n",
    "    n_actions_on_max=dummy_n_actions_on_max,\n",
    "    max_action_on_max=dummy_max_action_on_max,\n",
    "    network_key=dummy_q_network_key,\n",
    "    zero_initializer=True\n",
    ")\n",
    "pbo_optimal = CustomLinearPBO(\n",
    "    q=q,\n",
    "    max_bellman_iterations=max_bellman_iterations,\n",
    "    network_key=dummy_pbo_network_key,\n",
    "    learning_rate=dummy_learning_rate,\n",
    "    initial_weight_std=0,\n",
    ")\n",
    "pbo_optimal.params[\"CustomLinearPBONet\"][\"slope\"] = env.optimal_slope.reshape((1, 3))\n",
    "pbo_optimal.params[\"CustomLinearPBONet\"][\"bias\"] = env.optimal_bias.reshape((1, 3))\n",
    "\n",
    "validation_initial_weight = q.to_weights(q.params)\n",
    "\n",
    "weights = np.zeros((max_bellman_iterations_validation + 1, q.weights_dimension))\n",
    "\n",
    "batch_iterated_weights = validation_initial_weight.reshape((1, -1))\n",
    "for bellman_iteration in range(max_bellman_iterations_validation + 1):\n",
    "    weights[bellman_iteration] = batch_iterated_weights[0]\n",
    "    print(weights[bellman_iteration])\n",
    "\n",
    "    batch_iterated_weights = pbo_optimal(pbo_optimal.params, batch_iterated_weights)\n",
    "    \n",
    "print(\"Optimal weights\")\n",
    "print(env.optimal_weights)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:17:01.792304Z",
     "iopub.status.busy": "2022-09-19T14:17:01.792169Z",
     "iopub.status.idle": "2022-09-19T14:17:01.862942Z",
     "shell.execute_reply": "2022-09-19T14:17:01.862393Z"
    }
   },
   "outputs": [],
   "source": [
    "if not os.path.exists(\"figures/data/PBO_optimal/\"):\n",
    "    os.makedirs(\"figures/data/PBO_optimal/\")\n",
    "np.save(f\"figures/data/PBO_optimal/{max_bellman_iterations}_W.npy\", weights)\n",
    "np.save(f\"figures/data/PBO_optimal/{max_bellman_iterations}_Pi.npy\", env.greedy_V(weights))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:17:01.865084Z",
     "iopub.status.busy": "2022-09-19T14:17:01.864923Z",
     "iopub.status.idle": "2022-09-19T14:17:02.585010Z",
     "shell.execute_reply": "2022-09-19T14:17:02.584571Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.utils.lqr_weights_viewer import visualize\n",
    "\n",
    "\n",
    "visualize(weights, env.optimal_weights)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.10 ('env_cpu': venv)",
   "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.8.10"
  },
  "vscode": {
   "interpreter": {
    "hash": "af5525a3273d35d601ae265c5d3634806dd61a1c4d085ae098611a6832982bdb"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
