{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "68fe38ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from matplotlib.pyplot import figure\n",
    "import matplotlib\n",
    "\n",
    "\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3835ef88",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'UNCERTAINTY_DETERMINISTIC_128'"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "file_name = 'data/lambda_0_det_vs_prob.csv'\n",
    "df = pd.read_csv(file_name)\n",
    "sns.set(font_scale=0.5)  # crazy big\n",
    "\n",
    "# Some keys\n",
    "GATE_SELECTION_MODE  = 'gate_selection_mode'\n",
    "GATE_TYPE  = 'gate'\n",
    "PROJ_DIM = 'proj_dim'\n",
    "def build_plot_label(df_line):\n",
    "\n",
    "    def get_value_without_key(s):\n",
    "        return s.split('.')[-1]\n",
    "    return f\"{get_value_without_key(df_line[GATE_TYPE])}_{get_value_without_key(df_line[GATE_SELECTION_MODE])}_{df_line[PROJ_DIM]}\"\n",
    "\n",
    "\n",
    "build_plot_label(df.iloc[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "76a90c25",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 16 artists>"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA0sAAAJHCAYAAABB8c25AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACGJ0lEQVR4nO3dd3RU5fr28WuSEAiEUAMoiCBVBVEpRxQbYgOlidKkqBQbgigewaNg+WEBbFhBiqCAioANEUGaFAEPiDTp0nsJoYUk+/0jb+YQMikMyex9x+9nrbPOZM9k5mJ89mTup22f4ziOAAAAAABphLkdAAAAAAC8iGIJAAAAAAKgWAIAAACAACiWAAAAACAAiiUAAAAACIBiCQAAAAACoFgCAAAAgAAolgAAAAAgAIolAAAAAAggwu0AoeQ4jpKTHbdj5KiwMJ+pf5O1vJK9zNbySmQOBWt5JXuZreWV7GW2llcicyhYyyvZy2wtb3aEhfnk8/myfNw/qlhKTnZ08OAxt2PkmIiIMBUrVkhxcceVmJjsdpwsWcsr2ctsLa9E5lCwlleyl9laXsleZmt5JTKHgrW8kr3M1vJmV/HihRQennWxxDQ8AAAAAAiAYgkAAAAAAqBYAgAAAIAAKJYAAAAAIACKJQAAAAAIgGIJAAAAAAKgWAIAAACAACiWAAAAACAAiiUAAAAACIBiCQAAAAACoFgCAAAAgAAolgAAAAAgAIolAAAAAAiAYgkAAAAAAqBYAgAAAIAAItwOAAAAACB3hIX5FBbmC/r3w8PD0vz/+UhOdpSc7Jz384QSxRIAAACQB4WF+VSkaEFF5EChExMTdd7PkZiUrCOHj5sqmCiWAAAAgGw431EaKbQjNWFhPkWEh6nnhGXasDf+vF/vfFQuFa132lylsDAfxRIAAACQl4SF+VSsaEGF5UCRI+XMSE1yUrIOZWOkZsPeeK3aGXfer/dPRLEEAACAkLM4ShMWHqafR67SwV3Hzvv1zlfxCwrp1gcvNzdSYw3FEgAAAEIqJ9fSSKFdT3Nw1zHt3+bulDaEjueKpZMnT+rxxx/X8ePHVatWLT3yyCPq3bu34uPj1atXL11zzTVuRwQAAMB58NJaGsnuehrkPs8VS4sWLVK9evXUrVs3PfLII5owYYLuv/9+1atXT0888QTFEgAAQABemtaW3S2iWUsDr/NcsVSuXDn98ccfchxHycnJWrlypTp27KgCBQooX758SkxMVESE52IDAIA8xEuFh5S99TRe2nwguxsPAF7nuaqjbNmyWrx4se644w41atRI69atU4ECBSRJhQoVUnx8vIoWLRr080dE5MyHiBfk5IdwKFjLK9nLbC2vROZQsJZXspfZWl4p9Jl9vvMrPlJ/N1++8BwZ9XCcjL/E+3w+xRQu4JnCQ0opPuKOnswwd3h4mGc2H0jdeCBfvnAlJSUHfIxXz5XMcpE5Z3gxU2Y8VyxNnjxZzZo107333quePXsqMTFRJ0+eVIECBXTs2DFFR0cH/dxhYT4VK1YoB9N6Q058CIeStbySvczW8kpkDgVreSV7ma3llUKXOTnZOe+RGkmKji4QsixeKDyk/xUfRYsWzPKxXtp8gPMhNKxltpbXc8WS4ziKiYmRz+dTdHS0atSood9++0316tXT6dOnz2sKXnKyo7i44zmY1l3h4WGKiYlSXNyJDHtuvMRaXsleZmt5JTKHgrW8kr3M1vJKoc2c+lpeKD5SC4/M/t2peb1UeEjKVmYvsZZXInMoeOVzMiYmKlujXJ4rlpo0aaJevXpp7Nixqlixolq3bq3evXvrww8/VM+ePc/7+RMT3f+Pk9OSkpJN/bus5ZXsZbaWVyJzKIQqb06s9chJ2bp2iqG8ks3MkrdGPaydv5K9zNbySmQOBWt5PVcsFS1aVKNHj05zbMSIEe6EAQCck5RF5lEKCw/PkefLmbUeSTp0+ETAL/MWr/ViMTMAWOW5YgkAYFfKFe7DtePpPkrYtMntOIq85BKVHTwow2unWLzWi8XMAGAVxRIAIMclbNqkk6tXux0j2yxe68ViZgCwxtbefQAAAAAQIhRLAAAAABAAxRIAAAAABECxBAAAAAABsMEDgH+UnLg+TepF7LJzMbvMhOp6OjmVV8r+9XQAAMgLKJYA/GN47fo0XE8HAABvo1gC8I/hpevTcD0dAAC8j2IJwD+OtevTWMsLAEBewQYPAAAAABAAxRIAAAAABECxBAAAAAABUCwBAAAAQAAUSwAAAAAQAMUSAAAAAATA1uEAghYW5lNYmO+8niP8/19wNTwHLryanOxw/R8AAJBjKJYABCUszKdiRaMUFh6eI88XExN13s+RnJSkQ4dPUDABAIAcQbEEIChhYT6FhYdrx9N9lLBpk9txFHnJJSo7eJDCwnwUSwAAIEdQLAE4LwmbNunk6tVuxwAAAMhxbPAAAAAAAAFQLAEAAABAAEzDAzzkfHeXY2c5AACAnEOxBHhETu4ux85yAAAA549iCfAIL+0ux85yAAAAFEvIw6xeMJXd5QAAALyBYgl5EhdMBQAAwPmiWEKe5KUpbRLT2gAAACyiWEKexpQ2AAAABItiCdlidf0PAAAAECyKJWSJ9T8AAAD4J6JYQpZY/wMAAIB/IoolZBvrfwAAAPBPcv6LRwAAAAAgD2JkySVe2jCBzRIAAACA9CiWXOC1DRPYLAEAAABIj2LJBV7aMIHNEgAAAIDAPFcsLV68WEOHDpUkrVu3TsOHD9fIkSO1e/dutWvXTk2bNnU5Yc5hwwQAAADAuzy3wUO9evU0duxYjR07VhdffLG2b9+uunXraty4cZo0aZKSkpLcjggAAADgH8BzI0up1qxZo2rVqunPP/9Uq1atFBYWpkqVKmnnzp266KKLgn7eiAj368Pz3ZAhN2SWyYt5JTKHgrW8kr3M1vJKeSuztbxZ3ecma5mt5ZXsZbaWVyJzKHgxU2Y8Wyz98ssvatiwoWbOnKno6GhJUnR0tOLi4oJ+zrAwn4oVK5RTEfOU890kwg1kzn3W8kr2MlvLK5E5FKzllexltpZXspfZWl6JzKFgLa9ni6VFixapS5cuWrx4seLj41W6dGkdO3ZMMTExQT9ncrKjuLjjOZgyOOHhYZ5rKHFxJ5SUlBzwPi/mlcgcCtbySvYyW8sr5a3M1vJKZM4p1vJK9jJbyyuRORQyyxtKMTFR2Rrl8mSxtHfvXhUpUkT58+dXzZo1tWjRIlWsWFEbN27UhRdeeF7PnZjo/n8cL0pKSjb33pA591nLK9nLbC2vROZQsJZXspfZWl7JXmZreSUyh4K1vJ6cNDh79mzddNNNkqRGjRpp8eLFateunZo3b67wHLo2EQAAAABkxpMjS/fdd5//dmRkpN555x0X0wAAAAD4J/LkyBIAAAAAuI1iCQAAAAACoFgCAAAAgAAolgAAAAAgAIolAAAAAAiAYgkAAAAAAqBYAgAAAIAAKJYAAAAAIACKJQAAAAAIgGIJAAAAAAKgWAIAAACAACiWAAAAACAAiiUAAAAACIBiCQAAAAACoFgCAAAAgAAolgAAAAAggIicfLLExER99dVXWr9+vcqUKaPWrVurSJEiOfkSAAAAABASQRVL7733nt5//32NGTNGdevWlSQlJyerQ4cOWr58uRzHkc/n01dffaWvv/5aMTExORoaAAAAAHJbUNPwFixYoDJlyvgLJUmaNm2ali1bpqpVq+qll17SLbfcom3btunzzz/PsbAAAAAAECpBFUvbtm3TJZdckubYzz//LJ/PpzfffFP33Xefhg4dqgsuuEA//fRTjgQFAAAAgFAKqlg6fPiwihUrlubYkiVLdPHFF6tSpUqSJJ/Pp5o1a2rXrl3nnxIAAAAAQiyoYqlYsWLas2eP/+cNGzZo//79qlevXprH5cuXTwkJCeeXEAAAAABcEFSxVKlSJS1btkyrV6+WJI0aNUo+n0833nhjmsft2LFDpUqVOv+UAAAAABBiQe2G17lzZy1cuFCtWrVS4cKFFRcXp3Llyun666/3P+bo0aNauXKlGjZsmGNhAQAAACBUghpZuvHGG/X888+rdOnSOnXqlK6++mq99957ioyM9D9mypQpSkxMVP369XMsLAAAAACEStAXpW3fvr3at2+f4f333nuvmjdvroIFCwb7EgAAAADgmqBGlpYsWaLNmzdn+pgCBQrowIED+u9//xtUMAAAAABwU1DFUocOHTR8+PAsH/fJJ5+oY8eOwbwEAAAAALgqqGJJkhzHyZHHAAAAAIAXBV0sZcfevXtZswQAAADApGxv8DBlypQ0P2/dujXdsVSJiYnavHmzFi5cqFq1ap1PPgAAAABwRbaLpWeffVY+n0+S5PP59N///jfTzRscx1H+/Pn12GOPnX9KAAAAAAixbBdLjz32mHw+nxzH0fvvv69LL71Ut9xyS8DH5suXT6VKldJ1112nUqVK5VhYAAAAAAiVbBdLPXr08N+ePHmy6tevr8cffzxXQgEAAACA24K6KO0vv/yS0zkAAAAAwFNydTc8AAAAALAqWyNLffv2lc/nU+/evVWyZEn17ds32y/g8/k0cODAoAMCAAAAgBuyVSxNnjxZPp9PXbt2VcmSJTV58uRsv0AwxdKECRM0bdo0JSUlacSIEXrmmWe0e/dutWvXTk2bNj2n5wIAAACAYGSrWBozZowk6cILL0zzc27YuXOnNm7cqNGjR0uSpk6dqrp166pt27Z68MEH1aRJE4WHh+fa6wMAAACAlM1iqV69epn+nJPmz5+v+Ph4dezYUddee62OHDmi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3bp1U9OmTfXaa6/pmWee0Zdffqnnn39e1apVkyS99NJLevbZZ/Xuu+/K5/PJcRxJ0u23366+ffvmXnoAAAAAyCXZ3g2vTJkyevvtt7Vo0SK98soruueee9SmTRv17NlTRYsW1UcffaQtW7Zo06ZNkqQqVarooosuyrXgAAAAAJCbznnr8GuuuUbffPONxowZo/fff19Tp07V008/rZYtW6pChQpsEw4AAAAgTwhq6/Dw8HA98MAD+vHHH9WgQQM999xzatOmjVavXp3T+QAAAADAFedcLCUmJurQoUOSpNjYWL3xxhv67LPPdPLkSd17773q37+/jhw5kuNBAQAAACCUsl0sTZ06VXfffbdq1aqla6+9VldddZV69eqlrVu3qnbt2po0aZL69eunadOm6fbbb9cXX3yRm7kBAAAAIFdlq1gaN26cnnrqKR08eFD33HOPunTpomuvvVYzZszQvffeqz179igsLEzt27fXtGnT1KhRIw0YMECtWrXSihUrcvvfAAAAAAA5LlsbPIwcOVIXXHCBJk+erCJFiviPz5gxQ48//rgmTpyoxx57TJJUrFgxvfLKK7rvvvv00ksvsZYJAAAAgEnZKpb27Nmjm266KU2hJKXsjCdJe/fuTfc7V1xxhSZOnKivvvoqB2ICAAAAQGhlaxpelSpVtHDhwjRT6hzH0ahRo+Tz+VS5cuUMf/fee+89/5QAAAAAEGLZGll65pln1K1bN7Vu3VoVK1ZUTEyMtm/frv3796tatWpq1apVjgWaPXu2PvjgA0lS586d1aBBA/Xu3Vvx8fHq1auXfzQLAAAAAHJTtoqla665RlOnTtWIESO0du1axcXFqXr16rrxxhvVunVrRUZG5lig6tWra/z48XIcR507d9aOHTt0//33q169enriiScolgAAAACERLaKJUkqV66c+vfvn5tZJEllypSRlDLNLywsTH/++ac6dOigAgUKKF++fEpMTFRERLZjpxMREdR1eHNUeLj7Gc6WWSYv5pXIHArW8kr2MlvLK+WtzNbyZnWfm6xltpZXspfZWl6JzKHgxUyZCb7qyGWTJk1SgwYNtGTJEhUoUECSVKhQIcXHx6to0aJBPWdYmE/FihXKwZR5R0xMlNsRzhmZc5+1vJK9zNbySmQOBWt5JXuZreWV7GW2llcicyhYy+vJYmn9+vX6+eef9f77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HTt2pDm2du1al9Jk7ejRo0pISJAk7d27V1u2bHE30DlKTEz05/cqa+fdyZMnNWnSJE2ePFnHjh3zH58yZYp7oYIwcuRItyOcEwufb5Y+L/JKOwYsWrt2rXbu3ClJWrFihebPn6+kpCSXU4WezznzLz8875lnnlG5cuUUHh6uRYsWqX///qpcubI6duyoMWPGuB0vnVq1aunyyy9XoUKFJEmO42jVqlWqUaOGhg8f7nK6wN544w3t379fEREROnLkiF588UWVLFnSs+/xG2+8oS1btig5OVlVqlTR1q1bFR0drfDwcL300ktuxwto7Nix+umnn1SgQAE1atRIP/30k8LCwnT11VfrscceczteOtbOO0l65JFH1KhRI4WHh+vrr7/Wo48+qvr163s6c+PGjXXBBRcoLCylH8/rnxdWP98sfV5YbMcrVqxI87PjOHr11VfVr18/XXHFFS6lytj+/fs1btw4hYWFqUWLFipbtqwkafjw4eratavL6QI7cOBAumOvvPKK/vOf/6hEiRIuJMqatcx9+vRRkSJFdOzYMZ06dUqxsbEqUqSIVq9erffee8/teCEV4XYAnJtdu3b5ey7btm2r5557TnfeeafLqTL2xRdf6Msvv1R0dLTat2+v0qVLq0uXLp79IiGl/KH77LPPJEkbN27UM888o4cfftjlVBk7M+8dd9yhadOmSZI6dOjgZqxM/fDDD5owYYISEhLUpEkTf7HUtm1bTxZL1s47SYqLi9M999wjKaVdvPLKK1q+fLm83D/Wu3dvzZgxQzVr1lSrVq2UP39+T39eWP98s/B5YbEdP/roo6pcubLq1KnjP3bw4EHNnTvXk8VSnz591L17d0VERGjAgAFq3LixWrRooXnz5nm2WGrYsKGuuOIKlStXzn/s999/1+DBg/Xqq6+6mCxj1jLv3r1bgwYNkpTSkfXmm29K8u5nRW6iWDImPDxcBw4cUIkSJVS8eHG9//77GjJkSLqeLK+oXr26XnjhBe3atUuffvqp4uPj00yl8CLHcRQfH6/o6GhVqlRJ77//vl544QXPTsOLiorS8OHDdeLECZUsWVJfffWVihQpoogI757e+fLl09SpUxUfH6+oqCj99ttviomJ8Y8oeI21806SihYtql27dumCCy5QgQIF9Morr2jcuHH6448/3I6WoUaNGqlRo0ZatmyZXnrpJZUuXVqnTp1yO1aGLH6+Wfu8sNiOf/nlF33zzTdavHixbr75Zt1+++36448/9Pjjj7sdLaBTp07pmmuukSTVqVNH7733np5//nlPT42eOXOmxo8fr3379qlVq1a64oor1KVLF08WHamsZS5VqpQGDBig5ORkVa5cWW+//baKFCmimJgYt6OFHNPwjDlx4oQiIiKUL1++NMf37t2rUqVKuZQq++Li4rRlyxZP9q6l2rlzp2JiYhQdHZ3m+PLly3XllVe6EyoTp06d0qJFi1SuXDmVLVtWkydPVnJysu666y4VKVLE7XgB7d+/Xz/99JMuvvhiXXbZZRo5cqQcx1Hr1q1Vvnx5t+OlY/28s2rz5s3auHGjGjVq5HaUbLHw+Wbx88KyGTNm6Mcff9SmTZs0efJkt+MENGDAAHXv3l0XXHCB/9icOXP06quv+kceverEiRP66quv9Mcff2jbtm368ssv3Y6UJUuZN2zYoJIlSyomJka//vqrHMfRtddem+5vYV5HsWTMtm3b9MUXX6hKlSq67LLLNHToUBUoUEDdu3dXpUqV3I6XzpQpU9S8eXNt27ZN77zzjuLi4lSoUCE9/PDDqlatmtvxAoqLi9MPP/ygSy65RBUqVNDo0aOVP39+3X///SpZsqTb8QLavn27fD6ff665lLIws3r16i6mytzp06fl8/nS9Ginjt54jbXzTkqZbjVy5EhVq1ZNderU0bvvvqtChQqpa9euql27ttvxAvr111/VoEEDHT58WCNGjNDmzZtVrlw5PfDAAypdurTb8dKx+Pkm2fq8sNiOz5Y6UwG5JykpSQcOHDDVeWUh82+//Safz6e6devK5/NJ+t/n9D+KA1PatWvnLF261JkzZ45z6623Ohs2bHB27tzpdOzY0e1oAaXm6tKli7Nx40bHcRxnz549Ttu2bd2MlanOnTs733zzjfPll186d999tzN79mxn6dKlzkMPPeR2tIBef/1155lnnnH69u3rPProo86+ffscx3GcDh06uJwsY59++qnTsWNHp0uXLk7//v2dEydOOI7j3czWzjvHcZzWrVs7u3fvdjZs2ODcdNNNzv79+534+Hinffv2bkfLUOr7+fjjjzvz5893Tp065axYscKz77PFzzdrnxcW2/HAgQMdx3Gc2bNnO+3atXN69+7tdOjQwZkyZYrLyQKbNWuW06lT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6GiNGTNGP/30k6Kjo1W3bl116dLF7XjpWMsrSUeOHPFvPvDjjz9q1KhRyp8/v1q1aqVmzZq5HS8di4vMrS3kt9iOR40apRo1aig6OlqDBw/Wtm3bVLRoUUVGRuq5555zO15A1s49i+3C2ueFxXY8YMAA/9b3juPo119/VXJysq6//npPTmOylleyWURby2xtjVVuolgy5u+//1Z0dLQSExM1duxY/fjjj4qIiFD79u09+cfZWl5JWrJkiXr27CnHcfT2229r0qRJioqKUvv27T35hc3iInNrC/kttuPjx48rOjpap06d0vTp0zV9+nRJUocOHVxOljFr557FdmHt88JiO37hhRf0ySefKCoqSv369VPRokVVrFgxffvttxoyZIjb8dKxlleyWURby2xtjVVuolgyJikpSYcOHdKCBQt09dVXKyIiwn/ci6zllVKuLZCYmKjff/9d1apV8+wVzFNZXGRubSG/xXbs8/m0atUqLVq0SA0aNPAfP3XqlIupMmft3LPYLqx9Xlhsx2FhYYqKilJ8fLyWLVumadOmSZI6duzocrLArOWVbBbR1jJbW2OVmyiWjOnXr5/69++vAgUK+LdZ3rZtm6699lqXkwVmLa8kPfLII+revbsSExP1wgsvSErJ7NWhcouLzK0t5LfYjgcOHKjPP/9c+fPnV+/evSWlFKktW7Z0OVnGrJ17FtuFtc8Li+04f/78mj59upYuXarbb79dUsoXz5MnT7qcLDBreSWbRbS1zNbWWOUmn0PJCJj2/fff66677vL/bGGR+ejRo9W5c2e3Y+RpBw4cyPA+L051RGhY+7yw2I7j4uL07bffKn/+/GrevLny5cunXbt2adWqVWrUqJHb8dKxlldKKZhTi+guXbooOjpa27dv16+//qo2bdq4HS8ga5kXLVqka665xv+z19dY5SZGlow5cyvHM+tcn8/nya0creWVAm+Xmbr41YuZLS4yt7aQ31qbkKTBgwdneJ9XR/Wsvc/W8kr2Pi8stuMtW7b4pzSuWbPGf7xUqVJuRcqUtbySFBUV5W+vp06d0qlTpxQVFaVbb73V5WQZs5bZ2hqr3ESxZMwnn3zidoRzYi2vlHHmZcuWhThJ9lhcZG5tIX9GbeLnn38OcZLs8+oXycxYO/cstgtrnxcZtePx48eHOEn2ZbQmTPLmujBreSWbRbS1zNbW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LaCWLVuqUqVKatmyperVq6fu3bt7uk1I9noxJXvnnsV2ceY51rp1a33xxReSUnad+/TTT92MFtC1116rG2+8UY8++qguuugidenSxfPvcfXq1XXZZZepRo0a8vl8aToqvHg9HWt5JbudQZYKf4vrwnKL9+e7II1A6zni4+P13XffuZAma9bySlLNmjW1YsUKrVy5UrGxsUpOTnY7UqbYRCP3denSRfPmzdOXX36pzZs3KyEhwe1IWQq0/mTLli2aOHGiZ4sla+eexXZhbVOKDz/8UL/88osGDRqk8uXLe/Yz4kwzZ84MeNyrC/mt5ZUy3tXRy5kDFf61a9d2O1aGLG4SlFsYWTJm5syZGjdunBITE9WxY0ctWbJEmzZtUuPGjT05UmMt75kOHjyoOXPm+HeYq169ume3tpbYRCMUkpKS9Pvvv2vWrFnaunWrSpYsqRdffNHtWAFNmDBBP/74o06dOqUmTZpo+fLlioyMVIsWLTy5kP9M1s49S+3C4mh/qh07duiXX37R4sWLdfr0aX300UduR8rQ8ePHlZycrOjoaEkp16v5+uuvNWTIEJeTBWYtbyCpnUFPP/2021EC+uOPP/TLL79o8+bNKl++vJYuXaoJEya4HStLltaF5RaKJWPatGmjzz77TMePH9ett96qjz76yL91tBdZy5uRhIQELVq0yLNXDWcTjdBKSkrS6dOntWPHDlWqVMntOAG1bdtW48ePV0JCgm655RaNHz/esxc+zIzXz70zWWgXZ7OwKcWpU6cUFhamfPnyae/evYqPj1epUqX8X+y95u2339a6det04sQJVatWTZs3b1bNmjXVvHlzT56D1vJKtjuDJBuFf15YF5ZTmIZnTP78+RUREaGYmBhVrVrV84WHtbySNGPGDI0fP1758+fXXXfdpa+//loJCQlq1qyZ29ECOnMTjVtuuUWStHnzZm3evNncJhr/+te/3I4V0Lhx4/Tjjz8qIiJC1113nRYuXKiwsDBdeeWVeuyxx9yOF5DjODp48KCSk5NVtmxZRUVF+beC9eq2r9bOPYvtQgq8KUWPHj3cjhXQW2+9pdWrVys5OVnly5dXXFycfyrQSy+95HK6wH7//XeNHTtWycnJuu222zRp0iTFxMS4HStD1vJK0jfffGOyMyi18C9btqxuv/12XXfddSpVqpTbsQL617/+5V8XduGFF+rkyZP69ttvJXl7XVhuoFgyqGvXrnIcR2FhYf7bXl5wZy3vsGHD9Pnnn+v48eNq2rSpfv75Z+XLl09t27ZVq1at3I6XTq9evfy3z7xwnJfnbp+5kP/xxx/XM888o0ceecTtWBn69ttvNWHCBCUkJOiuu+7STz/9JJ/Pp/bt23v2S3HFihU1aNAg/+3Bgwf77/PqCIK1c89iuzhzU4rWrVure/fuatq0qduxMrR06VJ9/vnnSk5OVrNmzfzrXTt06OBysoyduSYzJiZGW7Zs8d/nxQuFW8sr2ewMslb4W1wXllsolozJaLcir15d2VpeSSpQoIDy5cunIkWKqHz58v5dary4W43EJhqhcGYbKF26tP+PRXh4uJuxMvXMM8+oWLFi6Y5v377dhTTZY+3cs9gurG1KkZSU5P9SXKhQIf/txMREt6NlqGHDhpo7d26625I3iw9reSWbnUHWCn+LmwTlFoolYx544AGNGjVKkvTUU0/5F1927drVk1suW8srpewWlToCdvDgwTS3vSizTTS8KnUIP3Uhf9GiRdW7d2/PLuT3+XxpRki7dOkiSWm2VPWanj17+s+xM7eL7tevH+deDrHYLho3bqzGjRv7N6W4/PLL9dhjj3l2U4qzvxSn3q5QoYKLqTJ3++23q0qVKpJS2nTqSMcff/zhZqwMWcsr2ewMslb4Z7Yu7J+GYsmYM0+qvXv3+m97dZ8Oa3kl6YcffnA7wjkZPny42U00ihcvrhYtWqhFixb+hfxelDpCmpSUpEOHDql48eKe/kIspT3HvHy+ncnauWexXaQKDw9XvXr1VLt2bf+mFF6UOkqwY8cO7d+/X7GxsZ694G+ql19+2d8h8eSTT/pvDxkyxJMdFdbySjY7g6wV/lbXheUGiiVjzpxbfPZtL7KWV0rZJnPo0KFav369wsLClJycrMqVK6tHjx6evMYAm2jkvv3792vgwIE6fvy4ihcvroMHDyoqKkr9+vVTbGys2/ECOnjwoP8aOmff9ipr557FdmFtU4rNmzfrlVdeUbly5RQbG6u9e/dq+/bt+s9//qNLLrnE7XhwicXOIGuFv8V1YbmFrcONsXZ9Gmt5Jenpp59Ws2bNdP311/uPzZkzR99++60nrznRqVMnRUZGynEcnT592n/by5to3HfffRku5PfidSceeeQR9erVS9WqVfMf++uvv/TWW295cstXKePr6UiB17l5gbVzz2K7aNOmTYabUnz++edux0vnwQcf1Kuvvppmu+I9e/bo2Wef9U/x9ppGjRqpdevWchxHX375pf/2V199pZ9//tnteOlYyytJTZo08Rf377//vv/2Bx98oO+//97NaBmyVvj37ds3w/u8ui4stzCyZMzOnTs1cOBAt2Nkm7W8Usof4jO/rEkp23NntDOM29hEI/fFx8en+UIsSdWqVfP0COmPP/6oYcOGuR3jnFg79yy2C2ubUpw+fTrddV1Kly7t2XUeUsqXzMKFC0uSrrzySv/xM297ibW8UspGJal/4868/dBDD7kZK1Mvv/yyqcLf4rqw3EKxZIy1RmotryRFR0drw4YNqly5sv/YunXrPDkNSGITjVAoVaqU5s2bl+aL/Lx58zx7fQxJOnnypNsRzpm1c89iu7C2KUWVKlU0YcIE3Xffff6pmV988YWnL/r76aefevazNxBreSWbnUHWCn+L68JyC8WSMX/99VeaaxVJ8vSUK2t5pZTrHQwcOFAnTpxQiRIltH//fkVFRXnyOggSm2iEwksvvaShQ4dq9OjRCg8PV1JSkipXruzJ3cNSce7lPovtwtqmFP369dP48eP1yCOPKDk5WeHh4br22mv1n//8x+1oGUpISNDBgwcDfgZ7ca2HtbySzc4ga4W/xXVhuYViyZiqVat69otOINbySlJsbKzeeust/5eJYsWKKTw8XEePHnU7WkBsopH7ChUqpGeffTbd8Y0bNyo6OtqFRFnj3Mt9FtuFtU0pIiIi1KFDh3TXopk7d65uuOEGl1Jlbvv27f6dzs7mxbUe1vJKNjuDrBX+FjcJyi0US8Z4eeeUQKzllaTDhw/7Rz6aNm2q9evXa8SIETp8+LAnP4QzuqBgw4YN3YyVqRdeeEHNmjXTv//9b/+xOXPm6IUXXvDkQv6tW7dq/PjxkqT7779ff/31lz7//HOVKlXKs18mvHoxycxYO/cstovnn38+4KYUzz//vCc3pfjjjz80cuRIOY6jrl27atmyZfr555/1r3/9y7PFUsWKFT373z8Qa3klm51B1gp/i+vCcgvFkjFn/oGbMmWKmjdvLill1zkv7i5nLa8k9e7dW23btlVcXJxatWql+vXr64knntBFF13kdrSA2EQj9z333HPq27evjhw5otatW6tjx44aOnSoChYs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f2xCQoK++uorTZo0Sdu3b9fJkydVokQJValSRU2bNlWTJk3SvYdjxozRv/71L/+0xsze00mTJqlv377p3uMz/21ffvml1qxZo5MnT6pcuXJq3LixunTpoqioqDSP79ChgxYvXqyZM2dq2bJlGjt2rNavX6/w8HAtXbr0nP67AEBew8gSAOQhc+fOlSTdcccdQRVKkvTGG29o7dq1qlatmurXr69Tp05p1apVGj58uGbPnq0vvvhChQoVkiTVrl1b+/bt06+//qry5curdu3a/ue59NJL/beXLVum7t2768iRI6pYsaJuuukmHTx4UL/++qvmzZunwYMHq3HjxtnKl5SUpN69e2vatGnKly+frr76apUsWVK7du3SnDlz/Gt8MpOQkKCnnnpKRYsWVeXKlXXZZZfp8OHDWrZsmV566SX9+eef6dZfvfHGGxo5cqQiIyNVt25dFStWTPv27dNff/2lrVu3pimWnn76af30008qVKiQ6tSpo+joaO3Zs0e///67jh8/nqZYOlvJkiXVokULrVmzRmvXrtXVV1+tiy++ON17GkjqyOL333+vggULqkaNGipSpIhWrlyp9957T3PnztXYsWNVoECBdL87bNgwffXVV7r66qt18803a9euXZm+FgD8E1AsAUAesnbtWklZf6nOzGOPPaarr746zTSvhIQEvfLKK/riiy80atQoPf7445Kke++9V+XLl9evv/6q2rVrB9zgIT4+Xj169FB8fLwGDRqUZurfn3/+qYceekjPPfecrrnmGhUvXjzLfB9//LGmTZumypUr66OPPkozTe3o0aNas2ZNls8RHh6u999/XzfeeKPy5cvnP37w4EF17dpVkydP1j333KO6detKkk6dOqXPPvtMhQoV0jfffJPmNRMTE7V8+XL/z9u2bdNPP/2ksmXL6uuvv06zrujUqVNavXp1ptkqVaqk1157TUOHDtXatWt17733qmXLlln+myRp5MiR+v7771WvXj29+eabio2NlZTy3+/FF1/UxIkT9d577+npp59O97tTpkzRp59+qnr16mXrtQDgn4CtwwEgDzl8+LAkZbjwv1+/fnr22WfT/O/sqVY33nhjuvUwkZGR6tevnyIiItJMZ8uOiRMnat++ferUqVO6NVI1a9bUo48+quPHj+vbb7/N8rkSEhI0atQoSdLAgQPTrecpXLhw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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_title = 'gate exit accuracy'\n",
    "sorted = df.sort_values(by=['test/gate_exit_acc'])\n",
    "gate_exit_acc_df = sorted['test/gate_exit_acc']\n",
    "figure(figsize=(10, 5))\n",
    "gate_exit_acc_df.head()\n",
    "# sns.lineplot(data=gate_exit_acc_df)\n",
    "# plt.ylabel('Percentage')\n",
    "# plt.show()\n",
    "label_list = []\n",
    "plt.xticks(rotation=90)\n",
    "colors = []\n",
    "color_map = {'GateType.UNCERTAINTY': 'tab:red', 'GateType.CODE': 'tab:blue', 'GateType.CODE_AND_UNC':'tab:purple'}\n",
    "for i in range(len(sorted)):\n",
    "    label = build_plot_label(sorted.iloc[i])\n",
    "    label_list.append(label)\n",
    "    colors.append(color_map[sorted.iloc[i][GATE_TYPE]])\n",
    "plt.xlabel(\"Gate classifier\", fontsize=15)\n",
    "plt.ylabel(\"% accuracy of exits\", fontsize=15)\n",
    "plt.bar(label_list, height=gate_exit_acc_df.to_numpy(), label=label_list, color=colors)\n",
    "\n",
    "# plt.savefig(os.path.join('figures',plot_title+'.pdf'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "2a778836",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f72588465e0>"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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VO3atUszZ76mP/95zMHzvpAkZWe/pXbt2uuPf/yTTNPU6tWrGvTzYaoRAAD45eYaxx26JKm8vGGjZR06dNSqVSslSRUVFSorK5NUten04MFDZBiGoqKidNllV2jx4kU1XltSUqxmzao21/7ii4W67bbblZOzvtZ7lJSUqFmzZg2qOzo6RmvXrlFeXp6ioqLq3OOx2rJlSzRw4CBJVXfPr++mqYcieAEAANutWrVC55xzrh544D4NHHi5LrnkUknS/v25Sk1t4T8vNbWFfy/EV16ZoptuGq4vvlikbt2qRrH27durVq1aq0WLlsrN3Sfp57vcjxx5sy677IoG1XPOOT11xhln6s47b9Po0XeruLi43vN9PlNOp/OYPzfBCwAA2GbevLd1++23KikpWYmJzfX4409rypRX9d13qyVJycnJ2rdvr//8ffv2Kjm5aguim266Va+88k8NHPg7ffLJR9q4MUcbN+bonnvu0Jo1q7Vw4eeSft5Qe/bsNzV79qzaRRyBYRi67rrr9frr/9a55/bWhx9+UO/5DoejxhZFDUXwAgAAtrnqqqv14otTNHLkHf5jbdumKSrKrW3btqpPn37697/nyLIsVVZW6r333lVm5q9qXCM+Pl6FhYVauPBzjRs3Qc8884JefvlVffXV0hrnxcTEqrS0YZtw79u3V+UH96dsyObY556bqblzsyXp4BqvlQ16HxbXAwAAv5QUS9HR1gktrk9JOfZtoC+7bIDeeWeu7rrrHnXvnq6RI2+SZUlDhgxVysFNt195ZYrmzs2Wy+XSI488rgcfvE/Dh4+QJEVFRam0tFRlZaX+qcaKinLdcMPNtd5rzJg/y+WKUrt27dS1azdJ0u7du/TAA/cpKsqt2NhYjR8/od56Bw36nZ599hmNGnWLvF6vsrKGNuhzskk2AAAR7vBNsgN1O4lIxCbZAACgXmlphKdAYY0XAACATRjxAgAAkqqmxdC4SktLJFV9a1IieAEAEPHc7qoF5QUFecEuJewYhpSY6JHb7a56zOJ6AABgmqYqKiqCXUbYcblccrl+HucieAEAANiExfUAAAA2IXgBAADYhOAFAABgE4IXAACATQheAAAANiF4AQAA2ITgBQAAYBOCFwAAgE0IXgAAADYheAEAANiE4AUAAGATghcAAIBNCF4AAAA2IXgBAADYhOAFAABgE4IXAACA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j8JXg+No9+7dVVRUpKysLKWnp2v37t2aP3++3G63+vfvr6FDhyo7O1uDBg1SixYt1KlTJ1133XX67rvv1K9fv0B+BgAAgJBgWJZlBbuI+vh8pvbvLw7ItV0uh5KS4pSXV8y/LJooehQa6FNooE9NX7j0KDk5jqnGOvBTAQAAsAnBCwCACFM92WV5vbIsS0188iusNHhxPQAACH3ln/1PheMfkuF2yyoqktxuyTAU/etLFX//X7jxeYARvAAAiBDln36swocelCRZFRVVBw/+Wv7eO1JZmeIfHk/4CiCmGgEAiADmvn0qfPgv9Z5T/tEClf3nfZsqikwELwAAIoE7qmHneb2BrSPCEbwAAIgA5o8/SkdbRO90ytqfa09BEYrgBQBAJIhqwIiXaTbsPBw3ghcAABHASEqSjrZo3rJkxDazp6AIRfACACACOGJiZTRvXv9JhiHX6WfYUk+kIngBABABjJgYNX/tdRkJnjrPSZjwpKLO7GpjVZGH+3gBABAhnCmpSpr1LxX9Y6KM2FhZRYUyYpvJLClW7KDBcp+dEewSwx7BCwCACOJITpFn3IRglxGxmGoEAACwCcELAADAJgQvAAAAmxC8AAAAbELwAgAAsAnBCwAAwCYELwAAAJsQvAAAAGxC8AIAALAJwQsAAMAmBC8AAACbELwAAABsQvACAACwCcELAADAJgQvAAAAmxC8AAAAbELwAgAAsAnBCwAAwCYELwAAAJsQvAAAAGxC8AIAALAJwQsAAMAmBC8AAACbELwAAABsQvACAACwCcELAADAJgQvAAAAmxC8AAAAbELwAgAAsAnBCwAAwCYELwAAAJsQvAAAAGxC8AIAALAJwQsAAMAmBC8AAACbELwAAABsQvACAACwCcELAADAJgQvAAAAmxC8AAAAbHJMwWvs2LHKysrStGnTahxfuXKlRowYoWHDhmndunX+4//85z910003NU6lAAAAIc7V0BNXrVql2NhYzZ49W7fffrvy8/OVmJgoy7I0Y8YMTZkyRW6323++1+utEcIAAAAiXYOD1+rVq9WrVy9JUkZGhtauXavMzExt27ZNJSUlGjVqlFJTUzVu3DjFxMToP//5j37zm99o5syZJ16kKzAzok6no8avaHroUWigT6GBPjV99Cj8NTh4FRQUKD4+XpKUkJCgwsJCSVJubq527typ7OxszZs3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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.patches as mpatches\n",
    "\n",
    "# Scatter plot of gated acc vs cost\n",
    "uncertainty_df = df[df[GATE_TYPE].str.contains(\"UNCERTAINTY\")]\n",
    "code_df = df[df[GATE_TYPE].str.contains(\"CODE\")]\n",
    "complex_df = df[df[GATE_TYPE].str.contains(\"CODE_AND_UNC\")]\n",
    "# gated_acc = df['test/gated_acc']\n",
    "# cost = df['test/cost']\n",
    "gated_acc_uncertainty = uncertainty_df['test/gated_acc']\n",
    "cost_uncertainty = uncertainty_df['test/cost']\n",
    "colors_unc = []\n",
    "gated_acc_code = code_df['test/gated_acc']\n",
    "cost_code = code_df['test/cost']\n",
    "colors_code = []\n",
    "gated_acc_complex = complex_df['test/gated_acc']\n",
    "cost_complex  = complex_df['test/cost']\n",
    "colors_complex = []\n",
    "# label_list = []\n",
    "fig, ax = plt.subplots()\n",
    "color_map = {'GateSelectionMode.DETERMINISTIC': 'tab:red', 'GateSelectionMode.PROBABILISTIC': 'tab:blue'}\n",
    "for i in range(len(gated_acc_uncertainty)):\n",
    "    colors_unc.append(color_map[uncertainty_df.iloc[i][GATE_SELECTION_MODE]])\n",
    "\n",
    "for i in range(len(gated_acc_code)):\n",
    "    colors_code.append(color_map[code_df.iloc[i][GATE_SELECTION_MODE]])\n",
    "\n",
    "for i in range(len(gated_acc_complex)):\n",
    "    colors_complex.append(color_map[complex_df.iloc[i][GATE_SELECTION_MODE]])\n",
    "\n",
    "scatter = ax.scatter(gated_acc_uncertainty, cost_uncertainty, marker='^', label='UNCERTAINTY', c = colors_unc)\n",
    "ax.scatter(gated_acc_code, cost_code, marker='X', label = 'CODE', c = colors_code)\n",
    "ax.scatter(gated_acc_complex, cost_complex, marker='o', label='CODE AND UNC', c=colors_complex)\n",
    "red_patch = mpatches.Patch(color='red', label='DETERMINISTIC')\n",
    "blue_patch = mpatches.Patch(color='blue', label='PROBABILISTIC')\n",
    "fig.legend(handles=[red_patch, blue_patch])\n",
    "plt.legend()\n",
    "\n",
    "# for i, txt in enumerate(label_list):\n",
    "#     ax.annotate(txt, (gated_acc[i], cost[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b174be7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.close()"
   ]
  }
 ],
 "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.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
