{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "import sys\n",
    "import os\n",
    "sys.path.append(os.getcwd())\n",
    "import utils\n",
    "from ray.util.multiprocessing import Pool\n",
    "import seaborn as sns\n",
    "sns.set()\n",
    "sns.set_style('whitegrid')\n",
    "sns.axes_style({'axes.edgecolor':.5, 'axes.font.family':'Helvectia'})\n",
    "\n",
    "from Algorithm import Algorithm\n",
    "from Worker import Worker\n",
    "from Instance import Instance \n",
    "from plot_functions import fixed_budget_plot, bar_plot, line_plot\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# !pip install ray[default]\n",
    "# !pip install protobuf==3.20\n",
    "# !pip uninstall -y pyarrow\n",
    "# !pip install pyarrow"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36m(PoolActor pid=6861)\u001b[0m 1 94592 [0.06485865 0.45420894 0.45401106 0.02692136] 634.2332471160605\n",
      "\u001b[36m(PoolActor pid=6882)\u001b[0m 1 5920 [0.25 0.25 0.25 0.25] 8.0\u001b[32m [repeated 25x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=6979)\u001b[0m 2 28267 [0.25 0.25 0.25 0.25] 8.0\u001b[32m [repeated 16x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=6991)\u001b[0m 1 5922 [0.25005001 0.24995003 0.25014999 0.24984997] 8.003202881793335\u001b[32m [repeated 19x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7001)\u001b[0m 1 116780 [0.06485865 0.45420894 0.45401106 0.02692136] 783.0040087852599\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7025)\u001b[0m 1 7309 [0.25 0.25 0.25 0.25] 9.876543209876543\u001b[32m [repeated 25x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7051)\u001b[0m 1 7309 [0.25 0.25 0.25 0.25] 9.876543209876543\u001b[32m [repeated 15x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7069)\u001b[0m 1 7312 [0.24984997 0.24995003 0.25005001 0.25014999] 9.880497384930042\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7079)\u001b[0m 1 147800 [0.06485865 0.45420894 0.45401106 0.02692136] 990.9894486188444\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7104)\u001b[0m 1 9250 [0.25 0.25 0.25 0.25] 12.5\u001b[32m [repeated 25x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7120)\u001b[0m 1 9250 [0.25 0.25 0.25 0.25] 12.5\u001b[32m [repeated 15x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7132)\u001b[0m 1 9254 [0.25005001 0.24995003 0.25014999 0.24984997] 12.505004502802086\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7177)\u001b[0m 1 193043 [0.06485185 0.4540117  0.45421374 0.02692272] 1294.3458082729687\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7194)\u001b[0m 4 536396 [1.99960008e-08 4.99899960e-01 5.00100000e-01 1.99960008e-08] 8.163265959126875\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7203)\u001b[0m 2 57687 [0.25 0.25 0.25 0.25] 16.326530612244905\u001b[32m [repeated 6x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7227)\u001b[0m 1 12081 [0.25 0.25 0.25 0.25] 16.326530612244905\u001b[32m [repeated 14x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=7241)\u001b[0m 1 12086 [0.24995003 0.25005001 0.24984997 0.25014999] 16.333067105700692\u001b[32m [repeated 20x across cluster]\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "# instance definition\n",
    "eps_vals = [1.0, 0.9, 0.8, 0.7]\n",
    "# eps_vals = [0.9]\n",
    "for v, eps in enumerate(eps_vals):\n",
    "    # print('eps:', eps)\n",
    "    d = 4\n",
    "    W = np.eye(d)\n",
    "    Z = np.eye(d)\n",
    "    a = .5\n",
    "    b = .75\n",
    "    theta = np.linspace(a, b, d)\n",
    "    # print('theta:', theta)\n",
    "    # Gamma = (1-eps)*np.ones((d, d))/d + eps*np.eye(d) # noisy model\n",
    "    Gamma = (1-eps)*np.ones((d, d))/d + eps*np.array([[0, 1, 0, 0], [0, 0, 1, 0], [0, 0, 0, 1], [1, 0, 0, 0]]) # permutation model\n",
    "\n",
    "    Gamma = Gamma\n",
    "\n",
    "    instance_type = 'compliance'\n",
    "    sigma_x = None\n",
    "    sigma_y = 0.15\n",
    "\n",
    "    # algorithm definition constants\n",
    "    delta = 0.05\n",
    "    alg_type = 'fixed_conf'\n",
    "    Gamma_hat = None\n",
    "    horizon = None\n",
    "    burn_in_sampling_method = None\n",
    "    burn_in_length = None\n",
    "    reuse_gamma = None\n",
    "\n",
    "    # oracle, our alg, static uniform, uniform w elimination, static xy, static g-optimal\n",
    "\n",
    "    # algorithm definition\n",
    "    workers = {}\n",
    "    algorithms = [('oracle', 'oracle-stop', 'oracle'), ('xy-optimal', 'oracle', 'oracle'), \n",
    "                   ('uniform', 'oracle', 'oracle'), ('uniform', 'oracle-stop', 'oracle'),\n",
    "                  ('xy-optimal', 'oracle-stop', 'oracle')]\n",
    "    # algorithms = [('oracle', 'oracle-stop', 'oracle')]\n",
    "    for algorithm in algorithms:\n",
    "        sampling_method = algorithm[0]\n",
    "        elimination_method = algorithm[1]\n",
    "        design_method = algorithm[2]\n",
    "        worker = Worker(W, Z, theta, Gamma, instance_type, sigma_x, sigma_y, \n",
    "                         sampling_method, elimination_method, design_method, \n",
    "                         delta, alg_type, burn_in_sampling_method, \n",
    "                         burn_in_length, horizon, reuse_gamma, algorithm)\n",
    "        workers[algorithm] = worker\n",
    "\n",
    "    # run algorithms\n",
    "    num_repeats = 5 \n",
    "    for algorithm in algorithms:\n",
    "        # workers[algorithm].run_individual(1)\n",
    "        workers[algorithm].run(num_repeats, aggregate=True)\n",
    "\n",
    "    for i, algorithm in enumerate(algorithms):\n",
    "        pickle.dump(workers[algorithm].save_results[algorithm], open('exp_2a_alg_'+str(i)+'eps_'+str(v)+'.p', 'wb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "worker_groups = []\n",
    "algorithms = [('oracle', 'oracle-stop', 'oracle'), ('xy-optimal', 'oracle', 'oracle'), \n",
    "               ('uniform', 'oracle', 'oracle'),('uniform', 'oracle-stop', 'oracle'),\n",
    "              ('xy-optimal', 'oracle-stop', 'oracle')]\n",
    "\n",
    "algorithms = [('oracle', 'oracle-stop', 'oracle'), ('xy-optimal', 'oracle', 'oracle'), \n",
    "               ('uniform', 'oracle', 'oracle'),('uniform', 'oracle-stop', 'oracle'),\n",
    "              ('xy-optimal', 'oracle-stop', 'oracle')]\n",
    "\n",
    "for i, algorithm in enumerate(algorithms):\n",
    "    workers_l = []\n",
    "    for v, eps in enumerate(eps_vals):\n",
    "        workers_l.append(pickle.load(open('exp_2a_alg_'+str(i)+'eps_'+str(v)+'.p', 'rb')))\n",
    "    worker_groups.append(workers_l)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "save = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 [ 94592. 116780. 147800. 193043.]\n",
      "1 [389903. 481362. 609224. 795720.]\n",
      "2 [2556906. 3156674. 3995164. 5218174.]\n",
      "3 [ 683656.  844018. 1068209. 1395212.]\n",
      "4 [ 683928.  844356. 1068638. 1395771.]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsQAAAGkCAYAAAA2STNEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAABgJ0lEQVR4nO3dd3xUZb4/8M+ZPpnJpHdCiEiTIAqKBAvBflkEsV5X/YnYtqirLpbdFVnRq6u76i7q3asr1+66cu24a1kFVAgtWAgltCQkIaS36eWc3x9TksnMJJNkJpNkPu/Xi1cy55w58x3MIR+fec73ESRJkkBEREREFKdksS6AiIiIiCiWGIiJiIiIKK4xEBMRERFRXGMgJiIiIqK4xkBMRERERHGNgZiIiIiI4tqYDMRGoxGLFi1CbW1tn8cdOXIE119/PRYvXoybbroJHR0dw1QhEREREY0UYy4Q//DDD7jmmmtQVVXV53GSJOHnP/85brnlFnz00UeYNm0aXnzxxeEpkoiIiIhGDEWsC4i0d955B6tWrcJ9993n2/bBBx/g1VdfhSiKmD59OlatWoWDBw8iISEB55xzDgDgZz/7GTo7O2NVNhERERHFiDBWV6o799xz8dprr8FisWDVqlV4+eWXoVar8dRTT0Gr1WLChAl4//33kZqair1792Ly5MlYuXIlkpOTY106EREREQ2jMTdlordt27ahuroaV111FZYsWYIvv/wSR44cgdPpxPbt23Hdddfh448/Rn5+Pv7whz/EulwiIiIiGmZjbspEby6XC//xH/+BBx98EABgMpngcrmwZ88eFBQUYMaMGQCARYsW4c4774xlqUREREQUA2N+hPiMM87AF198gZaWFkiShN///vd49dVXceqpp6K1tRX79+8HAHz11VeYPn16jKslIiIiouE25keIp06dittvvx033HADRFHEtGnTcOutt0KtVuP555/Hgw8+CIvFguzsbDz55JOxLpeIiIiIhtmYvamOiIiIiCgcY37KBBERERFRX8bMlAlRFGEymaBUKiEIQqzLISIiIqIRQpIkOBwO6HQ6yGSB48FjJhCbTCYcOHAg1mUQERER0Qg1efJkJCYmBmwfM4FYqVQCcL9RlUo1bK9bXl6OoqKiYXs9opGO1wRRIF4XRP6G+5qw2+04cOCALy/2NmYCsXeahEqlglqtHtbX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27VrFyorKzFjxoyIFEdEREREFG0hA/EVV1wBQRCwcuVKNDc393uitrY2PPDAAxAEAUuXLo1okURERERE0RIyEE+cOBG33norqqqqcPnll+Pvf/872tvbA45rbW3F22+/jUsuuQRHjx7FJZdcgpKSkiiWTEREREQUOX2uVHfnnXeitbUV77zzDlavXo1HHnkEeXl5SEtLg9PpRGtrK+rr6wEAkiThkksuwWOPPTYshRMRERERRUKfgVgmk2H16tVYsGABXnnlFezYsQM1NTWoqanxHaNSqTB37lzceOONKC4ujnrBRERERESR1Gcg9lqwYAEWLFiA1tZWVFZWoqmpCQqFAhkZGTjxxBOh0+miXScRERERUVSEFYi9UlNTkZqaGq1aiIiIiIiGXfjL0BERERERjUEMxEREREQU1xiIiYiIiCiuMRATERERUVxjICYiIiKiuMZATERERERxbUBt17waGxuxc+dOHD9+HOPHj8f555+P3bt3Y+rUqVAqlZGukYiIiIgoagYUiDs7O7F69Wr861//giiKAIBLLrkE559/Pv7rv/4LdXV1WLNmDU499dSoFEtEREREFGlhT5kwmUy4/vrrsX79eqSnp2PRokWQJMm3X6fToampCcuXL0d1dXVUiiUiIiIiirSwA/Hf/vY3VFRU4Oqrr8YXX3yBP/7xj377165di9tvvx0WiwUvvPBCxAslIiIiIoqGsAPxv/71L+Tm5uKhhx6CSqUKesztt9+OgoIClJWVRaxAIiIiIqJoCjsQ19fXY8aMGZDL5X0eN2XKFBw/fnzIhRERERERDYewA7FOpwsr6NbV1UGn0w2pKCIiIiKi4RJ2IJ41axbKy8vx/fffhzxm586d2Lt3L7tMEBEREdGoEXYgvvXWW31f33zzTRw8eBAAIEkSGhoasG7dOtx+++0QBAE33nhjdKolIiIiIoqwsPsQz5w5E4888ghWrVqFRx99FAAgCALWr1+P9evX+x7ff//9OO2006JTLRERERFRhA1oYY7LLrsMM2fOxKuvvort27fj+PHjcLlcyMjIwOmnn47rr78eRUVF0aqViIiIiCjiBrx088SJE7F69eqIF/LNN9/gr3/9K/bs2QOZTIaZM2firrvuwimnnBLx1yIiIiIi8gp7DnE0bd++Hbfccgu6urpw991345e//CWOHj2K6667Dj/++GOsyyMiIiKiMSzkCPHy5csHfVJBELB27dqwj3/ssceQk5ODd955B1qtFgBw6aWXYuHChXjmmWfw8ssvD7oWIiIiIqK+hAzEW7ZsGfRJBUEI+9iOjg7s378fN954oy8MA0B6ejpOP/10bN68edB1EBERERH1J2Qgfu2114alAL1ej08//dQvDHu1tbX1uzIeEREREdFQhAzEc+bMGZYC5HI5JkyYELB9//792LVrF84666xhqYOIiIiI4tOAu0wAQENDA3bs2IHGxkbIZDLk5OSguLgYBoMhIkWZTCbcf//9ALoXBCEiIiIiigZBkiQp3INra2vx6KOPYtOmTQH75HI5lixZgvvuuw9JSUmDLshiseC2227Dtm3bcNttt+Gee+4J63k2mw3l5eWDfl0iIiIiGtuKioqgVqsDtoc9QtzQ0IDrr78e9fX1SE9Px9lnn43s7GxIkoRjx45h8+bNePfdd7Fv3z688cYbSEhIGHCRnZ2duO2227Br1y5cfvnluPvuuwd8jlBvNFrKysowe/bsYXs9opGO1wRRIF4XRP6G+5rob+A07ED8/PPPo76+HldddRUefPBBqFQqv/12ux2rVq3CBx98gLVr1+KOO+4YUKEtLS246aabsG/fPlx99dV4+OGHB9StgoiIiIhoMMJemOPrr79GQUEBHn744YAwDAAqlQqPPPIIcnNzsX79+gEVYTQafWF42bJlWL16NcMwEREREQ2LsANxe3s7pk6d2mdQVSgUmDFjBhoaGgZUxOrVq7Fv3z78v//3//Cb3/xmQM8lIiIiIhqKsKdMnHjiiSgvL4fT6YRCEfpphw8fRmFhYdgFHD58GB9++CEMBgOmTZuGDz/8MOCYJUuWhH0+IiIiIqKBCDsQ33333bj11lvxm9/8Bo8++mjQG9f+/Oc/49ChQ3j22WfDLmD79u0A3DfUhRodZiAmIiIiomgJOxAfPnwYZ511FtavX4/S0lIsWLAA48ePh1wuR0NDA7755htUVlYiKysLmzZt8mvNJggCVq9eHfS811xzDa655pqhvxMiIiIiokEIOxA/9thjEAQBkiShubkZ69atC3rc8ePHA/b1FYiJiIiIiGIp7ED8+OOPR7MOIiIiIqKYCDsQL126NJp1EBERERHFRNht14iIiIiIxqKwR4gB4MCBA3j33XdRXV0Nu90e8jhBELB27dohF0dEREREFG1hB+KdO3di2bJlcLlckCSpz2O5yhwRERERjRZhB+Knn34aTqcTixYtwsUXX4zExEQGXyIiIiIa9cIOxBUVFTjppJPwpz/9KZr1EBERERENq7BvqtNqtcjKyopmLUREREREwy7sQHzuuefihx9+gNFojGY9RERERETDKuxA/Otf/xpJSUm45ZZbsHPnTgZjIiIiIhoTwp5DnJSUhMWLF+Mvf/kLrr/+egCAXC4PeXx5efnQqyMiIiIiirKwA/Hrr7+ONWvWAICv7ZrT6YxOVUREREREwyTsQPzGG29AJpPhN7/5DRYuXIjU1NRo1kVERERENCzCDsT19fWYO3currvuumjWQ0REREQ0rMK+qS4nJyeadRARERERxUTYgfjyyy/Htm3bUFFREc16iIiIiIiGVdhTJq6//nqUlZXhuuuuw9VXX42ZM2ciKSkJCkXwU8yaNStiRRIRERERRUvYgdgbcCVJwtq1a/s8VhAE7N27d2iVERERERENg7AD8WmnnRbNOoiIiIiIYmJAfYiJiIiIiMaasG+qIyIiIiIai8IeIfZqbGxEfX09HA6Hb8U6ABBFETabDc3NzdiwYQOeffbZiBZKRERERBQNYQdiu92OFStW4IsvvohmPUREREREwyrsKRNr167F559/DrlcjunTpyM3NxcAcMYZZ2DatGmQy+WQJAmFhYUcHSYiIiKiUSPsQPzpp59CJpPhrbfewv/93//h7rvvBgA88MADeO+997BhwwaceuqpOHr0KDIzM6NWMBERERFRJIUdiI8ePYqZM2fi5JNPBgCcfPLJkCQJu3btAgBkZGTgz3/+MwRBwEsvvRSdaomIiIiIIizsOcROpxNZWVm+x+PGjYNCocCBAwd827KysjBr1ix89913ka2SiIiIiEYVh92B9mOtaDvWjPaGNnQ2G9HVboHF6kTGiQnA7FhX2C3sQJyRkYGWlhbfY5lMhry8PL9ADABJSUloa2uLXIVERERENGI4nS50HG9DW22TJ+h2obPdAqPRDpPFBYtDBouogEOmDvJsJQAlHHtGVlYMOxCfeuqp+PTTT1FeXo6ioiIAwJQpU7Bx40a0trYiNTUVoihi3759SE1NjVrBRERERBR5LpeIrsZ2tNY2of24N+iaYeyywWQRYbYDFlEBu6AGBKHXsxXwi5UyQJBEqEQrtIIDWqUEnVYG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flhrIoqEofxs/+IXv0BnZydef/11rF+/HgCwYMEC3HzzzXjqqafYdo1GpcFeE52dnVi7di2Kiorwyiuv+P6H8Cc/+QmuuOIKrFy5EmeddRZbdNKoE4kMtG3bNpjNZlx88cWRL7AfHCGOoNzcXADB50Q2NjbCYDD4fmCIRpOh/GzLZDL89re/xTfffIM333wTX331Ff7nf/4HJpMJcrl82EcBiCJhsNdEVVUV7HY7Fi1a5PfpiFKpxCWXXILm5mYu0EGjUiQy0KZNm6BSqVBSUhKNEvvEEeIIMhgMGDduXNA7Kffu3YuioqIYVEU0dEP52V6/fj0yMjJwxhlnID093bd9x44dmD59um9uGdFoMthrwjvy63K5AvaJouj3lWg0iUQG2rVrF4qKimLyaTpHiCPswgsvRGlpKQ4fPuzbtmXLFlRWVg6oYwXRSDPYn+1XXnkFjzzyCJxOp2/bxo0bUVZWhmuvvTaqNRNF02CuiUmTJiEzMxPvv/++30fLNpsNH3zwAVJSUjBp0qSo104UDUPJQA6HA4cOHYrZjaVcujlM3gnePZdurqmpwa5duzBr1izk5+cDAFpbW30fhS1fvhw2mw0vvfQSxo8fj7fffpvzwmjUCudnO9g18dlnn+HOO+/EWWedhQsvvBB1dXV4+eWXMWfOHLz44ou8qY5GrcFeE1988QXuvPNOnHjiibjiiisgiiLeffddHDp0CE8++SQWL14c43dGNDiDvSYA4OjRo7jgggtw77334uabbx722jlCPAQ7duzAfffdhx07dvi2paam4o033sDUqVOxZs0avPrqqzj//PPx0ksvMQzTqBbOz3awa+Kiiy7C008/jebmZjz++OP45JNPcNNNN+G5555jGKZRbbDXxAUXXID//d//RXJyMp555hn85S9/gcFgwIsvvsgwTKPaYK8JoLs3fayaD3CEmIiIiIjiGkeIiYiIiCiuMRATERERUVxjICYiIiKiuMZATERERERxjYGYiIiIiOIaAzERERERxTUGYiIiIiKKawzERERERBTXGIiJiIiIKK4xEBMRERFRXGMgJiIiIqK4poh1AUREFDkOhwMff/wxPvroIxw5cgStra3Q6XTIysrC1KlTsXr1amg0mliXSUQ0ojAQExGNEWazGcuXL8d3332H5ORknHLKKdDr9ejo6EB1dTW2bNnCMExEFAQDMRHRGPHKK6/gu+++w9VXX40HH3wQKpXKb7/NZotRZUREIxvnEBMRjREVFRUAgFNOOSUgDAOAWq0e7pKIiEYFQZIkKdZFEBHR0H3wwQd44IEHIAgCTj31VOTm5kKhUOAXv/gFxo8fH+vyiIhGLAZiIqIx5LXXXsNTTz0Fq9Xq27Z9+3YkJSXFsCoiopGNgZiIaAxoa2vDihUrcPDgQdxzzz0488wzkZaWBpmMM+OIiPrDQExENAbceuut+Pbbb/Hxxx9j4sSJsS6HiGhU4dABEdEo19HRga+//hoZGRkMw0REg8BATEQ0BkiShOPHj+Pf//53wL7Ozk7s27cvBlUREY0OnDJBRDQG3H777fjiiy8AAFOnTsWECRPgcrnQ1NSEvXv34le/+hVuvvnmGFdJRDQyMRATEY0BNpsNr776Kj7//HMcOXIEVqsViYmJyM7OximnnIKbbrqJrdeIiEJgICYiIiKiuMY5xEREREQU1xiIiYiIiCiuMRATERERUVxjICYiIiKiuMZATERERERxjYGYiIiIiOIaAzERERERxTUGYiIiIiKKawzERERERBTXGIiJiIiIKK79fxxM5pQ08tiXAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "labels = ['Oracle', 'CPEG', 'SE', 'Uniform', 'Static-XY']\n",
    "line_plot(worker_groups, 'sample_complexity', labels=None,\n",
    "          xlabel=r'$\\epsilon$', save=save, save_name='plot2a_sc.png', xticklabels=[str(eps) for eps in eps_vals])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "d0788e5e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 683928.0, 'sample_complexity_ste': 0.0}, {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 844356.0, 'sample_complexity_ste': 0.0}, {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 1068638.0, 'sample_complexity_ste': 0.0}, {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 1395771.0, 'sample_complexity_ste': 0.0}]\n"
     ]
    }
   ],
   "source": [
    "print(workers_l)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# instance definition\n",
    "d = 4\n",
    "W = np.eye(d)\n",
    "Z = np.eye(d)\n",
    "a = .5\n",
    "b = .75\n",
    "eps = 0.99 # was 0.99\n",
    "theta = np.linspace(a, b, d)\n",
    "Gamma = (1-eps)*np.ones((d, d))/d + eps*np.eye(d) # noisy model\n",
    "# Gamma = (1-eps)*np.ones((d, d))/d + eps*np.array([[0, 1, 0, 0], [0, 0, 1, 0], [0, 0, 0, 1], [1, 0, 0, 0]]) # permutation model\n",
    "instance_type = 'compliance'\n",
    "sigma_x = None\n",
    "sigma_y = 0.15"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "# algorithm definition constants\n",
    "delta = 0.05\n",
    "alg_type = 'fixed_conf'\n",
    "Gamma_hat = None\n",
    "horizon = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "# algorithm definition\n",
    "workers = {}\n",
    "algorithms = [('xy-optimal', 'p-2sls', 'empirical', 'xy-optimal'), \n",
    "               ('xy-optimal', 'p-2sls', 'empirical', 'uniform'),\n",
    "              ('uniform', 'p-2sls', 'empirical', 'xy-optimal'),\n",
    "              ('uniform', 'p-2sls', 'empirical', 'uniform')]\n",
    "# algorithms = [('uniform', 'p-2sls', 'empirical', 'uniform')]\n",
    "for algorithm in algorithms:\n",
    "    sampling_method = algorithm[0]\n",
    "    elimination_method = algorithm[1]\n",
    "    design_method = algorithm[2]\n",
    "    burn_in_sampling_method = algorithm[3]\n",
    "    burn_in_length = 'adaptive'\n",
    "    reuse_gamma = True\n",
    "    \n",
    "    worker = Worker(W, Z, theta, Gamma, instance_type, sigma_x, sigma_y, \n",
    "                     sampling_method, elimination_method, design_method, \n",
    "                     delta, alg_type, burn_in_sampling_method, burn_in_length, horizon, reuse_gamma, algorithm)\n",
    "    workers[algorithm] = worker"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36m(PoolActor pid=4991)\u001b[0m 1 6035 [0.25424253 0.24635699 0.24539742 0.25400306] 8.154854490559767\n",
      "\u001b[36m(PoolActor pid=4987)\u001b[0m 5 1121355 [2.27354529e-05 1.88622276e-04 4.99794301e-01 4.99994341e-01] 4.082857771641537\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=5007)\u001b[0m 1 6037 [0.25071164 0.24845905 0.24958906 0.25124025] 8.157949342221936\u001b[32m [repeated 5x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=5010)\u001b[0m 2 28759 [0.25102406 0.24961762 0.24804593 0.2513124 ] 8.13925607313171\n",
      "\u001b[36m(PoolActor pid=5007)\u001b[0m 5 1121370 [1.07998400e-04 1.66566687e-05 4.99837652e-01 5.00037692e-01] 4.082913079297237\u001b[32m [repeated 18x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=5011)\u001b[0m 2 28959 [0.25362266 0.24631972 0.24626333 0.2537943 ] 8.195821122262746\n",
      "\u001b[36m(PoolActor pid=5026)\u001b[0m 1 6040 [0.25 0.25 0.25 0.25] 8.162432404856649\u001b[32m [repeated 5x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=5025)\u001b[0m 5 2241808 [0.25 0.25 0.25 0.25] 8.162432404856649\u001b[32m [repeated 20x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=5043)\u001b[0m 1 6040 [0.25 0.25 0.25 0.25] 8.162432404856649\u001b[32m [repeated 5x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=5041)\u001b[0m 5 2241808 [0.25 0.25 0.25 0.25] 8.162432404856649\u001b[32m [repeated 20x across cluster]\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "# run algorithms\n",
    "num_repeats = 5\n",
    "for algorithm in algorithms:\n",
    "    # workers[algorithm].run_individual(1)\n",
    "    workers[algorithm].run(num_repeats, aggregate=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i, algorithm in enumerate(algorithms):\n",
    "    pickle.dump(workers[algorithm].save_results[algorithm], open('exp_2b_alg_'+str(i)+'.p', 'wb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "save=True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "algorithms = [('xy-optimal', 'p-2sls', 'empirical', 'xy-optimal'), \n",
    "               ('xy-optimal', 'p-2sls', 'empirical', 'uniform'),\n",
    "              ('uniform', 'p-2sls', 'empirical', 'xy-optimal'),\n",
    "              ('uniform', 'p-2sls', 'empirical', 'uniform')]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "workers_l = dict()\n",
    "for i, algorithm in enumerate(algorithms):\n",
    "    workers_l[i] = pickle.load(open('exp_2b_alg_'+str(i)+'.p', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3S0OAAAAqAxsDsS/lpeXp5MnT+r69euqU6eO7r//flWrVs3etQEAAAAOV65AnJWVpT//+c9at26dzGaztb1GjRp6/PHH9dJLL6lWrVp2LxIAAABwFJsDcXZ2tgYPHqwTJ06oYcOG8vX1VYMGDXTlyhUdPHhQK1as0OHDh7V8+fJSV58AAAAA7jQ2B+IFCxboxIkTGj16tCZMmCBXV1frMYvForlz5+qDDz7QwoULNWHCBIcUCwAAANibzRtz/Pvf/5a/v78mT55cJAxLkslk0qRJk+Tv76+NGzfavUgAAADAUWwOxOfOnVNAQECZfQICAvTjjz/edlEAAABARbE5ENeuXVvp6ell9klLS5Onp+dtFwUAAABUFJsDcWhoqHbs2KEvv/yyxOO7du3Sjh07FBoaarfiAAAAAEez+aW68ePHa9u2bRozZox69+6toKAg1axZU+fPn9eBAwe0ZcsWubu7a9y4cY6sFwAAALArmwOxl5eXlixZopdfflmrV6/WmjVrJP2ywoQkNW3aVLNnz1azZs0cUigAAADgCOXamMPPz0+bNm3SwYMHlZycrOzsbHl4eMjHx0dBQUEymUyOqhMAAABwiHJv3VylShW1bdtWbdu2dUQ9AAAAQIW66Ut1Fy5c0Hvvvadjx44VO2axWNS1a1dNmzaN5dYAAABwVyozEH/33XcKCwvTP/7xjxJXlzh16pTOnTunTz/9VH379tW+ffscVigAAADgCKUG4nPnzmnEiBHKyclRdHS0+vbtW6xPs2bNtHv3bo0ZM0bZ2dmaMGGCzp8/78h6AQAAALsqNRAvXLhQOTk5mjt3rp5//nnVr1+/xH7169fX888/rz/96U/KysrS4sWLHVYsAAAAYG+lBuIvvvhC7du3V9euXW26UL9+/fTQQw9p586d9qoNAAAAcLgyp0w89NBD5bqYv78/L9cBAADgrlJqIPb09FRubm75Llalitzd3W+7KAAAAKCilBqIGzdurKSkpHJd7PDhw7rvvvtuuygAAACgopQaiHv27KkjR45o165dNl1ox44dSkpKUocOHexWHAAAAOBopQbi/v3765577tGkSZO0cePGMi+yfv16vfjii3J3d9eQIUPsXiQAAADgKKVu3Vy7dm3FxMRo1KhRmjx5subOnauHH35YXl5e8vDwUFZWlk6fPq2vvvpK6enpqlq1qt5/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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "labels = ['1', '2', '3', '4']\n",
    "bar_plot([workers_l[alg] for alg in workers_l], 'sample_complexity', labels=labels, save=save, xlabel='', save_name='plot2b_sc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "bar_plot([workers_l[alg] for alg in workers_l], 'accuracy', labels, save=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
