{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "062df147",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import sys\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from Env import FiniteStateFiniteActionMDP\n",
    "import pickle\n",
    "from FedQ import FedQlearning_gen\n",
    "from fed_adv import FedQlearning_gen_adv\n",
    "path_pre = \"C:\\\\Users\\\\15000\\\\Dropbox\\\\8542_federated_q_learning_linear_supp\\\\code_fedq_0803_neurips_rebuttal\\\\result\\\\result_\"\n",
    "\n",
    "total_episodes = 30000\n",
    "num_agents = 10\n",
    "num_experiment = 10\n",
    "final_result_regret = dict()\n",
    "mapping = {0:2,1:3,2:5}\n",
    "mapping = {0:0,1:1,2:2,3:3,4:4,5:5}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d5df4f97",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i,name in enumerate([\"UCB-H\", \"UCB-B\", \"FedQ-H\", \"FedQ-B\",\"UCB-A\",\"FedQ-A\"]):\n",
    "    cum_collection_fed = [0.0]*num_experiment\n",
    "    result_regret_sqrt_fed= np.zeros((total_episodes*num_agents, num_experiment))\n",
    "    for expe in range(num_experiment):\n",
    "        f = open(path_pre+str(expe+mapping[i]*10), 'rb')\n",
    "        best_value, best_Q, value_fed, global_Q_fed, fed_q = pickle.load(f)\n",
    "        f.close()\n",
    "        for t in range(total_episodes*num_agents):\n",
    "            cum_collection_fed[expe] += fed_q.raw_gap[t]\n",
    "            result_regret_sqrt_fed[t,expe] = cum_collection_fed[expe]/np.sqrt(t+1)/np.sqrt(10)\n",
    "\n",
    "    final_result_regret[name] = result_regret_sqrt_fed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2813355d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAEKCAYAAAD9xUlFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABX/klEQVR4nO2dd3gc1dX/P3dXvUuWbMu9yparXMFgMNX0TkIJAUISEzAQSCAJIfnB+yYkYEjImwAhhlBCMdUQSjAGgimm2sZgGzew5YKbZFmyetm9vz/Ozu5KlmRptdJK3vN5nnlmdnb2zp1dab5zzrn3HGOtRVEURVEAXJHugKIoitJ9UFFQFEVR/KgoKIqiKH5UFBRFURQ/KgqKoiiKn5hId6A9ZGdn2yFDhkS6G4qiKD2K5cuXF1trc9pybI8ShSFDhrBs2bJId0NRFKVHYYzZ0tZj1X2kKIqi+FFRUBRFUfyoKCiKoih+elRMQVGU8FBfX8/27dupqamJdFeUMJKQkMCAAQOIjY0NuQ0VBUWJQrZv305qaipDhgzBGBPp7ihhwFrL3r172b59O0OHDg25HXUfKUoUUlNTQ69evVQQDiGMMfTq1avD1l9ERcEYc4MxZo0xZrUxZoExJiGS/VGUaEIF4dAjHL9pxETBGNMfuA6Yaq0dB7iBCyPVH0VRFCXy7qMYINEYEwMkATs660S1tbBtW2e1rihKe3G73RQUFPiXwsLCNn2usLCQcePG+V9/8MEHTJ8+ndGjRzNq1Cjuu+++Fj97+eWX8/zzzzfal5KSElL/Af7617+Sn5/P9773PWpraznhhBMoKCjgmWeeaXTckiVLOP300wF4+eWXueOOO0I+Z2cTsUCztfZbY8zdwFagGlhsrV3c9DhjzBxgDsCgQYNCPt+ewiqqC3fDwNADMIqihI/ExERWrlzZoTZ27drFxRdfzEsvvcTkyZMpLi7mpJNOol+/fpxzzjnh6Wgr3H///bz++usMHTqUjz/+mPr6+oNe05lnnsmZZ57Z6X0LlUi6jzKBs4ChQD8g2RhzSdPjrLXzrbVTrbVTc3LalLqjWapLa7BerTKnKN2Z5cuXM2vWLKZMmcJJJ53Ezp07/fsnTpzIjBkzGlkC9913H5dffjmTJ08GIDs7m3nz5nHXXXe1+9zWWm666SbGjRvH+PHjGz3t33XXXUybNo0JEyZw6623AvCTn/yETZs2ceaZZ3LnnXdyySWXsHLlSgoKCvjmm29YtGgRo0ePZubMmSxcuNDf1qOPPso111wDiOVy3XXXccQRRzBs2DC/FeP1ern66qsZO3Ysp59+OqeeeuoBFk5nEckhqScAm621RQDGmIXAEcATnXVClQRFaYbrr4cOPrEfQEEB/OUvrR5SXV1NQUEBAEOHDuXZZ5/l2muv5d///jc5OTk888wz3HLLLTz88MP84Ac/4G9/+xuzZs3ipptu8rexZs0aLrvsskbtTp06la+++qrF89500038/ve/P2D/woULWblyJV988QXFxcVMmzaNo48+mlWrVrFx40Y+/fRTrLWceeaZvPfeezzwwAMsWrSId955h+zsbA477DDuvvtuXn31VWpqajjmmGP473//y4gRI7jgggta7M/OnTv54IMPWLduHWeeeSbnn38+CxcupLCwkFWrVrFnzx7y8/O54oorWv0+w0UkRWErcLgxJglxHx0PdGK2O4PXo7KgKN2Fpu6j1atXs3r1ak488UQAPB4Pubm5lJWVUVpayqxZswD4/ve/z+uvvw7I0317R9zcddddnH/++f7XTkzhgw8+4KKLLsLtdtOnTx9mzZrFZ599xnvvvcfixYuZNGkSABUVFWzcuJGjjz66xXOsW7eOoUOHMnLkSAAuueQS5s+f3+yxZ599Ni6XizFjxrB7925/X77zne/gcrno27cvxx57bLuusSNEMqbwiTHmeWAF0AB8DjT/rYWBnBzYWdRZrStKD+YgT/RdhbWWsWPH8tFHHzXaX1pa2uKNf+zYsSxbtqyRj3758uVMnToVgB/84Ad8/vnn9OvXj//85z8HPX9L+2+++WauvPLK9lxOm8UqPj7+gD601JeuIKKjj6y1t1prR1trx1lrv2+tre2sc3nKKrDezmpdUZSOMmrUKIqKivyiUF9fz5o1a8jIyCA9PZ0PPvgAgCeffNL/mblz5/Loo4/6LY69e/dyyy238Nvf/haARx55hJUrVx5UEACOPvponnnmGTweD0VFRbz33ntMnz6dk046iYcffpiKigoAvv32W/bs2dNqW6NHj2bz5s188803ACxYsKBd38XMmTN54YUX8Hq97N69myVLlrTr8x0hatJcNFTVAZb6euhAWhBFUTqJuLg4nn/+ea677jrKyspoaGjg+uuvZ+zYsTzy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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plt.plot([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "#          np.median(final_result_regret[\"UCB-H\"],axis = 1), \"g\", label = \"UCB-H\")\n",
    "# plt.plot([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "#          np.median(final_result_regret[\"UCB-B\"],axis = 1), \"m\", label = \"UCB-B\")\n",
    "plt.plot([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "         np.median(final_result_regret[\"FedQ-H\"],axis = 1), \"r\", label = \"FedQ-Hoeffding\")\n",
    "plt.plot([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "         np.median(final_result_regret[\"FedQ-B\"],axis = 1), \"b\", label = \"FedQ-Bernstein\")\n",
    "# plt.plot([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "#          np.median(final_result_regret[\"UCB-A\"],axis = 1), \"c\", label = \"UCB-A\")\n",
    "plt.plot([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "         np.median(final_result_regret[\"FedQ-A\"],axis = 1), \"y\", label = \"FedQ-Advantage\")\n",
    "\n",
    "\n",
    "\n",
    "# plt.fill_between([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "#                  np.quantile(final_result_regret[\"UCB-H\"], 0.10, axis = 1), \n",
    "#                  np.quantile(final_result_regret[\"UCB-H\"], 0.90, axis = 1), \n",
    "#                  alpha=0.15, color = \"g\")\n",
    "\n",
    "# plt.fill_between([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "#                  np.quantile(final_result_regret[\"UCB-B\"], 0.10, axis = 1), \n",
    "#                  np.quantile(final_result_regret[\"UCB-B\"], 0.90, axis = 1), \n",
    "#                  alpha=0.15, color = \"m\")\n",
    "\n",
    "plt.fill_between([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "                 np.quantile(final_result_regret[\"FedQ-H\"], 0.10, axis = 1), \n",
    "                 np.quantile(final_result_regret[\"FedQ-H\"], 0.90, axis = 1), \n",
    "                 alpha=0.15, color = \"r\")\n",
    "\n",
    "plt.fill_between([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "                 np.quantile(final_result_regret[\"FedQ-B\"], 0.10, axis = 1), \n",
    "                 np.quantile(final_result_regret[\"FedQ-B\"], 0.90, axis = 1), \n",
    "                 alpha=0.15, color = \"b\")\n",
    "\n",
    "# plt.fill_between([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "#                  np.quantile(final_result_regret[\"UCB-A\"], 0.10, axis = 1), \n",
    "#                  np.quantile(final_result_regret[\"UCB-A\"], 0.90, axis = 1), \n",
    "#                  alpha=0.15, color = \"c\")\n",
    "\n",
    "plt.fill_between([ii for ii in range(1,total_episodes*num_agents + 1)], \n",
    "                 np.quantile(final_result_regret[\"FedQ-A\"], 0.10, axis = 1), \n",
    "                 np.quantile(final_result_regret[\"FedQ-A\"], 0.90, axis = 1), \n",
    "                 alpha=0.15, color = \"y\")\n",
    "plt.legend()\n",
    "#plt.legend(loc = 'center right',bbox_to_anchor=(0.98, 0.7))\n",
    "plt.xlabel(\"Total number of episodes $MT/H$\")\n",
    "plt.ylabel(\"Regret$(T)/\\sqrt{MT}$\")\n",
    "plt.savefig(\"regret_plot_fed_q_new_small_replication.jpg\",dpi = 600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "931e6f96",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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4IM58cQTefrpp/nUpz7FE088wbp161i1ahWVlZXMmDGDq6++mlNPPZVrr72WvXv3kp+fz8MPP8zFF18MwO23386IESOIxWKcfPLJvPPOO8yePRuwhuvNN9/kF7/4BXfeeSe//vWv9yl1vmfPHl599VVEhF//+tfccccd/OhHP+Jb3/oWJ510EjfffDPPPvssixYtAuzs7YcffphXXnmFUCjEDTfcwO9//3suv/zyLv8+yajBSKI5bC30qClT+1kSRVGgf8qbL168mEsuuQSASy65hIceeohPfepTLF26lEsvvZRgMMi4ceM46aSTAMjKyuKMM87gL3/5CxdccAF/+9vfuOOOOwB45JFHWLRoEdFolIqKCt599902g/GpT30KsOXPH3/88ZSylJeXc/HFF1NRUUE4HGbKlCmAjck88cQTAJxxxhlts9ZffPFFVqxYwdFHHw1Ygztq1Ki0n70z1GAkEWYP4XA2IyZN6m9RFGVAsb+RQF+R6fLmf/nLX3jsscd46qmnuP322zHGUFNT01ZNtqN7XHzxxdx9992MGDGCo48+msLCQjZt2sSdd97JG2+8QUlJCVdeeWWbewsS5cmDwSDRaDTldb/whS/w1a9+lXPOOYclS5Zw2223tX0PHX0/V1xxBf/7v/+bcn9PGDQxDBE5Q0TWich6EflGpu4TD9XSUFvKsOG6eJKiDEQyXd78hRdeYM6cOWzbto3NmzezZcsWzj//fP785z9z/PHH88c//pFYLEZFRQUvvfRS2z1OPPFE3nzzTe699942d1R9fT35+fkUFxdTWVnZNuLpjORS53V1dYwfb+vaPfjgg23txx13HI888ghgVwLcs2cPACeffDKPPvpoW3xl9+7dbNmypQvfcMcMCoMhIkHgbuDjwAzgUhGZkYl7BYbV0VRbQm6RGgxFGYi48uZf//rXmTNnDnPnzm1LQ73//vtZuHAhxx57bLvFh/zlzadPn864ceP44he/mLK8+eLFi/fJnDr//PP5wx/+wHnnnce0adM44ogjuP7669udHwwGOeuss3jmmWc466yzAJgzZw5HHnkkM2fO5Oqrr+YjH9l/9euzzz6bJ554oi3ofdttt3HhhRfy0Y9+lJEjR7Ydd+utt/L8888zb948nnnmGcaOHUthYSEzZszgu9/9LqeddhqzZ8/m1FNPbUsK6CmDory5iBwL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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def get_rounds(arr,total):\n",
    "    result = np.array([0]*total)\n",
    "    result[0] = 2\n",
    "    for i in range(1,len(arr)):\n",
    "        result[arr[i-1]:arr[i]] = i+1\n",
    "    result[arr[len(arr) - 1]: ] = len(arr) + 1\n",
    "    return result\n",
    "\n",
    "\n",
    "for i,name in enumerate([\"UCB-H\", \"UCB-B\", \"FedQ-Hoeffding\", \"FedQ-Bernstein\",\"UCB-A\",\"FedQ-Advantage\"]):\n",
    "    if not \"Fed\" in name:\n",
    "        continue\n",
    "    dict_results = dict()\n",
    "    for expe in range(num_experiment):\n",
    "        f = open(path_pre+str(expe+mapping[i]*10), 'rb')\n",
    "        best_value, best_Q, value_fed, global_Q_fed, fed_q = pickle.load(f)\n",
    "        f.close()\n",
    "        dict_results[expe] = fed_q.comm_episode_collection\n",
    "    \n",
    "    num_rounds_collection_lower = []\n",
    "    num_rounds_collection_median = []\n",
    "    num_rounds_collection_upper = []\n",
    "\n",
    "    result0 = np.zeros((total_episodes, num_experiment))\n",
    "    for iii in range(num_experiment):\n",
    "        result0[:,iii] = get_rounds(dict_results[iii],total_episodes)\n",
    "    for t in range(total_episodes):\n",
    "        num_comms = result0[t,:]\n",
    "        num_rounds_collection_lower.append(np.quantile(num_comms, 0.1))\n",
    "        num_rounds_collection_median.append(np.quantile(num_comms, 0.5))\n",
    "        num_rounds_collection_upper.append(np.quantile(num_comms, 0.9))\n",
    "    coloring = \"r\"\n",
    "    if \"Bernstein\" in name:\n",
    "        coloring = \"b\"\n",
    "    if \"Advantage\" in name:\n",
    "        coloring = \"y\"\n",
    "    plt.plot([ii for ii in range(1,total_episodes + 1)],num_rounds_collection_median,coloring,label = name)\n",
    "    plt.fill_between([ii for ii in range(1,total_episodes + 1)], \n",
    "                 num_rounds_collection_lower, \n",
    "                 num_rounds_collection_upper, \n",
    "                 alpha=0.15, color = coloring)\n",
    "plt.legend()\n",
    "plt.xlabel(\"$T/H$\")\n",
    "plt.ylabel(\"Rounds of Communications\")\n",
    "plt.savefig(\"comm_rounds_plot_fed_q_new_replication.jpg\",dpi = 600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "35d7dcb5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
