{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "from utils import set_up_plotting\n",
    "plt = set_up_plotting()\n",
    "import sys\n",
    "sys.path.insert(0, '../')\n",
    "sys.path.insert(0, '../datasets')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_dir = '../results/similarity/'\n",
    "dataset = 'diabetes'\n",
    "budgets = [50,100,150,200,250,300]\n",
    "num_players = 400\n",
    "seeds = [0,1,2,3,4,5]\n",
    "eps = 1\n",
    "model_name = \"logistic_regression\"\n",
    "mode = \"cosine\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_names = []\n",
    "\n",
    "for file in os.listdir(results_dir):\n",
    "    if file.endswith('.npy') and dataset in file and any([f\"budget_{budget}\" in file for budget in budgets]) \\\n",
    "        and f\"players_{num_players}\" in file and f\"eps_{eps}\" in file and model_name in file \\\n",
    "            and any([f\"seed_{seed}\" in file for seed in seeds]) and mode in file:\n",
    "        f = '.'.join(file.split('.')[:-1])\n",
    "        exp_names.append(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_momentum_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_100_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_150_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_200_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_250_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_300_num_players_400_seed_5_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_0_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_1_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_2_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_3_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_4_mode_cosine',\n",
       " 'all_scores_with_updated_grad_diabetes_logistic_regression_clipping_norm_1.2_eps_1.0_delta_5e-05_budget_50_num_players_400_seed_5_mode_cosine']"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp_names.sort()\n",
    "exp_names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_momentum = {}\n",
    "scores_updated_grad = {}\n",
    "\n",
    "for budget in budgets:\n",
    "    scores_momentum[budget] = [None for _ in range(len(seeds))]\n",
    "    scores_updated_grad[budget] = [None for _ in range(len(seeds))]\n",
    "    for exp_name in exp_names:\n",
    "        for seed in seeds:\n",
    "            if f\"seed_{seed}\" in exp_name and f\"budget_{budget}\" in exp_name:\n",
    "                if 'momentum' in exp_name:\n",
    "                    results = np.load(results_dir + exp_name + '.npy', allow_pickle=True)\n",
    "                    scores_momentum[budget][seeds.index(seed)] = results\n",
    "                elif 'updated_grad' in exp_name:\n",
    "                    results = np.load(results_dir + exp_name + '.npy', allow_pickle=True)\n",
    "                    scores_updated_grad[budget][seeds.index(seed)] = results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAocAAAH7CAYAAAC+HDXFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACRVElEQVR4nOzdd3gUVfs38O+mJ6SSBiGFTugdpIbeBIIiRUUD2EDgQcGHoiggIiggCjxYKRERAelIjxB6CzVAEBBSgfTes+f9gzfzy2b7Zpe07+e6cpE9c+bMPSe7yc2ZmXNkQggBIiIiIiIAZuUdABERERFVHEwOiYiIiEjC5JCIiIiIJEwOiYiIiEjC5JCIiIiIJEwOiYiIiEjC5JCIiIiIJEwOiYiIiEjC5JCIiIiIJEwOiYioWhs/fjxkMpnSV69evco7NKJyweSQqJLLyMjA7t27MXnyZHTo0AF+fn6ws7ODnZ0dateujbZt2+L111/H0qVLcfbsWRQWFpZ3yEaRkpKC/v37w9HREVOnTi3vcCqU2NhYLFu2DIGBgahfvz6cnJxgYWEBe3t71KlTB127dsUbb7yBFStW4Pjx48jOztap3WnTpsHR0RH9+vVDSkqKic/COHR5n7Rs2RIDBw7EwIED0aBBg+ccoWk8evQInTp1grOzM5YsWVLe4VBlI4ioUsrIyBBffPGFcHZ2FgAEAOHk5CRatmwp+vTpI7p06SLq1asnZDKZtB2AsLe3F6+88orYvn27yM7OLu/TMNi8efMUzuvYsWPlHVK5y8zMFP/5z3+Eubm51C+Ojo6iY8eOom/fvqJbt26ifv36Su8JS0tL0a1bNxEVFaW27WPHjinsM2/evOd4ZobT930yf/58qW5AQMDzCdIExo0bp3De9+/fL++QqBLhyCFRJXT9+nU0b94c8+bNQ2pqKkaMGIG///4bSUlJuHHjBkJCQnD27Fn8+++/SEpKws8//4yGDRsCADIzM/Hnn39i1KhRGDZsWDmfieGEEAqv5XJ5OUVSMaSnp6Nfv35YtWoVioqK0KFDB4SEhCA1NRUXL17EsWPHcPr0aTx48AAJCQlYsWIFnJ2dAQAFBQU4c+YMkpKS1LZfWfu7ssZdVvqed926daXL6Rs3bjRhZFQplG9uSkT6OnDggKhRo4Y04rN161ad9svJyVEaTajMIyOJiYmiT58+wt7eXrz77rtCLpeXd0jl6p133pF+rp07dxY5OTla9wkPDxdOTk7SflevXlVbVy6Xi8mTJwt7e3sREBAgEhISjBi96ej7PqkqI4cPHjwQ7du3F46OjmLhwoVa6/v5+UnnvWHDBtMHSBWaRfmkpERkiFu3bmH06NHIysoCAGzatAmjR4/WaV8bGxsEBwfjyZMnOHbsmCnDfC5cXV0REhJS3mFUCPHx8Vi3bp30+osvvoCNjY3W/Zo3b47PPvsMM2fO1FpXJpNh7dq1WLt2bZlifd6q6/ukfv36uHz5cnmHQZUULysTVRI5OTl4+eWXkZmZCQB4+eWXMWbMGL3aMDMzw48//ggzM370q5Jjx44pXDZ84YUXdN43KCiI7wciUsDfCESVxI8//oh//vlHer148WKD2qlfvz5efPFFY4VFFUBMTIzCawsL3S8Kubq6okuXLqhTpw6srKyMHRoRVUK8rExUCeTl5WHZsmXS67Zt28Lf39/g9l588UXs27dPr32Sk5Nx8uRJxMbGIi0tDTVr1oSvry969uwJe3t7vWOIjIzExYsXERMTg+zsbNjb26Nu3bpo06YN/Pz89G6vLGJiYnDq1ClERUXB2toaDRs2REBAABwcHAxqLz4+HidPnkRcXBwyMzNRs2ZN+Pn5oXv37ga3qYlMJlN4ffXqVXTp0kXn/U+fPm3skDRKSUlBSEgIHj58CAsLC7Rs2RK9evVSmdQWFRXh+PHjuH79OgoLC+Hl5YVevXrBx8fnucaszaNHj3D9+nVERkYiIyMDdnZ28PDwQIcOHdCkSROjHSc7OxvHjx9HZGSk9Dls2LAh2rRpA1dXV6Mdh6q58r7pkYi0O3TokMKDJJ9++mmZ2issLBQZGRk6TWVz6dIlMXDgQGFmZqYQQ/GXpaWlGDNmjPjnn390Ovbp06dFt27dVLZV/NWgQQPx4YcfimvXrintX/LG+ZJf8+fPV6q7a9cutccQQoj09HQxbtw4YWFhobTd0dFRfPPNNzqdU7Hz58+Lvn37Kk0VU/xlYWEhXnnlFXHr1i292tXmjz/+UDjOwIEDRVFRkVHaDgoKUnkuqh7WSElJUdvfx48fF3K5XCxcuFDY29srbff29hYHDx5UaO/EiROiXr16SnXNzMzExIkTNT50o8/7pCR9Hki5fv26+OCDD1TGWPKradOmYuPGjRrbunr1qtr9Hz58KAoLC8Wnn36q8ACRqp+HujZUPWQSEBCgMW5Vfbdhwwat9Y4fP650LE31qeLhyCFRJVD6hvrWrVuXqT1zc3OdRvuWLVuGOXPmQC6Xw8rKChMnTkT//v3h5uaGx48fY+/evdiyZQu2bt2KPXv2YOPGjRrvg9y0aRMmTJiAoqIiuLm5YcKECejYsSM8PDwQHx+PGzduYO3atXjw4AFWrlyJlStXKk3JERAQgKdPnwIALl68qHEyZm9vbyme+Ph4HD9+XNqWlpaGHj16IDw8HG3btoWfnx/S09Nx4cIFZGZmIj09HTNmzIBcLtfpgY2lS5fi448/hhACNWrUwLvvvovevXvDyckJsbGx2Lt3L7Zt24Y///wT+/btw/r16/Haa69pbVcXPXv2hLm5OYqKigAAhw8fxqBBg/Ddd9+hadOmZWq7eIJoALh//z4ePHigtq6VlZXCz3/r1q0K28ePH49ff/0VzZs3R6NGjZCRkYHz588jKysLMTExCAwMxP79+9G/f38cPnwYI0aMgJ2dHQYNGgRra2tcu3YNkZGRkMvlWL9+PVJTU7Fjxw6VsejzPjHUxIkTERYWBgDw8vLC22+/jVatWsHDwwNpaWkICwvDhg0bcOfOHYwfPx7Hjh3Dr7/+qjTSCwAuLi5S32VlZWH//v3StqKiIgwfPhwHDhxArVq10KVLF8hkMoSFhSE+Pl6hneKfFQCEhoYiNzdXbfydOnWSHlwqWbdFixaoU6eOUv2GDRvC09MTAwcORGZmJs6cOSNta9u2LTw8PAAANWvWVNq3OK7k5GRcunQJNWrUQPfu3dXGRuWsvLNTItKua9euCv/TvnPnjsmPuXTpUul4zs7O4sqVKyrrHTp0SFhZWQkAQiaTie3bt6usFxUVJWxtbQUA4eXlJZ4+faqyXmpqqujevbtOowolRz60jQgdP35coQ+DgoJEs2bNxI0bNxTqJScni4EDB0r1bG1tRUpKisa2S/aVt7e32lHUQ4cOCWtra2n0y5gTd7/55psqR9gGDhwofvvtN63noAt9p3kp3d+urq7i77//VqiTmJgoevToIdVr0KCBSEhIEK6urmL27NkiLy9PqiuXy8WXX36p0G5ISIjWOPR5n+hzju3btxcARJcuXURGRobKOtnZ2WLkyJFSm4sWLdIa78OHDxXO8a233hJ2dnZi06ZNClPxZGZmir59+6qNVZ/pafSdyqagoEB4e3tL+0yZMkXrPkIIMWvWLAFATJs2Taf6VD6YHBJVAqUvW6lLrIzl/PnzCqtsaJtLsWRy5ODgoHKljeXLl0t1PvjgA43tRUREmDw5dHBwENHR0SrrxsXFCUtLS6nu+vXr1bZ74cIFhb4qnfyUtnDhQqlunTp1FJKfskhJSRFt2rRRe+nO0tJS9O7dW6xYsUJEREQYdIyyJIcAxJEjR1TWu3//vkK9Nm3aiNdee01tuy+88IJUd+LEiVrjMHVyePPmTY310tPThYuLiwCerVCkLVEvnRwCEPv27VNZNyQkpFySQyGE+OKLL6R97O3tRVpamsb62dnZombNmkImk4m7d+/qdAwqH3xamagSKL1yhSkeaihpwYIF0iXKRo0aYdSoURrr/+c//5EuU2dkZOCrr75SqnP//n3p+5ycHI3tNWnSBM2aNYOnp6e+oevsnXfegbe3t8pttWvXRqdOnaTXxZcOVSnZV507d0bv3r01Hvf999+Hubk5gGdrIP/xxx/6hq6Ss7MzTp48iffee0/l1DQFBQU4fvw4Zs6cCX9/fzRv3hxffPGF0mVJU3nhhRfQv39/ldsaNGiA5s2bS6+vXbuGzz77TG1bI0aMkL6/ePGi0WLU1+rVqxESEoIWLVporOfg4IAePXoAeLZCkb7zjPbr1w9Dhw5Vua1Dhw7YtGkTPvnkE73aNIZ3330X1tbWAJ6d14YNGzTW//3335GcnIwBAwagcePGzyNEMhCTQ6JKoPR9Q6acciQ2NhaHDh2SXg8bNkzlPVIl2draYsCAAdLrjRs3oqCgQKGOnZ2d9P22bdvw8OFDjW3eunULT5480Sd0vWhbOrDk0+Clp4opFhcXh4MHD0qvAwMDtR7Xzc1Noe3du3dr3UdXDg4O+OGHH3Dnzh1MnjxZ5b1fxW7fvo1PP/0Ufn5++Oyzz5CXl2e0OFQZPHiwxu3FyzsCQL169TQ+4duoUSPp++jo6LIHZ6AuXbqgT58+OtV1cXGRvr969apex3nllVfUbnN0dMS4cePUJt6m5O7urnCP6f/+9z+le4RLWr16NQBg2rRpJo+NyobJIVElUHqKiuKJsE3hxIkTCq/btm2r034lH5LJysrCpUuXFLaXTA5SUlLQvn17fP7552oTL1Nr1qyZxu0l+zwjI0NlnZIPuAC691XJEctz587ptI8+GjdujLVr1+LJkyc4dOgQpk2bppB8lZSbm4tFixZhwIAByM7ONnosxbQ9GOPo6KhzXScnJ+l7dT+b5yk7Oxs7d+7Exx9/jNdffx3Dhg3DoEGDFL6OHj0q1U9MTNSr/bI+gGZKJRO9e/fuKfzHsqRTp07h+vXraNCggdb/KFD549PKRJWAu7s7Hj9+LL3OyMhQ+ANpTBEREQqvdZ1zsHS9iIgIdO3aVXrdr18/TJgwQbr0lJKSgvnz52PBggXo1KkThg0bhqFDhz63P4QlR3JUKbn8XPFl49JK99WiRYvw7bffaj12yZGjJ0+eoKCgAJaWllr305elpSUGDhwoPSl679497Ny5E7///jtu3LihUPfkyZOYMWMGfvjhB6PHATy77K1JyUvh2uoWX5YHoLAyzPOWm5uLL7/8EitXrtTrP2z6jtJW5PkLO3TogM6dO+PChQsAgFWrVqlM/opHDadMmcIVeSoB/oSIKoGSl9GAZxNIm0rp+xt1neC69H2QqkZH1q1bhzVr1khTXgCAEAIXLlzAvHnz0KZNGzRo0AALFy7Ue3RFX9qSMW2X0gHlvjp79iwOHz6s9av0fX7Jycn6n4ABGjVqhNmzZ+P69es4ceIE2rVrp7B93bp1JruUr0/ya4pE2dhycnIwePBgLFq0CJmZmbC1tcWnn36K69evIysrC+LZA5/SV1BQkMHHquj9UXL08PDhw7h3757C9tjYWOzatQs1atTAhAkTnnd4ZAAmh0SVQOn7iW7evFlOkZSNTCbDlClTEBkZie3bt+OVV15BjRo1FOr8+++/WLBgARo3bow///yznCI1zNWrV5WSAl2+TPngjToBAQE4d+6cQoJYWFiodFsBqfb5559LfWVubo4jR47g888/R6tWrRTur60ORo0aJb2HhRBYs2aNwvbvv/8ehYWFeOONN7SOClPFwOSQqBIYNGiQwmtT3KdWzND7G0vf++Xm5qa2ro2NDV555RVs374dCQkJ2LlzJ0aNGqXwoE1KSgrGjh1boZOV53kvqClYWVlhyZIlCmVRUVHlFE3lUVBQoHD5ffjw4dV6QmcrKyu8++670uuNGzdKvw/y8vLw888/AwCmTp1aLvGR/pgcElUCfn5+Cgninj17yvR06RtvvIGhQ4di6NChOHv2rMK20ms263oJu3Q9Xdd+trW1xUsvvYRt27YhMjISb7zxhrStqKgIn3/+uU7tlIfSD06Y8nK/JidPnoSNjY1Ba1KXfoiG94Npd+/ePaSmpkqvq3NiWGzSpEnS2tjp6ekIDg4G8Gxmgvj4ePTp00dhuiKq2PhbgKiS+PLLL6Ub8dPS0rB582aD2jl+/Dh+++03/PXXXzh9+jTatGmjsL30PH26Trtx7do16fsaNWqgY8eOCtsfPHiA8+fPIz09XW0btWrVQnBwsMJl9PKcx06b0n2laT7E0j7++GOMGzcOixcvLnMccrkceXl5iIuL07hcmiqlL4HWrl27zPFUdSUTQ0DxSWt19P25VDZeXl4YOXKk9HrNmjUQQnD6mkqKySFRJdG2bVvMnTtXev3JJ58gLS1NrzaKioowZ84c6fWcOXOUkgMvLy+Fpw337t2rce4y4NlUHiWn6hg/frzSTfSLFi1Cly5d8Pfff2tsSyaTKcxBWJFHsmrXro0XX3xRer1r1y6tfQU8G2H86quvDE7w1SksLFSaXkeb0k8tF0/WTOq5u7srvNZlOqa7d++aKhyjKB71A5SfABdC4NChQzh06BDi4uLUtlEyAbx79y4WLVqES5cuwc/PT+u8olSxVNzfukSkZMGCBXjppZcAPJsC5aWXXtJrRGLGjBnSSFy7du0wY8YMtccpHqW8f/8+tm3bprHd1atXS/fbOTg4YNasWWrraksOAcWnd1u2bKm1fnlauHCh9If10aNHWL9+vdZ9Pv30U8jlctjb2+O9994zajyff/45CgsLda6/bNky6ft+/frB19fXqPFURQ0bNkStWrWk1zt27ND4n4IrV64ojKxXRCWndip972xCQgIGDx6MwYMHS1PWqNKtWzeF2xTmz58PAJg8ebLC9ENU8TE5JKpEzM3N8ccff2DixIkAnl0i7tmzp9Y/PE+fPsXYsWOxatUqAM+WK9u/f7/alVY6deqEpUuXSq8nTZqk9vLy4cOHFZY6W79+vcYE46efftL4kEl0dDR+/PFH6XVFvxzVvn17hQTrP//5j8IoaklCCCxatAibNm0CACxfvlzjgzuGOH/+PEaNGqU0zU5pWVlZeP/997Fr1y4Azy6NFr8/SDOZTIYPPvhAeh0eHq4wql/S48eP8frrrz+nyAxX8vaSO3fuKGwLDQ2Vvtf2n7XSD53Y2Njg7bffLnuA9FzJhC7XQIiowvn5558xZ84cJCcnw8zMDD179sSwYcNQv359uLq6Ijc3F//++y9CQ0Oxe/duaT3jYcOGITg4WOsk0ACwYsUKzJo1C3K5HFZWVpg4cSIGDBgAV1dXPHnyBHv37sWWLVsgl8thY2ODDRs2YOzYsSrbmjBhAjZu3Ajg2aXiUaNGYfDgwfDz84OlpSXi4+Nx5swZrFu3Trqn64MPPsDKlSsV2gkKCsLTp08BPLsfMSUlBcCzhLd4FZBx48Zh3LhxePr0qTS/XHJyssKqLcUTQ3t6eko3zx89ehQrVqwA8GzE9MGDBwCejaoUr7Xcv39/zJw5U+n8vv32W3z00UcoKiqCTCbDSy+9hMDAQPj6+qKoqAi3bt1CcHAwrly5AgDSBODGcPbsWXTr1k2hzMHBAS+//DK6desGPz8/1KhRA7m5uYiJicGFCxewY8cOab7FOnXqYMeOHejcubNS2ytWrJCSXXV90qpVK3z99dcAFH8+hw8fltrp2LGjtJxfcHAwPD09Ffr75s2b0iVLLy8vKQkx9Gepz/tEl3Ms2Tbw7BJ+YGAgDhw4IJX16NED48ePR8OGDZGbm4uzZ8/if//7Hzw8PODl5SWtqazq/ID/m5UgJycHJ0+elNrt2bMnbG1tVcZRWskH10JDQ6UrCy1atECdOnUAADNnzlSaHuvMmTPo0aMHhBCws7PDokWL0LZtW/zzzz/49NNPkZCQgD59+iAkJETtsYFn91Z6e3tL/zmZOHEi1q1bp3EfqoAEEVVaaWlpYtGiRaJJkyYCgNova2trERgYKEJCQvQ+xqVLl8SgQYOEmZmZyrYtLS3FmDFjxN27dzW2k5qaKtauXSt69uwpLCwsNMbbrl07sWvXLpXt+Pn5adwXgJg/f74QQoiHDx9qrevn5ye1vWHDBq31g4KC1J7jlStXxNChQ4W5ubna/bt16yb+/vtvPX8K2kVFRYlVq1aJYcOGCTc3N63nAUA0btxYfPHFFyIjI0Ntu0FBQVrbCQgIkOrr8vN5+PChEEK3/jb0Z6nP+0SXcyzZdrGCggKxaNEi4eLionIfKysrMXXqVJGSkqL2GMUxCCF0+pmpiqMkXdrYsGGDyn2/++47YWNjo3Kf7t27i8ePH2s8drFZs2ZJ+129elWnfahi4cghURURFRWFy5cvIz4+HklJSbCxsYGLiwuaNm2KVq1aKU02ra+kpCScPHkSsbGxSE9Ph7OzM/z8/NCzZ0+l1VG0ycjIwPXr1/HPP/8gKSkJeXl5qFGjBnx8fNC+fXvUq1evTLGWt5SUFJw8eRIxMTFITU2FnZ0dfHx80LlzZ/j4+DyXGB49eoT79+8jMjISaWlpyM7OhpWVFRwcHODr64tWrVo9t1iqupycHJw5cwZ37txBeno6HB0dUa9ePQQEBOj92ShvycnJ+Pvvv/Hw4UPk5+fD1dUVnTp1UlpNR5Pg4GCMHz8e3bt3x6lTp0wYLZkKk0MiIiIymm7duuHs2bPYunUrRo8eXd7hkAGYHBIREZFR3LhxA61bt0adOnXw6NEjhSlyqPLg08pERESks+zsbPz2228KDwUVK570uuSKKVT5cOSQiIiIdBYTEwMfHx8EBAQoTEt19+5dtGzZElZWVoiMjFRae5wqD6b1REREpLfQ0FDMmTMHAwYMQGxsLObPn4+CggIsWrSIiWElx5FDIiIi0lnxyGFpZmZmePfdd7F27VrIZLJyiIyMhckh6UUulyMuLg4ODg788BMRVVOPHj3ClStX8OTJE+Tk5KBWrVro1q0b6tatW96hkRpCCGRkZMDLy0vrmvW8rEx6iYuL49xoRERElVR0dDS8vb011mFySHopntA1Ojoajo6O5RyNagUFBThy5AgGDBgAS0vL8g6nUmNfGg/70jjYj8bDvjSeytCX6enp8PHx0WlidiaHpJfiS8mOjo4VOjm0s7ODo6Njhf2QVhbsS+NhXxoH+9F42JfGU5n6UpdbwjjPIRERERFJmBwSERERkYTJIRERERFJmBwSERERkYTJIRERERFJmBwSERERkYTJIRERERFJmBwSERERkYTJIRERERFJmBwSERERkYTJIRERERFJmBwSERERkcSivAMgIiIi48nOzkZERITWehkZGQgNDYWzszMcHBy01vf394ednZ0xQqzShBAoLCxEUVGRwW2Ym5vDwsICMpnMiJHpjskhERFRFRIREYH27dvrXH/lypU61QsLC0O7du0MDavKMzMzQ2JiIjIzM1FYWFjm9iwsLODk5ARnZ2dYWVkZIUI9jv1cj0ZEREQm5e/vj7CwMK31wsPDERQUhODgYLRo0UKndkm1/Px8uLu7Iz09HU5OTrC3t4e5ublBI39CCBQVFSEzMxMpKSlISUlB3bp1YW1tbYLIVWNySEREVIXY2dnpNMJXPLrl7+/PEcEyKCwsRFxcHBwdHVG/fn1YWloapV17e3u4u7sjMjIS0dHRqFu3Liwsnk/axgdSiIiIiAyUlpaGoqIieHh4wNzc3Khtm5ubw9vbG4WFhUhLSzNq25owOSQiIiIyUGZmJuzs7Ew2qmdlZYUaNWogMzPTJO2rwuSQiIiIyAByuRw5OTmoUaOGSY9To0YN5OTkQC6Xm/Q4xZgcEhERERmgsLAQQgiTPyxibW0tTZHzPDA5JCIiIjJA8UieqecjNDMzUzieqTE5JCIiIioDUyeHz3sybCaHRERERCRhckhEREREEiaHRERERCRhckhEREREEiaHRERERCRhckhEREREEiaHRERERCRhckhEREREEiaHRERERCRhckhEREREEiaHRERERCSxKO8AiIiIsrOzERERobVeRkYGQkND4ezsDAcHB53a9vf3h52dXVlDJFJLCFGp2y+NySEREZW7iIgItG/fXuf6K1eu1LluWFgY2rVrZ0hYRBqZmT27AGvq5E0ulyscz9SYHBIRUbnz9/dHWFiY1nrh4eEICgpCcHAwWrRooXPbRKZgYWEBmUyGvLw8mJubm+w4eXl5kMlksLB4Pmkbk0MiIip3dnZ2Oo3uFRYWAniW8HE0kMqbmZkZbG1tkZWVBUdHR5MdJysrC7a2ts9t5JAPpBAREREZyN7eHtnZ2dJ/XIwtPz8fWVlZsLe3N0n7qjA5JCIiIjKQk5MTzM3NER8fj6KiIqO2XVRUhJiYGFhYWMDJycmobWvCy8pEREREBrKwsICXlxdu3ryJf//9F05OTrC3t4e5uTlkMpne7QkhUFRUhIyMDKSnpwMA6tat+9zuNwSYHBIRERGViZWVFRISEuDn54eMjAykpKSUuU0LCwu4uLjA2dkZVlZWRohSj2M/16MRERERVUFyuRxubm6oVasWCgsLy3SJ2dzcXHoSujwwOSQiIiIyEplMBktLS1haWpZ3KAbjAylEREREJGFySEREREQSJodEREREJGFySEREREQSPpBCREQmFRUVhcTERKO0FRERIf1rzHnf3Nzc4Ovra7T2TMGY/QhU774kzZgcEhGRyURFRaGJf1Pk5mQbtd2goCCjtmdja4e7EXcqbFJjqn4Eql9fknZMDomIyGQSExORm5MN16EzYenqU+b2RGE+CtOewsLJEzIL40wMXJAUjaT9K5CYmFhhExpj9yNQffuStGNySEREJmfp6gPrWg2N05h3M+O0UwkZtR+BatuXulyiz8nJwaNHj3Rqr6ioCNeuXUNaWhrMzc211q9bty5sbW011inPy/NMDomIiKjaMOUlemMqz8vzTA6JiIio2tD1En3xZXdT0HYpv7wvzzM5JCIiompHp0v01fSyO+c5JCIiIiIJk0MiIiIikjA5JCIiIiIJk0MiIiIikvCBFCIiIqp2CpKijdaWsScUN2ZshmBySERERNWGm5sbbGztkLR/RXmHopGNrR3c3NzK5dhMDomIiKja8PX1xd2IO1pXSNFHeHg4goKCEBwcjBYtWhilTa6QQkRERPSc+Pr6GjXxKiwsBAD4+/ujXbt2Rmu3vPCBFCIiIiKSMDkkIiIiIgkvKxMRERGVkp2djYiICJ3qFteLiIiAhYX21Mrf3x92dnZlis+UmBwSERERlRIREYH27dvrtU9QUJBO9cLCwir0vYnVIjm8fPkydu7ciZCQEMTGxiIhIQH29vbw9PREu3btMHz4cAQGBsLa2tpoxzxx4gR69+5d5namT5+Ob7/9Vmu9hIQE/Pnnn9i/fz/u3r2L+Ph4FBYWwtPTE/Xr18eQIUPwyiuvwM/Pr8wxERERVXX+/v4ICwvTqW5GRgb27NmDwMBAODg46NR2RValk8OYmBh88MEH2LFjh1RmZmaGWrVqITU1FXfu3MGdO3ewefNmNGjQAN999x1efPHFcoxYf3K5HN988w0WLVqE9PR0qdzFxQU2NjZ49OgRHj16hL///huffPIJZsyYgc8++ww2NjblGDUREVHFZmdnp/PoXkFBAVJTU9G1a1dYWlqaODLTq7IPpNy7dw9dunRRSAx79OiByMhIxMbGIiUlBV988YW07cGDBxg2bBh++OGH8gjXIEVFRXjjjTfw3//+V0oMHRwcsG/fPiQnJyM+Ph5nzpxBrVq1AAB5eXlYsmQJhg4diuzs7PIMnYiIiCqoKpkcpqeno2/fvoiJiZHKrK2tsXXrVnh7ewMArKys8Mknn2Dw4MFSHSEEJk+ejF27dj33mA0xc+ZM/P777wplCxYswNChQ6XXXbt2xXfffadQJyQkBK+99tpziZGIiIgqlyqZHM6ZMwfR0YrrEnbv3h21a9dWqjt69GilsqlTpyItLc1k8enDxcVFZfn58+exevVqpXJV56Pqfso9e/Zg+/btxgmSiIiIqowqlxzGxMTgxx9/VCpXt5xNy5Ytlcri4uLw/fffGy0mIYTOX6GhodJ+NjY2eO+991S2OX/+fMjlcoUyJycnaWS0JGtrazRq1Eip/LPPPivjmREREVFVU+WSw19//VUpaQKgMmkCAB8fH5XlGzduNGZYOlu0aJH0/dtvvy3dL1hSTEwMjh07plSu7hwB1ecZERGBc+fOGRgpERERVUVVLjncvXu3ynJXV1eV5TVr1lRZfvfuXdy5c8dYYenk/PnzUtJnZWWF2bNnq6y3d+9elQmwunPUtE1dfxEREVH1VKWmsikoKMCNGzdUbnN0dFRZbmFhATs7O5VP74aFhaFp06YGxdKsWTNs2bJFr31KjhpOmDBB7Ujg5cuXVZarO0dN23Sdw4mIiIiqhyo1chgREYG8vDyV2zQtU6Nu27Vr1wyOxcPDA2PHjsXYsWN1qn/lyhUcOHAAwLOEdc6cOWrrXr9+XWX58z5HIiIiqnqq1MhhfHy82m1WVlZ6b9PUnrGVHDV84403ULduXbV11cVlyDkmJSVBLpfDzEz1/xPy8vIUEu7i+RQLCgpQUFCg9njlqTiuihpfZcK+NJ7q2peFhYXlHYLOCgsLK+zPpzL1I1Cx+9IUKsPnW5/YqlRyqGn6GXNzc723lVxxxJRu3ryJPXv2SLF8/PHHGuurO09DzhF4dp7Ozs4qty1ZsgQLFy5UKj9y5EiFXjQcAI4ePVreIVQZ7EvjqW59+eDBg/IOQWenT5/G48ePyzsMlSpTPwIVuy9NqSJ/vvVZ/KJKJYeGrvqhbtQsMzOzLOHo7IsvvoAQAgAwduxYNGzYUGN9Q85T3TkCz85TXXI4d+5czJgxQ3qdnp4OHx8fDBgwQOM9juWpoKAAR48eRf/+/avEMkbliX1pPNW1L69evVreIeise/fuaNu2bXmHoVJxPxYkRWupqTtRmI/CtKewcPKEzEL9lSd9FMdXkfvSFCrD51ufAa8qlRwaOpKl6slfALC3ty9LODqJiIjAn3/+CeBZAvfJJ59o3cfOzg4ZGRl6HUfdOQKaz9Pa2lppAm0AsLS0rLAfgGKVIcbKgn1pPNWtLy0sKs+fGQsLiwr7s6lVqxZsbO2QtH9FeYeilY2tHWrVqlVh+9KUKvLnW5+4Ks+nVgeaRrKKior03vY8RsYWL14sJW6vvPKKTk9HOzo6qkwODTnH4vaIiKji8vX1xd2IO0hMTNRaNycnB48ePdJa78GDB5g/fz4WLlyIBg0aaK1ft25d2Nraaq3n5uYGX19frfWo4qpSyaGnp6fabfn5+Xpv8/DwKHNMmjx48ECa7kYmk2HevHk67efp6YnY2FilckPO0dXVVeMlZyIiqhh8fX11SrquXLmCcePG6dzu/PnzdaoXFhaGdu3a6dwuVV5VKjn09/eHtbW1yulsNN2np25bmzZtjBWaSl9++aU0ohcYGKhyKT9VWrdujStXriiVV8RzJCKi58vf31+nOWwzMjKwZ88eBAYGwsHBQad2qXqoUsmhpaUlWrZsqXKSaHU3YhYVFSEnJ0flNlP+DykyMhKbNm2SXus6aggA7du3x4YNG5TKNd1squ4eRf4vkIioarGzs9Ppd3tBQQFSU1PRtWvXCnufHJWPKnc9MTAwUGV5UlKSyvLk5GTpSeGSGjVqhGbNmhk1tpKWLl0qzTk0ZMgQtG/fXud9hw0bpvJSsLpz1LRtxIgROh+XiIiIqr4qlxwGBQWpTJxU3aMHANHRqqcFmDBhgsryH374AY0aNYKzszMCAwMRGRmpd4yxsbEKI3+ffvqpXvv7+vqiT58+KttVR9V5Nm7cGF27dtXr2ERERFS1VanLygDg4+ODt99+Gz/99JNC+c2bN1XWv3XrllJZrVq1MHnyZKXydevWKZTv3bsXd+/exdWrV3V6gqvY119/Ld0X2b9/f7zwwgs671tswYIFCAkJURj1TE1NRUxMjNKazPn5+bh3755SG59//rnexyWi/5OdnY2IiAid6mZkZCA0NBTOzs46399V0SeaJ6Kqqcolh8Cz5Ouvv/5SGEkrnq29du3aCnW3bdumtP+aNWtUTgq9bt06pbK7d+/i1KlTGDBggE6xPX36FD///LP0Wt9Rw2LdunXDlClTsGbNGoXybdu2KUxaDQD79u1Dbm6uQtmwYcMwZswYg45NRM9ERETodUsIAKxcuVKnenwylIjKS5VMDp2cnBASEoI+ffogLi4OwLM1gseOHYvNmzfD29sb+fn5+Oabb7B//36FfVevXo2RI0fqdTyZTKZz3eXLl0sPwAQEBKBHjx56HauklStXIiEhAVu3bpXKFixYgCZNmuDFF18EAJw/fx7Tpk1T2C8gIECaQoeIDKfrU6EAEB4ejqCgIAQHB6NFixY6tU1EVB6qZHIIAE2aNMG5c+cwffp07N69GwBw8uRJ+Pn5oXbt2khJSVGY3qVevXr49ttvMXz4cLVtvvPOOzh37pxCmb+/P7p3765TTImJifj++++l14aOGhazsLDA5s2b0bZtWyxevBgZGRnIyMjA0KFDUbNmTVhYWCA+Pl6qb2VlhQ8++AALFizQ6zI4Eamm61OhAFBYWAjg2e8MjggSUUX2XJPDnJwcxMXFITk5GR07djT58Xx9fbFr1y5cunQJO3bsQEhICGJjY5GQkAA7Ozv4+PigXbt2GD58OEaMGAEbGxuN7U2YMAF5eXlYvnw5EhMTERAQgFWrVumcaK1cuRJZWVkAgC5duqBv375lPkdzc3PMnj0bEyZMwPbt2/HXX38hIiIC8fHxyMnJga+vL+rXr48hQ4Zg1KhRqFu3bpmPSURERFWXyZPDpKQkfP/999i9ezdu3LiBoqIiyGQy6X/RAPDhhx8iOzsbH374oUkupXTs2NFoyeikSZMwadIkg/ZdvHgxFi9ebJQ4SvPw8MCUKVMwZcoUk7RPRERE1YNJp7IJDg5GvXr1MH/+fFy9ehWFhYUQQijNK5iYmIhffvkFLVu2xLx581TOO0hEREREpmey5HDFihWYOHEisrKyVCaEJbVr1w6Ojo4oKirCkiVLDB6ZIyIiIqKyMUlyeP78ecyePRsAIISAm5sbXnzxRbz33nvw8/NTqv/hhx8iJiYG8+bNg5mZGX755Rfs2rXLFKERERERkQYmSQ7nz58PuVwOFxcXBAcHIy4uDvv27cP333+v9p7CGjVq4PPPP8dPP/0EIQS++OILU4RGRERERBoYPTlMTk7GsWPHYG1tjWPHjuGNN96AhYXuz71MmDABvXr1wrVr1/DgwQNjh0dEREREGhg9OTx9+jSEEBg/fjzatGljUBuvvvoqAODy5ctGjIyIiIiItDF6chgbGwuZTKbzcnKqNG7cGEIIaXUTIiIiIno+jJ4cpqamAgDc3d0NbkMulwOA0nrARERERGRaRk8OnZycADybu9BQxfca1qxZ0ygxEREREZFujL5Cio+PD4QQOHToEEaMGGFQG1u3boVMJuNSb0RUbqKiosr0n9zSIiIipH/1eUhPEzc3N/j6+hqlLSKiYkZPDgMCAmBhYYGNGzfi7bffRocOHfTa/7fffkNISAisra3Rs2dPY4dHRKRVVFQUmvg3RW5OttHbDgoKMlpbNrZ2uBtxp1IkiAVJ0UZpRxTmozDtKSycPCGzsDJKm8aKjaiqMHpy6OjoiGHDhmHXrl0YMGAAvv32W4wbNw5mZpqvYGdnZ+Orr77Cl19+CZlMhlGjRsHW1tbY4RERaZWYmIjcnGy4Dp0JS1cfo7Rp7KSmICkaSftXIDExsUInh25ubrCxtUPS/hXlHYpGNrZ2cHNzK+8wiCoEoyeHALB48WL89ddfSEtLw4QJEzBv3jy8+OKLaNu2LeLj4wEA+/btQ0ZGBiIjIxEWFobDhw8jOzsbQgjY2dlh4cKFpgiNiEhnlq4+sK7V0HgNejczXluVhK+vL+5G3DHaJfrw8HAEBQUhODgYLVq0MEqbAC/RE5VkkuTQ398fP//8M4KCgiCTyRATE4OffvpJ2i6EULofsXjtZTMzMwQHB6NevXqmCI2IiJ4zX19foyVehYWFAJ79nWnXrp1R2iQiRSZZPg8A3njjDfz++++oUaOG0jaZTAYhhJQQFnN0dMT27dsxcuRIU4VFRERERBqYLDkEgLFjxyI8PByTJk2CnZ2dlBCWTAqFEKhRowamTJmC8PBwvPTSS6YMiYiIiIg0MMll5ZJ8fX2xdu1arFq1ChcvXkRERASSkpIAAK6urmjatCk6duxotKkdiIiIiMhwzy0js7CwQNeuXdG1a9fndUgiIiIi0pNJLysTERERUeXC5JCIiIiIJCa7rPzTTz8hNzdXeu3r66t2Ob0ffvgBv//+O6ZOnYrRo0ebKiQiIiIi0sIkyeH58+cxadIkyGQyqaxv375qk8OioiKcPn0aZ86cwY8//oitW7dypnoiIiKicmCSy8obNmwA8H8TW/fo0QNjxoxRW79p06bw9/eHEAInTpzAgAEDFEYdiYiIiOj5MEly+Ndff0Emk6FFixa4fv06Tpw4gbfeektt/T59+uD27dvYv38/PD09cf36dSxatMgUoRERERGRBkZPDu/fv4+4uDjUrFkTISEheq19OWTIEBw7dgw2Njb4/vvvkZeXZ+zwiIiIiEgDoyeHN2/eBABMnDgR7u7ueu/frFkzBAUFIS0tDWfPnjV2eERERESkgdGTw9jYWMhkMnTr1s3gNvr37w8hBO7cuWPEyIiIiIhIG6MnhxkZGQCeLY1nKA8PDwBAWlqaUWIiIiIiIt0YPTl0cHAAACQnJxvcRkpKCgDA3t7eKDERERERkW6MnhzWrl0bQgicPHnS4DZCQ0Mhk8lQu3ZtI0ZGRERERNoYPTns3r07gGcrpERFRem9f1RUFH766ScAz+ZHJCIiIqLnx+jJoaenJ7p164aMjAz06tULly5d0nnfsLAw9OnTB5mZmejWrRs8PT2NHR4RERERaWCS5fM+//xz9O3bF5GRkXjhhRekpfPatGkDPz8/6V7CzMxMREZG4vr169izZw+OHTsGuVwOmUyGzz//3BShEREREZEGJkkOe/fujRkzZuCbb76BTCZDSEgIQkJCtO4nhIBMJsOHH36IXr16mSI0IiIiItLAJMvnAcCyZcvw/vvvS+srA8+SP1VfxdsAYMqUKVi+fLmpwiIiIiIiDUwycggAMpkMa9asQe/evTF//nzcvn1bbV0hBJo3b47PP/8cL730kqlCIiKiCio7OxsRERFa6xXXiYiIgIWFbn/C/P39YWdnV6b4iKoTkyWHxUaOHImRI0fi3Llz+PvvvxEREYGkpCTIZDK4urrC398fffr0wQsvvGDqUIiIqIKKiIhA+/btda4fFBSkc92wsDC0a9fOkLCIqiWTJ4fFunTpgi5dujyvwxERUSXi7++PsLAwrfUyMjKwZ88eBAYGSosu6NI2EenuuSWHRERE6tjZ2ek0uldQUIDU1FR07doVlpaWzyEyourHZA+klMXvv//OqWyIiIiIykGFTA43bdqEhQsXlncYRERERNVOhUwOiYiIiKh8mPSeQyEETp48ibCwMMTExCAjIwNFRUVa97t586YpwyIiIiIiNUyWHO7cuRMffPABYmNj9d63eKUUIiIiInq+TJIc/vHHH3j99dcBQGGFFCIiIiKq2IyeHObl5eHDDz9USArr1KkDf39/uLq6wsbGRuuo4NGjR/H48WNjh0ZEREREWhg9OTx9+jSePn0KmUyGNm3a4Oeff9Z7ZvrBgwczOSQiIiIqB0ZPDu/cuQMAsLa2xv79+1G7dm1jH4KIiIiITMToyWFWVhYAoHPnzgYnhuPGjeNay0RERETlwOjJYZ06dQAAbm5uBrdR/DALERERET1fRp8Eu3PnzpDJZIiLizN200RERERkYkZPDhs1aoTBgwfj0qVLiImJMaiN2bNno2/fvkaOjIiIiIi0Mcnyeb/88gtq1aqF119/XboHUR83btzAiRMnjB8YEREREWlkkuSwVq1aOH36NCwsLNC8eXOsXbsWUVFRpjgUERERERmRSVZIqV+/PoBnq6NERUVh2rRpmDZtGuzs7ODs7AxLS0uN+z958sQUYRERERGRFiZJDh89eiStgiKTyaTVUrKyspCVlaV1hRSurUxERERUPkySHBZTt64y11smIiIiqphMlhx26tQJkyZNMmjfFStW4NatW0aOiIiIiIi0MVlyWK9ePQQFBRm07x9//MHkkIiIiKgcmORp5bLiZWciIiKi8mGSkcOVK1eiSZMmBu+/bNkyJCcnGzEiIiIiItKFSZLD6dOnl2n/li1bGikSIiIiItKHSZ9WJqKKKTs7GxEREVrrZWRkIDQ0FM7OznBwcNBa39/fH3Z2dsYIkYiIyslzTQ7v3buHqKgoJCcnY9SoUVK5XC6HmVmFvP2RqEqKiIhA+/btda6/cuVKneqFhYWhXbt2hoZFREQVgMmTw1u3bmHlypXYs2ePdB+hTCZTSA7feustxMXF4b///S/69etn6pCIqj1/f3+EhYVprRceHo6goCAEBwejRYsWOrVLRESVm0mTw4ULF+KLL76AXC7X+ARyYWEhjh49imPHjuHVV1/FL7/8AhsbG1OGRlSt2dnZ6TTCV1hYCOBZ0scRQSKi6sFk13JnzJiBzz//XGtiCAADBw5Eo0aNIITAli1bMHr0aFOFRUREREQamCQ5PHToEL799lsAz+YsbN26NaZMmYIlS5aovOw0btw4RERE4JdffoGtrS3++usv/PLLL6YIjYiIiIg0MElyuHDhQgCAn58fQkNDcfXqVaxevRqzZ8+Gn5+fyn1kMhkmTpyI7du3A3g21yERERERPV9GTw4fP36MCxcuwMHBAcePH0ePHj302n/w4MEYNmwY7t+/zyX0iIiIiJ4zoyeHZ86cAQC8++67akcJtXn55ZchhMDVq1eNGRoRERERaWH05PDJkyeQyWQICAgwuI169eoBAJ4+fWqssIiIiIhIB0ZPDjMyMgAAzs7OBreRl5cHACgoKDBGSERERESkI6MnhzVr1gQAxMXFGdxGREQEZDIZ3NzcjBUWEREREenA6JNg161bF0II7Nmzx+D5Cjdt2gQAaNiwoVFiunz5Mnbu3ImQkBDExsYiISEB9vb28PT0RLt27TB8+HAEBgbC2traKMfT5PHjx9i/fz+OHDmC27dvIzExESkpKXBwcICrqyvc3NzQqFEjtGrVCi+88AI6duwIKysrlW316tULoaGhBsVx9OhRrkZTBUVFRSExMdFo7RWvvxwREQELC+P9unBzc4Ovr6/R2iMiIuMxenLYs2dPWFtbY+vWrXj99dcxZMgQvfZfunQpLl26BHt7e3Tr1q1MscTExOCDDz7Ajh07pDIzMzPUqlULqampuHPnDu7cuYPNmzejQYMG+O677/Diiy+W6ZjqpKamYvHixVizZg1yc3OlcktLS3h4eCAzMxP37t3DvXv3cO7cOWn7rl27MGLECJPERFVLVFQUmvg3RW5OttHbDgoKMmp7NrZ2uBtxhwkiEVEFZPTk0NbWFq+99ho2bNiAl19+GR9//DGmT58OJycnjfs9evQI8+fPx2+//QaZTIbx48fD0tLS4Dju3buHPn36ICYmRirr0aMHfv/9d3h7eyM/Px/Lli3DvHnzAAAPHjzAsGHDsHbtWkyaNMng46oSGRmJAQMG4J9//pHKWrRogaVLl6J///7SyGBcXBxWrVqFZcuWQS6XGzUGqvoSExORm5MN16EzYenqY5Q2RWE+CtOewsLJEzIL1SPY+ipIikbS/hVITExkckhEVAGZZG3lzz//HDt27EBGRgYWLlyIr776Cj179kTbtm0RGRkJAFi1ahUyMzMRGRmJsLAwadoaIQRcXV2lpM0Q6enp6Nu3r0JiWDyaWbt2bQCAlZUVPvnkE5w5cwYHDx6Ujj158mR4enripZdeMvj4JSUkJKB79+4KsbRt2xYnT56Evb29Ql0vLy8sXboUPj4+mDp1qlGOT9WPpasPrGsZ55YMAIB3M+O1VckUJEUbrS1jJ9rGjI2IqCSTJId16tTB9u3b8eKLL6KoqAg5OTk4cuQIjhw5AuBZEvbhhx8q7FO8/rK1tTV27twJDw8Pg48/Z84cREcr/uLs3r27lBiWNHr0aCk5LDZ16lT06dNH62inLqZMmaKQGALA6tWrlRLDkiZPnoxvvvkG//77r07HOH78OHr16lWWMImoBDc3N9jY2iFp/4ryDkUjG1s7PrhHREZnkuQQAPr374+///4bY8eOVXpyWSaTqdzH29sbf/75Jzp16mTwcWNiYvDjjz8qlbdo0UJl/ZYtWyqVxcXF4fvvv8ecOXMMjgMAQkNDpeUAizVo0EDrvZRmZmZ48OBBmY5NRIbz9fXF3Yg7Rn24Jzw8HEFBQQgODlb7+0hffLCHiEzBZMkh8Gy0LiIiAmvXrsW6detw7949lfWaNGmCt99+G5MmTUKNGjXKdMxff/1V5f163t7eKuv7+Ki+N2vjxo1lTg5VJak9e/YsU5tE9Hz4+voaNfEqLCwEAPj7+6Ndu3ZGa5eIyNhMmhwCgL29PWbNmoVZs2YhLi4OERERSEpKAgC4urqiadOmKi/3Gmr37t0qy11dXVWWF8/LWNrdu3dx584dNG3a1KA4srKysGvXLqXyxo0bG9QeERER0fNg8uSwJC8vL3h5eZms/YKCAty4cUPlNkdHR5XlFhYWsLOzQ3a28vQfYWFhBieHV65cUZiyppibmxtyc3OxY8cOHD16FBEREUhPT4eDgwP8/PzQu3dvvPrqq3qvMBMREYH169fj+PHjuH//PjIzM+Hk5AR3d3d06NABffr0wdixY2Fra2vQ+RAREVH1YPQVUp4+fYr69etLXw0aNMDevXuNfRiVIiIipKX3SrOzs1O7n7pt165dMziWsLAwleUnTpxA/fr1MW7cOAQHB+PChQu4c+cOLl68iO3bt+P9999HvXr18MMPP+h8rIULF6J58+ZYvnw5oqOjYWlpicLCQiQlJSEiIgK//fYbJk6cCG9vb/zvf/8z+JyIiIio6jP6yOHVq1fx6NEjyGQy6QnkzMxMYx9Gpfj4eLXb1K0yommbpva0uXv3rsryzZs3w8zMDMuXL8dbb70FIQR++uknzJ07V+qv1NRUTJ48GTExMfjiiy+0His0NBQffvghPvroI+kS/cOHDzF37lxs3bpVqpecnIypU6fi5MmT+P3332Fubq617by8PIWEOz09HcCzUdqKuvZ1cVwVNT5TKb6nrbIoLCysVj+jku/L6nTexlZdP9+mwL40nsrQl/rEZvTk8NGjR9L3b7zxBhYsWIC6desa+zAqpaWlqd2mKRFSt604ETJ2LBMnTsTMmTOl17Nnz0ZERAQ2btyoUG/x4sXo2rWr1lVm1q9fj/HjxyuU1atXD1u2bEFubi727NmjsG3btm1wd3fHmjVrtJ7HkiVLsHDhQqXyI0eOaByNrQiOHj1a3iE8V5XtCffTp0/j8ePH5R3Gc1P887lw4YJRn4Kurqrb59uU2JfGU5H7UtXtc+oYPTlMTU0F8OxJv/Xr1+s0OmUs+px4SWZmqq+ul2XEU1Ny+PrrryuVjRs3Tik5BIBPPvlEbXIYEhICQH1yK5PJ8PXXXyslhwCwdu1aTJgwAe3bt1cbJwDMnTsXM2bMkF6np6fDx8cHAwYMUHsfZ3krKCjA0aNH0b9//zKtslPZFE8kX1l0794dbdu2Le8wnpuLFy8CADp37lym6bqqu+r6+TYF9qXxVIa+1GfAy+jJYfHTv61bt36uiSGg+b5CTdQtVadpompt8vPz1W5T9QdR3dQW165dw61bt9C8eXOlbbr0b+PGjdGyZUvcvHlToVwIgf/9739Yv369xv2tra1hbW2tVG5paVlhPwDFKkOMxmRh8VyfLyszCwuLavXzKT7X6va+NBX2o/GwL42nIvelPnEZ/YGU+vXrA4DKJ3VNTdNIVlFRkd7byjIypm7fGjVqqFx5xcXFRW1ye+bMGYPjAJ4l6qocOnSoTO0SERFR1WP05LBXr17w8PDA5cuX1Y7IaTN48GCDRkE8PT3VbtM0kqduW1mW8FO39J6mhNPBwUFleWxsrMFxAOr75fHjx+WSxBMREVHFZfTk0MLCAp988gmSk5OxevVqg9spfnJXH/7+/iovgQKa70dUt61NmzZ6x1CseAS1NE3Duuqems7IyDA4DgAa5zZMTk4uU9tERERUtRg9OQSAadOm4d1338V///tfvebrKytLS0uVayUD6m/ELCoqQk5OjsptZVniqkOHDirLNU03ou4xc30nxC5NU2Jc1raJiIioajHJHewnT57Ea6+9hqKiIkyZMgXfffcdXn75ZbRu3Rqurq5ab4osy2hWYGAgLl++rFRevGSfqmOpGqVs1KgRmjVrZnAcL7zwAqytrZUm5db0BHRWVpbKclXruwYFBeHp06dYv3691lVnnjx5orLc3d29wk9HQ0RERM+XSZLDXr16QSaTAXh2efju3btYunSpzvsLIaT99RUUFIT58+cr3e+o7r696OholeUTJkxQWf7DDz9gxYoVSEhIQEBAAFatWgU/Pz+les7Oznj55ZexZcsWhfL09HRkZ2crJWVZWVlqLx/36tVLqSw0NBSRkZGIjIzUmhyqW+llwIABGvcjIiKi6sckl5VLkslkBid6hvDx8cHbb7+tVF56Kpdit27dUiqrVasWJk+erFS+bt06TJ48Gffv30daWhr27t2LgQMHqr0sPWPGDJVzKIaHhyuVqVsTumfPnhonET958qTa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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# checkout seed 0\n",
    "diffs = []\n",
    "for budget in budgets:\n",
    "    score_mom = scores_momentum[budget]\n",
    "    score_up = scores_updated_grad[budget]\n",
    "    # convert to numpy\n",
    "    score_mom = np.array(score_mom)\n",
    "    score_up = np.array(score_up)\n",
    "    # squeeze dim 1\n",
    "    score_mom = score_mom[:,0,:]\n",
    "    score_up = score_up[:,0,:]\n",
    "    # get the average over axis 1\n",
    "    score_mom = np.mean(score_mom, axis=1)\n",
    "    score_up = np.mean(score_up, axis=1)\n",
    "    diff = score_mom - score_up\n",
    "    diffs.append(diff)\n",
    "# convert to numpy\n",
    "diffs = np.array(diffs)\n",
    "# plot boxplot of the differences with pretty fill colors\n",
    "medianprops = dict(linestyle=None, linewidth=0)\n",
    "plt.boxplot(diffs.T, patch_artist=True, showfliers=False, showmeans=False, medianprops=medianprops)\n",
    "# fill the boxes with colors\n",
    "# colors = ['lightblue', 'lightgreen', 'lightpink', 'lightyellow', 'lightgray', 'lightcoral']\n",
    "# for patch, color in zip(plt.gca().patches, colors):\n",
    "#     patch.set_facecolor(color)\n",
    "plt.grid()\n",
    "plt.xlabel('Evaluation Budget')\n",
    "plt.xticks(range(1, len(budgets)+1), budgets)\n",
    "plt.legend()\n",
    "plt.ylabel('Difference')\n",
    "plt.title(f'Cosine Similarity')\n",
    "plt.savefig(f'../figs/{dataset}_similarity_{mode}.pdf', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dv_dp",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
