{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "import pickle\n",
    "import numpy as np\n",
    "from environment import MDP, generate_mdp\n",
    "from PI import policy_iteration\n",
    "from sampling import omega_star_o, omega_star_g, oracle_policy\n",
    "from MDP_NaS import MDP_NaS\n",
    "from VRQL import VRQL, Delta_min, Mu_min"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1) Build RIver Swim MDP $\\mathcal{M}$, print $U_o(\\mathcal{M})$, save it in .pkl file "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "## River swim MDP from Strehl and Littman (2004)\n",
    "# Ns = 5\n",
    "# Na = 2\n",
    "# gamma = 0.95\n",
    "# R = np.zeros((Ns,Na)) #R[s,a]\n",
    "# R[0,0] = 5/(10**2)\n",
    "# R[Ns-1,1] = 1\n",
    "# P = np.zeros((Ns,Na,Ns)) #P[s,a,s']\n",
    "# for i in range(1,Ns-1): # action 0 = LEFT, 1 = RIGHT, 2 = STAY PUT\n",
    "#     P[i, 0, i-1] = 1\n",
    "#     P[i,1,i+1] = 1\n",
    "#     #P[i,2,i] = 1\n",
    "#     #R[i,1] = 5/(10**4)\n",
    "# P[0,0,0] = 1\n",
    "# P[0,1,1] = 1\n",
    "# P[Ns-1,0,Ns-2] = 1\n",
    "# P[Ns-1,1,Ns-1] = 1\n",
    "# riverswim = MDP(Ns,Na,P,R,reward_family = \"Bernoulli\", gamma=gamma)\n",
    "# pi,V,Q = policy_iteration(riverswim)\n",
    "# omega_o, U_o, H, H_star = omega_star_o(riverswim,pi, V, Q, omega_0 = None, N_iter=100)\n",
    "# omega_g, U_g, _, _ = omega_star_g(riverswim,pi, V, Q) #oracle allocation and upper bound in case of generative model for comparison (not used here)\n",
    "# print(\"U_o = {}, U_g = {} \".format(U_o, U_g))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import pickle\n",
    "# with open(\"./Instances/RIVER_SWIM.pkl\",\"wb\") as file:\n",
    "#     pickle.dump(mdp,file)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2) Load $\\mathcal{M}$ from the .pkl file and print info again "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "S = 5 , A = 2, Gamma = 0.95\n",
      "$U_o \\log(1/\\delta)$ = 4.383698E+05\n"
     ]
    }
   ],
   "source": [
    "name = \"RIVER_SWIM\"\n",
    "file = open(\"./Instances/\"+name+\".pkl\", 'rb')\n",
    "mdp = pickle.load(file)\n",
    "file.close()\n",
    "print(\"S = {} , A = {}, Gamma = {}\".format(mdp.Ns, mdp.Na, mdp.gamma))\n",
    "pi,V,Q = policy_iteration(mdp)\n",
    "omega_o, U_o, H, H_star = omega_star_o(mdp,pi, V, Q, omega_0 = None, N_iter=100)\n",
    "delta = 0.1\n",
    "#omega_g, U_g, _, _ = omega_star_g(mdp,pi, V, Q) #oracle allocation and upper bound in case of generative model for comparison (not used here)\n",
    "print(\"$U_o \\log(1/\\delta)$ = {}\".format(format(U_o*np.log(1/delta), \"10E\")))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 3) Run parallelized Monte-Carlo simulations    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def RunSim(procnum, REGISTER, name, mdp, Navigation = \"D\", delta= 1e-1, period = 1e4):\n",
    "    mdp_c = mdp.copy()\n",
    "    REGISTER[procnum] = MDP_NaS(mdp_c, Navigation, delta, period)\n",
    "    with open(\"./Results/\"+name+\"_\"+Navigation+ \"_\"+str(procnum)+\".pkl\",\"wb\") as file:\n",
    "        pickle.dump(REGISTER[procnum],file)\n",
    "    \n",
    "\n",
    "from multiprocessing import Process, Manager\n",
    "def RunExp(num, name, mdp, Navigation=\"D\",delta= 1e-1, period = 1e4):\n",
    "    start = time.time()\n",
    "    manager = Manager()\n",
    "    REGISTER = manager.dict()\n",
    "    jobs = [] \n",
    "    for i in range(num):\n",
    "        p = Process(target=RunSim, args = (i, REGISTER, name, mdp, Navigation, delta, period))\n",
    "        p.start()\n",
    "        jobs.append(p)\n",
    "    for p in jobs:\n",
    "        p.join()\n",
    "    end = time.time()\n",
    "    print('{:.4f} s'.format(end-start))\n",
    "    return REGISTER"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# num= 30\n",
    "# ALGOS = {\"name\":[\"D\", \"C\"], \"results\": []}\n",
    "# for alg in ALGOS[\"name\"]:\n",
    "#     REGISTER = RunExp(num, name, mdp, Navigation = alg,delta = 1e-1, period = 1e5)\n",
    "#     ALGOS[\"results\"].append(REGISTER)\n",
    "#     with open(\"./Results/results_\"+name+\"_\"+alg+\".pkl\",\"wb\") as file:\n",
    "#         pickle.dump(ALGOS,file)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 4) Plot results: "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "name = \"RIVER_SWIM\"\n",
    "num = 30\n",
    "ALGOS = {\"name\":[\"D\", \"C\"], \"results\": [0,0]}\n",
    "for i,alg in enumerate([\"C\", \"D\"]):\n",
    "    L = []\n",
    "    for exp in range(num):\n",
    "        file = open(\"./Results/\"+name+\"_\"+alg+ \"_\"+str(exp)+\".pkl\", 'rb')\n",
    "        REGISTER = pickle.load(file)\n",
    "        file.close()\n",
    "        L.append(REGISTER)\n",
    "    ALGOS[\"results\"][i] = L"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXwAAAEPCAYAAABBUX+lAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAABH3klEQVR4nO2deZhdVZXof+tONc+VuVJJgBAykkBImGQwioAoIAiojQIP00gjj7Z9YosD2k3rswFFacRo4/RsBEEGIYKAQSZBAoSZQIAMlcpU83Dne/b7Y59761bVrfnWdGv9vu9895yz9zlnn5zKWnuvtfbaYoxBURRFyX08490ARVEUZWxQga8oijJFUIGvKIoyRVCBryiKMkVQga8oijJF8I13A/qjurrazJ8/f7yboSiKMml44YUXGowx0zKVTWiBP3/+fDZv3jzezVAURZk0iMiOvspGbNIRkbkisklE3hSR10Xkf2eoIyLyIxHZJiKviMgRI32uoiiKMjSy0cOPA/9ijHlRREqAF0TkEWPMG2l1TgMWutta4Cfur6IoijJGjLiHb4zZY4x50d1vB94E5vSodibwa2N5FigXkVkjfbaiKIoyeLJqwxeR+cAq4LkeRXOAXWnHde65PRnusR5YD1BbW5vN5imKMgJisRh1dXWEw+HxbooC5OfnU1NTg9/vH/Q1WRP4IlIM3A1cZYxp61mc4ZKMSXyMMRuADQCrV6/WRD+KMkGoq6ujpKSE+fPnI5Lpv7QyVhhjaGxspK6ujgULFgz6uqzE4YuIHyvsf2uM+UOGKnXA3LTjGqA+G89WFGVsCIfDVFVVqbCfAIgIVVVVQx5tZSNKR4D/Bt40xtzYR7X7gc+60TpHA63GmF7mHEVRJjYq7CcOw/kW2TDpHAdcCLwqIlvcc18DagGMMbcCG4HTgW1AELg4C89VFEVRhkA2onSeMsaIMWaFMWalu200xtzqCnvc6Jx/MsYcbIxZbowZ3dlUmuNfUXKWvXv3csEFF3DwwQezZMkSTj/9dN5+++1uda699loKCwvZv39/6lxxcfGwn3nssccO+9pf/vKX1Nd3WbAvvfRS3njjjX6uGD1yM5eOkxjvFiiKMgoYYzj77LM56aSTePfdd3njjTf4j//4D/bt29erbnV1NTfccENWnvvMM88M+9qeAv/nP/85S5YsyUazhkxuCnyjAl9RcpFNmzbh9/u57LLLUudWrlzJBz7wgV51L7nkEu644w6ampp6lZ111lkceeSRLF26lA0bNgDwk5/8hK985SupOr/85S/54he/CHSNDhzH4fLLL2fp0qWcccYZnH766dx1110AfOc73+Goo45i2bJlrF+/HmMMd911F5s3b+Yzn/kMK1euJBQKcdJJJ6VSxtx+++0sX76cZcuWcfXVV6eeXVxczDXXXMPhhx/O0UcfnVGhDYcJnUtn2Bhje/ke73i3RFFykquugi1bsnvPlSvhhz/sv85rr73GkUceOaj7FRcXc8kll3DTTTfx7W9/u1vZbbfdRmVlJaFQiKOOOopzzjmHc889l2OOOYbvf//7ANxxxx1cc8013a77wx/+wPbt23n11VfZv38/ixcv5pJLLgHgiiuu4Jvf/CYAF154IQ888ADnnnsuN998M9dffz2rV6/udq/6+nquvvpqXnjhBSoqKjjllFO49957Oeuss+js7OToo4/muuuu4ytf+Qo/+9nP+PrXvz6o9+6P3Ozhg5p1FEXhyiuv5Fe/+hVtbd2nBv3oRz9K9Z537drFO++8w7Rp0zjooIN49tlnaWxsZOvWrRx33HHdrnvqqaf45Cc/icfjYebMmZx88smpsk2bNrF27VqWL1/OX/7yF15//fV+2/b8889z0kknMW3aNHw+H5/5zGd44oknAAgEApxxxhkAHHnkkWzfvj0L/xq52sMHNesoyigyUE98tFi6dGnKhJLONddcw4MPPgjAlrShR3l5OZ/+9Ke55ZZbUucef/xxHn30Uf72t79RWFjISSedlIpnP//887nzzjs57LDDOPvss3uFPpo+AkLC4TCXX345mzdvZu7cuVx77bUDxsj3dS8Av9+ferbX6yUej/d7r8GiPXxFUSYNH/zgB4lEIvzsZz9LnXv++ec55ZRT2LJlSzdhn+RLX/oSP/3pT1NCs7W1lYqKCgoLC3nrrbd49tlnU3U/8YlPcO+993L77bdz/vnn97rX8ccfz913343jOOzbt4/HH38cICXcq6ur6ejo6KaUSkpKaG9v73WvtWvX8te//pWGhgYSiQS33347J5544rD+XQZL7gp87eErSs4hItxzzz088sgjHHzwwSxdupRrr72W2bNn93lNdXU1Z599NpFIBIBTTz2VeDzOihUr+MY3vsHRRx+dqltRUcGSJUvY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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "#fig, axs = plt.subplots(2,2, figsize=(10,10))\n",
    "period = 1e4\n",
    "labels =[]\n",
    "Taus = []\n",
    "T = np.float('inf')\n",
    "for i,alg in enumerate([\"C\", \"D\"]):\n",
    "    labels.append(alg+\"-Navigation\")\n",
    "    REGISTER = ALGOS[\"results\"][i]\n",
    "    Taus_alg = []\n",
    "    for j in range(num):\n",
    "        X = REGISTER[j][\"time\"]\n",
    "        Taus_alg.append(X[-1])\n",
    "        if len(X) < T:\n",
    "            T = len(X)\n",
    "    Taus.append(Taus_alg)\n",
    "    \n",
    "Times = [period*j for j in range(T)]\n",
    "colors = [\"b\", \"r\"]\n",
    "for i,alg in enumerate([\"C\", \"D\"]):\n",
    "    REGISTER = ALGOS[\"results\"][i]\n",
    "    omega_d = np.array([REGISTER[j][\"omega_d\"][:T] for j in range(num)])\n",
    "    omega_d = np.log10(omega_d)\n",
    "    d10 = np.quantile(omega_d,0.1 ,axis=0)\n",
    "    d90 = np.quantile(omega_d,0.9 ,axis=0)\n",
    "    plt.plot(Times, np.mean(omega_d,axis = 0), label=alg+\"-Navigation\", color = colors[i])\n",
    "    plt.fill_between(Times, d10, d90, alpha=0.15)\n",
    "\n",
    "plt.xlabel(\"Time\",fontsize=20)\n",
    "#plt.ylabel(\"\" ,fontsize=24)\n",
    "plt.legend()\n",
    "ext = 'pdf'\n",
    "plt.savefig('omega_d_RIVERSWIM.'+ext, format=ext)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 5) Plot average sample complexity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlkAAAJJCAYAAACZLiLcAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAcu0lEQVR4nO3dfZBld13n8c9XJgIxCSSbIGVIGLWIlqIhpgEx4AbQWhYoH1mND7g+ZgtLCRp0V7YELAurXHcpUWSzEZTaMooSIlgUIqwmPLgmMjNMSCajWy5qjGBlAoGQiAuB7/5x72Db9KR7Mv3NdA+vV1VX7pzzO+f+7jBz5n3POfdS3R0AALbW5x3vCQAAnIhEFgDAAJEFADBAZAEADBBZAAADRBYAwIBtG1lV9RtVdXtV3bzJ8d9RVbdU1YGq+u3p+QEA3Jfart+TVVVfn+TuJP+zux+7wdjHJPm9JE/r7jur6hHdffsDMU8AgPVs2zNZ3f3OJB9evayqvrSq3lpVe6vqXVX15ctVP5Lk17r7zuW2AgsAOK62bWQdwZVJfry7L0zywiSvWi4/L8l5VfWnVXV9VT3juM0QACDJruM9gc2qqlOSfF2S11fV4cUPXv53V5LHJLk4yaOSvKuqHtvdH3mApwkAkGQHRVYWZ90+0t2PW2fdbUmu7+5PJvnrqvrLLKLrPQ/g/AAAPmPHXC7s7ruyCKh/lyS1cP5y9RuTPHW5/MwsLh++/3jMEwAg2caRVVW/k+TPknxZVd1WVT+U5HuS/FBV3ZjkQJJvXg7/oyQfqqpbklyb5Ke6+0PHY94AAMk2/goHAICdbNueyQIA2Mm25Y3vZ555Zu/evft4TwMAYEN79+69o7vPWrt8W0bW7t27s2fPnuM9DQCADVXV36633OVCAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGbBhZVXVOVV1bVQer6kBVXXaEcRdX1f7lmHesWfegqnpvVb15qyYOALCd7drEmHuTXN7d+6rq1CR7q+rt3X3L4QFV9fAkr0ryjO6+taoesWYflyU5mOS0LZo3AMC2tuGZrO7+YHfvWz7+WBaxdPaaYd+d5JruvnU57vbDK6rqUUmeleTVWzVpAIDt7qjuyaqq3UkuSHLDmlXnJTm9qq6rqr1V9X2r1v1ykp9O8ukN9n1pVe2pqj2HDh06mmlxAqqqkR8AeKBs5nJhkqSqTknyhiQv6O671tnPhUmenuShSf6sqq7PIr5u7+69VXXxfe2/u69McmWSrKys9GbnxYmpe3N/BKpq02MB4IG0qciqqpOyCKyruvuadYbcluSO7r4nyT1V9c4k5yf5miTfVFXPTPKQJKdV1W919/duzfQBALanzXy6sJK8JsnB7n75EYa9KclTqmpXVZ2c5InL8T/T3Y/q7t1JLknyJwILAPhcsJkzWRcleW6Sm6pq/3LZi5KcmyTdfUV3H6yqtyZ5Xxb3Xr26u28emC8AwI5Q2/F+lpWVld6zZ8/xngY7gHuyADjeqmpvd6+sXe4b3wEABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGbBhZVXVOVV1bVQer6kBVXXaEcRdX1f7lmHcczbYAACeaXZsYc2+Sy7t7X1WdmmRvVb29u285PKCqHp7kVUme0d23VtUjNrstAMCJaMMzWd39we7et3z8sSQHk5y9Zth3J7mmu29djrv9KLYFADjhHNU9WVW1O8kFSW5Ys+q8JKdX1XVVtbeqvu8otj28/tKq2lNVew4dOnQ00wIA2HY2HVlVdUqSNyR5QXfftWb1riQXJnlWkn+T5Ger6rxNbpsk6e4ru3ulu1fOOuuso3wZAADby2buyUpVnZRFJF3V3desM+S2JHd09z1J7qmqdyY5P8n/2cS2AAAnnM18urCSvCbJwe5++RGGvSnJU6pqV1WdnOSJSQ5uclsAgBPOZs5kXZTkuUluqqr9y2UvSnJuknT3Fd19sKremuR9ST6d5NXdfXNVPXm9bbv7LVv4GgAAtp0NI6u7352kNjHul5L80v3ZFgDgROMb3wEABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGiCwAgAEiCwBggMgCABggsgAABogsAIABIgsAYIDIAgAYILIAAAaILACAASILAGCAyAIAGCCyAAAGbBhZVXVOVV1bVQer6kBVXXaEcRdX1f7lmHesWv6MqvrLqvqrqvpPWzl5AIDtatcmxtyb5PLu3ldVpybZW1Vv7+5bDg+oqocneVWSZ3T3rVX1iOXyByX5tSTfmOS2JO+pqj9YvS0AwIlowzNZ3f3B7t63fPyxJAeTnL1m2Hcnuaa7b12Ou325/AlJ/qq739/dn0jyuiTfvFWTBwDYro7qnqyq2p3kgiQ3rFl1XpLTq+q6qtpbVd+3XH52kr9bNe62fHagHd73pVW1p6r2HDp06GimxQ5xxhlnpKq29CfJlu/zjDPOOM6/UwCcCDZzuTBJUlWnJHlDkhd0913r7OfCJE9P8tAkf1ZV1yepdXbV6+2/u69McmWSrKysrDuGne3OO+9M9/b/n/ZwvAHAsdhUZFXVSVkE1lXdfc06Q25Lckd335Pknqp6Z5Lzl8vPWTXuUUk+cGxTBgDY/jbz6cJK8pokB7v75UcY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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1,1, figsize=(10,10))\n",
    "axs.boxplot(Taus, notch = False, labels = labels, showfliers=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 6) Compare with VRQL:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples = 3.393258E+09\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(True,\n",
       " '3.393258E+09',\n",
       " array([0, 0, 0, 0, 0]),\n",
       " array([[0., 0.],\n",
       "        [0., 0.],\n",
       "        [0., 0.],\n",
       "        [0., 0.],\n",
       "        [0., 0.]]))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Ns = mdp.Ns\n",
    "Na = mdp.Na\n",
    "gamma = mdp.gamma\n",
    "pi_u = np.ones((Ns,Na))/Na #uniform policy\n",
    "pi_b = pi_u #behavior policy\n",
    "hyperparameters = {\"c0\": 0.01, \"c1\": 10, \"c2\":10, \"c3\":10, \"mu_min\": Mu_min(mdp, pi_b)}\n",
    "VRQL(mdp, U_o, pi_b, hyperparameters, epsilon = Delta_min(V,Q, gamma), delta = 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "#!pip3 freeze > requirements.txt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python3UMPA",
   "language": "python",
   "name": "python3umpa"
  },
  "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.5"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  },
  "varInspector": {
   "cols": {
    "lenName": 16,
    "lenType": 16,
    "lenVar": 40
   },
   "kernels_config": {
    "python": {
     "delete_cmd_postfix": "",
     "delete_cmd_prefix": "del ",
     "library": "var_list.py",
     "varRefreshCmd": "print(var_dic_list())"
    },
    "r": {
     "delete_cmd_postfix": ") ",
     "delete_cmd_prefix": "rm(",
     "library": "var_list.r",
     "varRefreshCmd": "cat(var_dic_list()) "
    }
   },
   "types_to_exclude": [
    "module",
    "function",
    "builtin_function_or_method",
    "instance",
    "_Feature"
   ],
   "window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
