{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "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\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# instance definition\n",
    "theta = np.array([1, -0.95, .45, .45, .95, 0.45])\n",
    "# theta = np.array([1., 0.9, 0, 0.])\n",
    "d = len(theta)\n",
    "W = np.eye(d)\n",
    "Z = np.eye(d)\n",
    "eps = .8\n",
    "# Gamma = (1-eps)*np.ones((d, d))/d + eps*P\n",
    "Gamma =None\n",
    "instance_type = 'special_compliance'\n",
    "sigma_x = None\n",
    "sigma_y = .275"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# algorithm definition constants\n",
    "delta = 0.05\n",
    "alg_type = 'fixed_conf'\n",
    "horizon = None\n",
    "burn_in_sampling_method = None\n",
    "burn_in_length = None\n",
    "reuse_gamma = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# oracle, our alg, static uniform, uniform w elimination, static xy, static g-optimal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 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",
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-10-18 13:42:11,143\tINFO worker.py:1749 -- Started a local Ray instance.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36m(PoolActor pid=4026)\u001b[0m 1 686125 [0.46428956 0.01767344 0.00226924 0.01788284 0.48100709 0.01687784] 1995.2451985321895\n",
      "\u001b[36m(PoolActor pid=4054)\u001b[0m 3 206479 [0.49166667 0.00416667 0.00416667 0.00416667 0.49166667 0.00416667] 5.6993748871234935\u001b[32m [repeated 54x across cluster] (Ray deduplicates logs by default. Set RAY_DEDUP_LOGS=0 to disable log deduplication, or see https://docs.ray.io/en/master/ray-observability/user-guides/configure-logging.html#log-deduplication for more options.)\u001b[0m\n",
      "\u001b[36m(PoolActor pid=4062)\u001b[0m 3 543590 [0.16666667 0.16666667 0.16666667 0.16666667 0.16666667 0.16666667] 15.004579987056776\u001b[32m [repeated 24x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=4071)\u001b[0m 1 25976 [0.15610127 0.17159793 0.17196674 0.17130079 0.17001945 0.15901381] 14.636162951698164\u001b[32m [repeated 22x across cluster]\u001b[0m\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[36m(raylet)\u001b[0m Spilled 2155 MiB, 4 objects, write throughput 1236 MiB/s. Set RAY_verbose_spill_logs=0 to disable this message.\n"
     ]
    }
   ],
   "source": [
    "# run algorithms\n",
    "num_repeats = 5\n",
    "for algorithm in algorithms:\n",
    "    workers[algorithm].run(num_repeats, aggregate=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i, algorithm in enumerate(algorithms):\n",
    "    pickle.dump(workers[algorithm].save_results[algorithm], open('exp_1a_alg_'+str(i)+'.p', 'wb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "save = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "algorithms = [('oracle', 'oracle-stop', 'oracle'), ('xy-optimal', 'oracle', 'oracle'), \n",
    "               ('uniform', 'oracle', 'oracle'),('uniform', 'oracle-stop', 'oracle'),\n",
    "              ('xy-optimal', 'oracle-stop', 'oracle')]\n",
    "workers_l = dict()\n",
    "for i, algorithm in enumerate(algorithms):\n",
    "    workers_l[i] = pickle.load(open('exp_1a_alg_'+str(i)+'.p', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels = ['Oracle', 'CPEG', 'Uniform-Elim', 'Uniform', 'Static-XY']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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], 'sample_complexity', labels, save=save, save_name='plot1a_sc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bar_plot([workers_l[alg] for alg in workers_l], 'accuracy', labels, save=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "78a81010",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0: {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 4680458.6, 'sample_complexity_ste': 1199.3150578559414}, 1: {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 5392566.8, 'sample_complexity_ste': 2438.732447809722}, 2: {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 11504896.0, 'sample_complexity_ste': 13745.99586497828}, 3: {'accuracy_mean': 1.0, 'accuracy_ste': 0.0, 'sample_complexity_mean': 12225791.6, 'sample_complexity_ste': 12015.36100364862}}\n"
     ]
    }
   ],
   "source": [
    "print(workers_l)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# instance definition\n",
    "theta = np.array([1, -0.95, .45, .45, .9, 0.45])\n",
    "d = len(theta)\n",
    "W = np.eye(d)\n",
    "Z = np.eye(d)\n",
    "Gamma = None\n",
    "instance_type = 'special_compliance'\n",
    "sigma_x = None\n",
    "sigma_y = 0.275"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# algorithm definition\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",
    "workers = {}\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": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36m(PoolActor pid=4153)\u001b[0m 1 25270 [0.16627676 0.17092383 0.16114682 0.17020205 0.17095342 0.16049711] 14.627036350428469\n",
      "\u001b[36m(PoolActor pid=4150)\u001b[0m 2 98301 [0.17331175 0.00811335 0.20967136 0.20983373 0.20362441 0.1954454 ] 12.116504526342027\n",
      "\u001b[36m(PoolActor pid=4164)\u001b[0m 1 25304 [0.166068   0.17068852 0.1615425  0.16977582 0.17101797 0.16090719] 14.646838094642655\u001b[32m [repeated 38x across cluster]\u001b[0m\n",
      "\u001b[36m(PoolActor pid=4160)\u001b[0m 1 25419 [0.15560169 0.16826516 0.16932127 0.17095006 0.17340181 0.16246   ] 14.7134303673301\n",
      "\u001b[36m(PoolActor pid=4178)\u001b[0m 1 26017 [0.16666667 0.16666667 0.16666667 0.16666667 0.16666667 0.16666667] 15.059827594445165\u001b[32m [repeated 39x across cluster]\u001b[0m\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[36m(raylet)\u001b[0m Spilled 5032 MiB, 9 objects, write throughput 1258 MiB/s.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36m(PoolActor pid=4195)\u001b[0m 2 122511 [0.16666667 0.16666667 0.16666667 0.16666667 0.16666667 0.16666667] 15.100653803684239\u001b[32m [repeated 26x across cluster]\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "# run algorithms\n",
    "num_repeats = 5\n",
    "for algorithm in algorithms:\n",
    "#     print(algorithm)\n",
    "    workers[algorithm].run(num_repeats, aggregate=True)\n",
    "#     result = workers[algorithm].run_individual(1)\n",
    "#     print(result.T, result.accuracy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i, algorithm in enumerate(algorithms):\n",
    "    pickle.dump(workers[algorithm].save_results[algorithm], open('exp_1b_alg_'+str(i)+'.p', 'wb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "save=True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "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": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "workers_l = dict()\n",
    "for i, algorithm in enumerate(algorithms):\n",
    "    workers_l[i] = pickle.load(open('exp_1b_alg_'+str(i)+'.p', 'rb'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": [
    "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='plot1b_sc.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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agRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZGIAYAAICpEYgBAABgagRiAAAAmBqBGAAAAKZ2UwTiFStWKDY2VmFhYRo0aJD27t1bY//s7GyNGjVK4eHh6tGjhxYsWCCbzeakagEAAFCXuDwQp6WlaebMmYqLi1NycrJ8fX01duxY5eXlVdn/+++/1+jRo2WxWPTmm28qPj5eb775phYvXuzkygEAAFAXuLtycJvNpuTkZMXHx2vixImSpO7du6t3795aunSppk+fXumeZcuW6cqVK5o/f768vLwUHR2tkpISLViwQCNHjpSHh4ezPwYAAABuYS59Q5yTk6P8/Hz17NmzvM3Dw0M9evTQrl27qrwnIyNDkZGR8vLyKm/r1auXzp07p6ysLMNrBgAAQN3i0jfEx48flyS1adOmQntAQIByc3NVWloqNze3Svd07dq1Uv+r1yIiIq457tX1xiUlJddb+nW7vaHbtTvhllZcXOzaAryau3Z8GM/Fc8zfw9+l48N4rv47VubPHKvrnD3Hrma+6r5z5tJAXFhYKEny9vau0O7t7a2ysjJdunRJPj4+le6pqv9Pn3ctVqtV0o9fznO2t/vd7vQx4VwHDhxwbQG9lrt2fBjPxXPsL0F/cen4MJ7L/47NfdO148NwrppjVqtVDRo0qNTu8jXEkmSxWKq8Xl17derVs28FiLe3t+655x55eHjUegwAAADcWmw2m6xWa6WXqle5NBD7+vpKkoqKiuT/k/97pKioSG5ublUW7ePjo6KiogptV3/++dvk6tSrV698bAAAANR9Vb0ZvsqlX6q7unb451us5eXlKTAwsMp7AgMDdeLEiUr9Jalt27aOLxIAAAB1mksDcWBgoFq2bKn09PTyNqvVqh07digyMrLKe7p166aMjAxdvHixvC09PV2NGzdW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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "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
}
