{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "import sys\n",
    "sys.path.insert(0, '../')\n",
    "sys.path.insert(0, '../datasets')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_dir = '../results/q_value/'\n",
    "dataset = 'covertype'\n",
    "budget = 1000\n",
    "num_players = 800\n",
    "seeds = [0,1,2,3,4]\n",
    "eps = 1.0\n",
    "model_name = \"logistic_regression\"\n",
    "utility = \"negated_loss\"\n",
    "flip_ratio = 0.3\n",
    "metric = \"shapley\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_loo_mnist_cnn_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_0.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_2.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_no_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_0.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_accuracy_seed_1.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_3.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_0_no_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_accuracy_seed_4.npy',\n",
       " 'scores_loo_mnist_cnn_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_2_use_momentum.npy',\n",
       " 'scores_loo_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_3_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_accuracy_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum.npy',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_accuracy_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_16_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_1_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_200_num_players_800_utility_negated loss_seed_2_use_momentum.npy',\n",
       " 'scores_banzhaf_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum.npy',\n",
       " 'scores_beta_alpha_4_beta_1_covertype_logistic_regression_no_dp_budget_200_num_players_800_utility_negated loss_seed_0.npy']"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "os.listdir(results_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_names = []\n",
    "\n",
    "for file in os.listdir(results_dir):\n",
    "    if file.endswith('.npy') and dataset in file and f\"{metric}\" in file and f\"budget_{budget}_\" in file and f\"players_{num_players}\" in file and model_name in file:\n",
    "        if not \"utility_negated loss\" in file:\n",
    "            continue\n",
    "    # if file.endswith('.npy') and dataset in file and f\"{metric}\" in file and f\"utility_{utility}_\" in file  and f\"budget_{budget}_\" in file and f\"players_{num_players}\" in file and model_name in file:\n",
    "        if not (\"no_dp\" in file or f\"eps_{eps}\" in file):\n",
    "            continue\n",
    "        f = '.'.join(file.split('.')[:-1])\n",
    "        exp_names.append(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_0',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_1',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_2',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_3',\n",
       " 'scores_shapley_covertype_logistic_regression_no_dp_budget_1000_num_players_800_utility_negated loss_seed_4',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_no_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_0_use_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_no_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_1_use_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_no_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_2_use_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_no_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_3_use_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_no_momentum',\n",
       " 'scores_shapley_covertype_logistic_regression_warmup_0_eps_1.0_delta_5e-05_budget_1000_num_players_800_utility_negated loss_seed_4_use_momentum']"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp_names.sort()\n",
    "exp_names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "scores = {}\n",
    "scores_no_dp = {}\n",
    "scores_no_mom = {}\n",
    "\n",
    "for seed in seeds:\n",
    "    for exp_name in exp_names:\n",
    "        if 'scores' in exp_name and f\"seed_{seed}\" in exp_name and metric in exp_name:\n",
    "            if \"no_dp\" in exp_name:\n",
    "                scores_no_dp[seed] = np.load(results_dir + exp_name + '.npy', allow_pickle=True)\n",
    "            elif \"no_momentum\" in exp_name:\n",
    "                scores_no_mom[seed] = np.load(results_dir + exp_name + '.npy', allow_pickle=True)\n",
    "            else:\n",
    "                scores[seed] = np.load(results_dir + exp_name + '.npy', allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "ys = []\n",
    "y_error = []\n",
    "num_data = num_players\n",
    "num_flipped = int(num_data * flip_ratio)\n",
    "partitions = np.arange(0, 1.0, 0.01)\n",
    "warmups = [\"no_dp\", \"iid\"]\n",
    "for partition in partitions:\n",
    "    warmups.append(partition)\n",
    "flipped_idx = np.arange(num_flipped)\n",
    "\n",
    "for i, warmup in enumerate(warmups):\n",
    "    cur_y = []\n",
    "    for seed in seeds:\n",
    "        if warmup == \"no_dp\":\n",
    "            cur_scores = scores_no_dp[seed]\n",
    "        elif warmup == \"iid\":\n",
    "            cur_scores = scores_no_mom[seed]\n",
    "        else:\n",
    "            cur_scores = scores[seed]\n",
    "        if warmup != \"no_dp\" and warmup != \"iid\":\n",
    "            cur_scores = cur_scores[int(len(cur_scores) * warmup):]\n",
    "        cur_scores = np.mean(cur_scores, axis=0)\n",
    "        lowest_idx = np.argsort(cur_scores)\n",
    "        # check how many of the lowest indices are in the flipped indices\n",
    "        # compute the AUC with different ratio of indices checked\n",
    "        auc_partitions = np.arange(0, 1.02, 0.02)\n",
    "        tpr = []\n",
    "        fpr = []\n",
    "        for partition in auc_partitions:\n",
    "            num_correct = 0\n",
    "            for idx in lowest_idx[:int(len(lowest_idx) * partition)]:\n",
    "                if idx in flipped_idx:\n",
    "                    num_correct += 1\n",
    "            tpr.append(num_correct / num_flipped)\n",
    "            fpr.append((int(len(lowest_idx) * partition) - num_correct) / (num_data - num_flipped))\n",
    "        # compute the AUC\n",
    "        auc = 0\n",
    "        for i in range(len(tpr) - 1):\n",
    "            auc += (tpr[i] + tpr[i + 1]) * (fpr[i + 1] - fpr[i]) / 2\n",
    "        cur_y.append(auc)\n",
    "    ys.append(np.mean(cur_y))\n",
    "    y_error.append(np.std(cur_y))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "from notebooks.utils import set_up_plotting\n",
    "plt = set_up_plotting()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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j/XDUVZWlnjwwQeFwWBwe99BgwaJL7/80us8gxVbkFqZ9u3bY+TIkQCAHTt2oLy8HLGxsbjqqqvs54SGhjZV8RrFxYsXkZeXZ3/uTSsMAJcB4o7r7TT3vFszIQQ2bNjglDZq1KhGL0dpaSn27Nljf969e3cYDIZ65enN/+UzZ87g1ltvtdeLK664AlOmTEGvXr1QU1OD/fv3Y/HixTh58iQefvhhrFixAp9++inatGljz6Nt27YYOXIkzGYz/u///s+e3qNHD3Ts2BGAaz0EpLFSFy9eRGVlJbZt2wa1Wo0bb7xRsewFBQUYO3YsduzYAUBa5+mRRx5B7969YbFYcPjwYSxZsgQHDx7ECy+8gI8//hgbNmyw399Gr9fjnnvusT+Xr602depUvPPOO2jTpg1uvPFGhISE4JdffsHZs2ed3lfb52hhYaHT782WLhcaGoqBAwciJCQER48exenTpwFI3eA33HADACAhIcHlOsfP7IMHD+LcuXPo1q0bOnfujL59+9rfewD299GmqKgII0eORHFxMWbOnIlBgwYhJCQEmZmZWLx4MX755Rd89dVXSE9PxzfffIOrr75asew2mzZtwp133onS0lKoVCrcc889GDt2LJKTk1FcXIytW7di8eLF2L17N26++WZMnz4db7zxRvOdMNDUERoFljfT/C0Wi319lU6dOomjR496zNObvw79ffi7FIFjHr62IO3YscPp+hdeeMGr66qrq52uu/HGG1tM3o0lGFuQ5syZ43TN+PHjA1omb23cuNGpHPfcc0+D3zMvL0+kpqba7/nQQw8Jk8nkcl55ebkYNWqU/bwrr7zSbevWoEGD7OfdcsstXpXjP//5jwAgbr31VsXjlZWVol+/fvZ8J0yYoFjOmpoa8eCDD9rP69mzpygvL/d4b8f3fMqUKUKj0Yg33njDKf/q6mpx//33K7by+DPN/+uvv3a6Zs+ePXVeYzKZRPv27QUAsW/fPsVz5C1bV155pejXr5/iEhHV1dVi/Pjx9nNjYmJEVlaW2/tv375daLVaAUitm+vXr1c87+TJk6JTp072fP/617/W+dqCVTMN68hf1dXVGD9+PN58803069cPO3fuRLdu3Zq6WI2qtLTU6XlYWJhX1+l0Omi1tY2u8nyac96ticViQUFBATZv3ox77rkHzz//vP3YqFGjsHjx4iYpl3ys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eQMGDLAfe+CBB+osq2M3ByB1Ddiud/xCP3jwoNN5gW5ps8nJyXGq70lJSWLatGnio48+Ehs3bhRbt24Vq1evFn/5y19E79697ee1bdtWfPLJJ17d48yZM06foZdffrmYP3++2Lx5s9i4caN47bXXnD4rhg8fLgoLC316HRaLRXTr1s2eR3p6us/vRVFRkbjhhhucXuOf/vQn8dlnn4nt27eLzz77TDzzzDOibdu29j8KfvzxR8W8HnjgAcXPEsf64ilAlnv44YftefTr10+sXr1afPPNN06tkh9++GGd+axcudKpPNu2bfO6DEK4Bkjff/+9SE5OFgkJCeKll14SX331lfj222/Fv//9b3H55Zfbz4uMjBQ7duyoM/8tW7bY31/b+zVv3jx7XVy2bJnIyMgQKpVKABA333xzs/rDW87vAGnOnDn2L2O1Wi0efvhh0b9//0YNkEwmk7jyyitd7rdv3z6Xc6dNm+Zy3ptvvtkg5Wpstm4Hb75Q5P+B3D08dds0tokTJ/r8Bepr+VeuXCl69OihmFdISIi4//77RW5url/lb05533777fbr//jHP/pVJjlv6md9AiRv8+/YsWOdZT1x4oTLH1O2x9q1a+3nzZs3z57ev3//gLxPnmzfvl2MGTNGhIeHe3yNXbp0EX/7299EUVGRT/lXVFSIOXPmiISEBLd5d+rUSbzzzjuKLUzeePvtt+15+TvusaamRixZskR06dLFbTnDw8PFI488Ii5evOg2H8eWdk8Pb5WUlIjf//73innodDqvx02ZTCbRvn17AUBcccUVXt/fRv75furUKXHx4kVx++2327s25Y+RI0eK3377zet7nD9/Xjz++OMe62JaWppYtGiRy3is5kYlhA8rRDno1KkTzpw5g4EDB+Lf//43rrrqKlx33XWKi6wtXbq0QWYrvfbaa3juueec0tLS0pyW0LfZsmWLy4yL8PBw/Prrr+jUqVPAy0bN008//YRff/0V58+fR3h4OFJTU3Hdddd5tU9Vc8+7qKgIKSkpqKiogEajweHDh9GtW7d6l60l+t3vfmff3+u9997DlClTGuW+1dXV2L17N06fPo3c3FwYjUZERUWhffv26NevX73XTBJCYN++fThw4ADy8vKg0WgQHx+PK6+8MugWGM3MzMTevXvt70NMTAx69uyJgQMHOi3b0Jh+/fVX7Nq1C7m5udBoNOjQoQOuv/56n1bAHj58OLZs2eJXvTp9+rRTHTh16pT9++3ixYvYunUrzp07B6PRiOTkZAwbNgwdOnTw6R42RqMR33//PY4fP478/HzodDokJCSgf//+LWetNX8jqwEDBoj33nvPqQ/S3V9yDdGCVFFRIaKjo13ulZGRoXh+fn6+YtkeffTRgJeNqDmaNGmS/f/FjBkzmro4QWvZsmX292ngwIF+t6gQyR09elSoVCrRtm1bUVFR4fP1Si1I5D+/10Hatm0bpkyZ4rLWTmNZu3at4rod8l2cbWJjY+3rTDj6+OOPUVlZGfDyETUn//rXv+wrOA8fPhz//Oc/m7ZAQWrLli32RfuSk5PxySef1LmOD5G3Fi1aBCEEHnroIcXvK2pcfgdIISEhgSyHz9atW6eY7mk3ZqVjJSUl2LJlS4BKRdT8/PTTT/jTn/4EQNr24PPPP4fBYGjiUgWfiooK3Hfffbh06RK6du2KrVu3snuefPbrr7/iv//9r8smsGVlZVi2bBk0Go3TytrUdJrtStp79+5VTI+KinJ7jbtjvqwMStTSpKen4/3338cbb7yBzz77rMnGbwS7sLAwfPHFF3j88cexd+9ely0ZiLyxbt063H///fj888+d0l9//XUUFRXhrrvuQseOHZuodOSoWbYNl5aWut2oMywszO117o61tN2hiXw1ceLEpi5Cs9CvXz/7NhlE9fHCCy9ArVYjNTUVmzdvxpw5cxAeHo7Zs2f7lM+BAwfw7LPPAoDLcJGJEyfau+pee+01XH755YEpfCvRLAOkvLw8t8f0er3Px3Jzc+tdJiIiIm/l5OQ4/WESFxeHDz74AGlpaT7lU1hYiG+++UbxmOMedM8//7x/BW3FmmWA5GlTRY1G4/Ox0tJSj/czGo0wGo325xaLBYWFhYiNjW2yQepERNT8TJ06Fddccw0OHTqEgoIC6PV6dOjQASNGjEBoaGid30dy6enpXm00DNT9XdcaCCFw6dIlJCcn2zdud6dZBkgVFRV+XefuzSgrK/N43SuvvIKXXnrJr3sSERFRcMnKynI7692mWQZInsYZeWKxWBTTIyIiPF43c+ZMzJgxw/68pKQEHTp0wKlTpxAZGelXWdwxmUz47rvvMHz4cOh0uoDmTc0f6wfVhXWE6tKa68ilS5fQuXNnr767m2WA5Gmmmtls9vmYp/wAwGAwKE57btu2bZ3X+spkMiEsLAyxsbGtruJS3Vg/qC6sI1SX1lxHbK/Xm+ExzXKaf3x8vNtj1dXVPh/zlB8RERG1Ps0yQIqKinK755Cn8UnujvXr1y8QxSIiIqIWolkGSABw5ZVXKqZ7GqV/6dIlxfT09PSAlImIiIhahmYbIGVkZCimy5dvr+tYVFQUhg8fHrByERERUfMXdAHSokWL0LVrV8TExCAjIwNnzpxRPO+OO+5QHCCdk5OjeH5hYaFiF9u4ceO4KSARERE5CaoAacmSJZg2bRqOHz+OkpISrF+/HiNHjnRZPh0AQkNDFVcGPXjwoGLehw4dckkLCwvj6qJERETkIugCJLmjR49i+/btiuf/6U9/Qv/+/Z3STpw4gZ9++snl3JUrV7qk/eMf/3A72JuIiIhar6AKkNxxt16BVqvFV199hd69ezul33///Thy5AgAaXHIZcuWYdGiRU7nPPPMM06LPxIRERHZ+B0grVmzBl26dHF67N69W/Hc5557zuVcJQ8//LBLWo8ePTBkyBC35UhISMDWrVsxZcoU+1Yihw8fRq9evZCcnIw2bdpg8uTJqKmpASCtebRkyRK8/vrrvr5kIiIiaiX8Xkm7tLQUJ06c8Orc3Nxc5Obm1nne5MmTYTQaMXfuXOTn52PYsGGYN29enYOoY2Nj8d5772HGjBn49NNP8c033+Ds2bPIy8uDwWBAly5d0KdPH4wePRp33nlnwFe/JiIiopbF7wBp0qRJmDRpUgCLIpk6dSqmTp3q17W9evXCX//6V/z1r38NcKmIiIioNWkWY5CIiIiIGhMDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERER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iIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCTDAImIiIhIhgESERERkQwDJCIiIiIZBkhEREREMgyQiIiIiGQYIBERERHJMEAiIiIikmGARERERCSjDVRGe/fuxZo1a7B582bk5OQgLy8PERERSEhIQHp6OsaMGYOMjAwYDIZA3dLFwYMHsWbNGuzevRtHjx5FQUEBysvLodPpEBkZic6dO+Pyyy/Hrbfeit///vfQ6/UNVhYiIiJqvuodIGVnZ2P69OlYvXq1PU2tViMxMRHFxcXIzMxEZmYmli9fjrS0NLz99tu45ZZb6ntbJzk5OXj00UfxxRdfuByLj49HcXExcnNzkZubi927d+Pdd99Fp06d8Pbbb2PMmDEBLQsRERE1f/XqYjt27BgGDx7sFBwNHToUZ86cQU5ODoqKijB79mz7sRMnTmD06NFYtGhRfW7rJDs7GwMGDHAJjvr06YPjx4/j4sWLKC8vx6uvvup0/PTp0xg7diyWLFkSsLIQERFRy+B3gFRaWoobbrgB2dnZ9jSDwYBPPvkEKSkpAAC9Xo9Zs2Zh1KhR9nOEEJg2bRrWrl1bj2LXeuKJJ3D+/HmX9Dlz5iAtLQ0AoNVq8eyzz6J///5O5wgh8OSTT+LMmTMBKQsRERG1DH4HSM8//zyysrKc0oYMGYKkpCSXc++++26XtCeeeAIlJSX+3h4AUFhYiA0bNigeGzBggEvawIEDXdIqKyvx3//+t17lICIiopbFrwApOzsb77zzjkt6nz59FM/v27evS9q5c+ewcOFCf25vd/LkSZjNZsVjbdu2dUmLjY1VPHf//v31KgcRERG1LH4FSB9++CEsFotLuq1rTS41NVUxfdmyZf7c3isqlcqrNEDqLiQiIiKy8StAWrdunWK6uxYapdYcADh69CgyMzP9KQIAoHfv3ggNDVU8VlhY6JJWUFCgeG6HDh38LgMRERG1PD4HSCaTCQcOHFA8FhUVpZiu1WoRFhameGzfvn2+FsEuNDQUf/jDHxSP7d2716s0ALjzzjv9LgMRERG1PD4HSEeOHIHRaFQ85i4I8nSsvuN/Zs+ejQceeMAl/fnnn8fJkycBAGazGW+88YZigDR+/HiMHDmyXmUgIiKilsXnhSJzc3PdHvO0MrW7Y57y84ZWq8UHH3yABx54AAsWLMCmTZtQXl6OAwcOIC0tDfHx8SgpKXEJ6vR6PZ5++mn84x//qPMeRqPR6XrbmCWTyQSTyVSv8svZ8gt0vtQysH5QXVhHqC6tuY748pp9DpA8Tc3XaDQ+HwvUAGmNRoOoqChER0ejvLzcni4PwEJCQjBt2jT86U9/UlySQMkrr7yCl156ySV948aNHlvN6mPTpk0Nki+1DKwfVBfWEapLa6wjFRUVXp/rc4DkS+aO1Grl3ryysjK/8rO5dOkSHnjgAZeB4zfddBNee+019OzZE8XFxfj444/xzDPPoKqqCm+++Sa2bduGZ555BuPGjavzHjNnzsSMGTPsz0tLS5GamoqbbrrJ7bgrf5lMJmzatAk33ngjdDpdQPOm5o/1g+rCOkJ1ac11xJdGGZ8DJH9bTJSWBQCAiIgIv/IDpLFFN998M3bs2OGUnpCQgHXr1tlnuMXHx+MPf/gDCgoK8Pe//x2ANDh8/PjxWLt2Lf773/96rCQGg0Fxk12dTtdglash86bmj/WD6sI6QnVpjXXEl9fr8yBtTy0m7hZt9HSsPi0wixcvdgmOAGDMmDGK0//Hjx/vkrZy5Uo8//zzfpeBiIiIWh6fA6SEhAS3x6qrq30+Fh8f72sR7N577z3F9F69eimmd+vWDVqta6PZ/PnzkZOT43c5iIiIqGXxuYutR48eMBgMilP9PY1PcnesX79+vhYBgDSz7JdfflE8FhcXp5iuVqvRtm1bl4HbJpMJX3/9NaZMmeJXWYiIiFoVSw1QUwZUFwLGQsBYAFQXAKYSwFwFmI3ST4v1p7my9qfFFj+oAJVa+qkNB6J6AnGDgLZXArrAju/1h88Bkk6nQ9++fRXXFHI3+MlsNqOyslLxWHp6uq9FACCtlO2u205pvFBdx44fP+5XOYiIiFoES40U6BjzgKqLQNkpoPwUcOk4UHYSqMoFasqlh6WqAQuiqg2WYgdKj5i+gLpxx0v5HCABQEZGhmKA5G4rj8LCQgghXNK7du3qtjusLp4Gi3vq6nO3yKW7QeRERESNytY6Y6mW/i2sj5oKoOoCUHleelRkS0FLdTFgKpZ+1pQBar3UImN7aMIAjQFQGwCNAWpocGXVUWi2zgdMhUB1kfQwlQJw/a5ufAIoPSw9Ti6VkjQhwBX/BHr8sdFK4VeANHHiRLz44osuQYW7cTxZWVmK6ZMnT1ZMX7RoEd544w3k5eVh2LBhmDdvHjp27Oh0TnR0NGJjYxWDsvz8fMV8LRYLioqKFI+521CXiIjIZ0JIwcyl41JrTHWRcyBjKgGqS6SfphIpODFdaoTWGUADIAUA6rdOc+MyVwEh7sdANwS/AqTU1FQ89NBDWLx4sVP6wYMHFc8/dOiQS1piYiKmTZvmkr5kyRKn9PXr1+Po0aP4+eefXWam3XbbbYoDtY8cOaJYjhMnTrhdRXPUqFGK6URE1IqZq4HKHKD8rPSzprK2Rcdikr64a8qswY11TM6lE0D5SSnYocCJHdiot/MrQAKA1157DV988YVTq9GOHTtw/vx5lxWqV65c6XL9ggULEBMT45K+ZMkSl7SjR49i+/btuOmmm5zSZ82ahRUrVjitnA0AX3zxBWpqalxmrK1Zs0bxtdx7771IS0tTPEZERPVgMQPCJLWoqDSAWmsdmGslBCDMgLAAcOyVUFmPW9OF9QFRe0xlO8dc2xVlqZGe29LNlVLrjLEAMObXDiY2V0oDiS3V1p9VteNraiqkn8Y8KeAJim6nVk7fFoho3O9pvwOk6OhobN68Gddffz3OnTsHQBrfM27cOCxfvhwpKSmorq7Gv/71L2zYsMHp2vnz5+OOO+7w6X4q238EB506dcKKFStw9913o6qqtkkyKysLDz74IN5++220adMGQgisX79ecd+1wYMH49///rdPZSEialaERQoc5MGJ7ZjZ6DDbqKp2tlFNOaSgRW29zvpTrbH+WyM9hDUIMhul4MJSBdRUST8tNQDM1gDJ4Rq1zho81ViDH5O1m8mh68litMYmQnoIizWgsZbR4jBbyvG5xRr4CPdr81EzEzuwNiBuJH4HSADQvXt37Ny5E0899ZR9q49t27ahY8eOSEpKQlFRkdP0/s6dO+Ott97CmDFj3Ob58MMPY+fOnU5pPXr0wJAhQxTPHz16NHbu3Ik//OEP2L59uz39o48+wooVK5CUlITS0lKXPeRCQ0Mxffp0/OUvf1FcVJKIqFkRwjqQ1zpjuCIbsFySWk0qz0tBg0oDqHSARi8N2DVXAeYKqatImACz9aedWvpSsliAmkvSw1QOWCql62qsU7btrTsWqRzmSuu5l6Sgx1wBqLTS4GHbA7AOQjZZfxrBlhpyq5G714B6BkgA0KFDB6xduxZ79uzB6tWrsXnzZuTk5CAvLw9hYWFITU1Feno6xowZg7FjxyIkJMRjfpMnT4bRaMTcuXORn59vH6TtKYjp168ftm3bhv3792PNmjXYu3cvMjMzUVRUhHPnzkGn06Fdu3ZISUlB3759MXz4cGRkZKBNmzb1fflERIFhC3AcZy05tbCYAVhbgmytJaYyKQCpKa9tMamxAIgDstYBGosUmNhmMZmNQE0xIIzSNbYuJls3U025NbAprR08XF1snd1Uz5m+wuyw/g21WNoIacaZWicF5FBb66AB0IRKD22Y9ZiVMNeO23IndlCDF12u3gGSzYABAzBgwICA5DV16lRMnTrV5+v69evn98KTREQBZQtqbA9LtdT9ZK6sHeNSU+68gJ5jMOT4E47jb2p/QK2xtsZorAFVNWCqRmLNCaiLzwKV2UDFWWkquKWKXU7kIxWgiwYMsUBIPBCSJP00xEljggxtpX+HpQKhyYA+RurGlbPUWFsv6+giqy4B8n4AcrcCBbuAkkNSCygAxAYmvvBFwAIkIqJWyVwNmMut42ZKpUG9VReloEce7FiM1ueQvixUWuu4INvDGvCoNLVjhWrKpKnhRutaNcZ8afCw7Wd1sdO0cB2AQQBwttHfCWpM2nBAGwXoIgBNBKCPkp4bYqXj5nKpO9RsaymssQ6Wr4HFXIPcygjER2uh1oYB2lCplVEXLQU+YUlS0BPWQQqCtBGALlI6x59xQEpBkxJ9NNB+lPQApFbVimyg+BcgpJ3v960nBkhE1PpYahzG3jgGMTW1XU62bidhtgYvtoHKKuvMqGIpKLLNhjJXQop8NNIXjkpnHdBssF5rHYOjUktdV0ZrIGUPdvKlYMg+k8o6dby+XVsUHNT62u4lTbgUdNgWctRFWv8d6ZAeIdUjtV6qS2rrQx8LhMQ51Cu1NbiJkPKXD8IHnGcACjPM1Sbs3vgtbr72Wqh1GikQgbCWMUQ5j6agUgHhqdKjCTBAIqKWyWyUBRzlUmtLdZF1zI7RoUtLQLEbyz6NXNhnlktU0heUbcCxvg2gTgJqSoGqPKD8jHVhQIdViu2PYjDoacZUmtrWPpXW2s1prQu21ap1UUBoeyCqOxDTR9o2wxBnHYcTYj2/Eb9+7cE9AOgArXX8jy4C0DXu9h3NCQMkImo+zFXS+B1hhvTXsG36d400YNlcbu2KKnAY32OsPdfxS0wbZf2SUjl8gag9dyEIi9TiU5EtLRpYkS3NEDPmSYGRUF6IloKJ2tpdFOIQ6NiWHnCoH2q91IKjt42/SQYi04DQRKmlxhYca/QOLYwOSxhoI4KnJYb8wgCJiJqW2TrF27Z+jeNif8I6Y6u6SFrgr6bMOrbHuq5ObSbSVHQVrNPYQ6SHPs59l4EQUjebfQHBfMCYKwU6tp+mEodgzKF1iRqBNZCBLGDVGKyz8kJrW2M0htruIbUtYLG27ti6NrXhUiuOIVZq8TPEOY/1gnV9J7XO4XqdQ3dXGAOeVoYBEhEFji2YqS6Sxvc4Li4IVe1ihDVl1unk1kUFLabaQaQWc+13om3RZJXWGvRY/6K3z4ixraisdp42DFh3Js8FSnKAqvPSmJ/qAutP68Nc2VjvTMuj0lnHvYRbB5pran8PaoM0o0nfBtDFSIN/bTP5bMEwLIA6xLnFRhcBqEOlVhmoreO/4LR4ttO/bWs62VpubItXavTWoMYa2KgN1rE+UdJDY2jsd4uaIQZIROSexVy7/o59ILPF+YvOYpRmy1Sdk1pjTGV1dDWpav86V+ukLzltiMNzjftLbTO67Cs/WwdHVxfXBj3VhVK3V9UFTmv3hTrEOiYl2hpIRFtnNcXUBjr6NtIxbYR0jbnSujyBxbWb0j7I3aEu2IIbxyDHiaq2xSYkQRqMDDWcthpRqWrX07G3ItmCJFtXV+OuuEwtEwMkotbIYqpdj8dsXZPHdElq+bEvHmhyCI5sM2Csa/LY99dyGGysDpG+2MLa166U7Cthti58WFa7F1bZSaDslPSozg/Ai28dhEoHVVgKEN7ROl071qG1xtotZQtGNGHuBw0Li7WO2PYns+5lZpuVpYuS/i1MtXVGCGl6uK6NNHXblr/julDC4jz+x7aYoC5a6lpjdxY1MQZIRC2RbWdxx721asqtqyOXSsGRxbp3lsVk/WveNjNLC3u3mEoDwDYuw6F1wL5+j4fWHjlzVe1mobYxP9UFDuv6WMcYkXsqrXX8TDvpERIn/dRG2rsgTaoQbPktHNf1bwedbMNuezeXuap25W3bqtm2Fhp7UIzaeqENldbaie4gjd3RRVmnpkdKx5zuYZ0VqPahbhAFIQZIRM2dxWydvVUAVOUDFVlS0GFbmdlO7bwXljYUMOj9b+2RM10CLh0Dyo5LKzfbtqqwfQHXlAfmPi2NWl8b8OjbOK+Po42wdnG1lVqAlGZGOS5RICxAjRkV6hDrWLCq2oHvAABV7VRzTVjtDCxb16Za5zBDS2vt/gyXWoG0Ud4FPSq1m+4zouaFARJRsBMWh+6NUimtYC8grONxTNY1fWrKAQjpi08bKf2lrw7gGie2bjlTiXWml7Xlp/KcFBhVXQjcvVoC2/pI+jZSgGMLdOzPrTOptJF1j5kRwjrWy2FhSmFyGMTuMEDZogGQJF0X0s56L2s3lzZcGrSsDbcuNMhIhsgdBkhETcViqu36chwHZLbukO44/d3eTVYDIA3I3wXoHHZH10ZKg1p96fICpO4UY74U5FRaZ3qZimtnotl2YjdXyVqjCFADoUlAWIr00xAvBSSGeGu3V7j3AYgw1wY+FpPDZrU1sC8qqQ6xrstjC7JirKsyh1qDHetYHrMAfvsB6HgPYHC/yTcRecYAiaghmausXUyltYOPTdbd0h1nYjmOA7IvXmdbeE5rXcMlFrBY/8tGpgEaL798LdXSlhhVF6TFDSvPWwOic0DlBS5uaKeWgg9bkBNi7fayr6Okqt06JDRJCki9aaET5trfteP6TrZtTQSkritNiDUICgd0YYA6TAqAdJG1431sCxx6YrL+PhtzpWaiFoj/g4j8ZTFLa/jYWngsVUCNddqz6ZI0ANlU6rCtBRymt+uti9DZusK8HAdkWznaJd0ijT0qOQSUHpGCH8cB2a2dSisFNIZYawuMQxeX7aGP8a8FrqaiNvixLYdgqXEOejWh1hlkGmmdH21Y7eagOuuGo1rrflwMbIiCAv8nEimxOGxaajY6THMus3Y9lUjBkG1qs6VausbWpaLSWhenCwNCkqzrtARmvIdOXILq0nmgKkcKhMpPA6WZrXsGmEprHcjctjYACk2U9sMKbS+1Bvkc/Fisga8JtetAmWuDImEB1NaNQm0LEWr0tV1e+pjaAde2jURtm9USUdBjgEStk23Qqy3oqSmTuqGM1lYfS7U1+LG2BNi7oVTOM8E0YYDWNhYogP+dLDXSWKCqPKDiLFB+Fig/DW3FWdxsKgEOBO5WQU+tB8I7ARGXAeGdpX/rIp23mKjPgGMhrK1/FQ7jrYR1QcIQh6BGbZ39ZQCiekitUbpo6wDocE5rJ2phGCBR82Mb3Gxr3bGt6uzU2lMuPbctimfbVNJcKQVCplJr91i1tQvKOh3IvkO7ztoVoqud7hzoGT81FdJmpxVZUhBkm55vGxyt0JXWouYc6aKt09vjHPbIirWOt4mofdR30UDbGCDbQHP7Xm/WABgqaSVvTZi0yKWhXe1ihdqI2k1N1Vq2/hC1IgyQqOmZq6V1fGqs3ViWakjBgahd28VcaZ1dVVIbHNm+5IT1S86+sJ3DwobCoWsEFumYxqEFSB8htQj42v3iLSGAqovS2kC2mWK2bTCqCxvmnk1ODYSnAqHJUqChjQL0UQ4BkXUckL9LEAiL64a2Tis0m2vrBgDnMUB6QBttHQNk3ZvLtsaPPjqwyyIQUbPGAIkajuP6PbYAyL6yc2XtuB779Gajh72zZK072sjaXbeDZVCrxSQFQxXZQPkpaW2gS79ZW4NaIrU05sfQDgiJByLSgMhuUldYXTOtfGE21m5ua6lG7V5u1tl+ai2kwNcWBFkXQnRsBbJvqtoALYFE1CIFyTcLNStC1G5T4Piwzd4yldZuKWELiCzVDl9MauuXm7Z2/yV9eODH8QSaENbXliutFF11sfZnZY70b9uaNc2S2rqwYKw0wFgXY/0Z6bApaKh1LZ5YKTiqT8ubEFIrj30WoLG2XkHUtgja1nmKSAPCkqXZZ2rb5rYOKz5zDBARBVAQfxtRk7Lt4m4bs2G6ZN0xvUBaO6emrHbDSds2B5Zq63Nra48mtHb9noYYw9MQhNnaCpRlHR+U7bBXWL61BaM5U0njfUKTpbV8QpNrH96u6+MrS7XDAGj5CtC62q0v9InWgCzCeQC2JkwKijQB2hKFiMgLDJBaK3MVYLLO3jJbu7mqS6UgyFzusKaLpbZ1SJilcT0ah9V7bYvnqaz7fDXUWJ6GYCqVdogvt+4UX34SqMhp/itG66KAqF7SbC99jHWdnWjp34Z4KfBoCPaZgeW1dQqw7ucV5rDtRox19l+Y80+2ABFREGGA1FpUF1kHB+dJXUE1l6R1fCxG2Lsz1Na1e2wbV6q0tas5G+KDu/vLRgippaciy2HlatvPYmkrDds2Gpaqpi5t/elipNafsBQgsisQ3Vta96chW+scV4a2daEK69ggdYgU8ISlACGJ0sBn22KI2rCGKxMRUYA1g2888ovFLC1mWHleaiGpyJG6yVRaaQyJJlQaWNucN6w0V0nBUNVF4NJxh0HRxU1dssDTxwLhHWAO7Yhf8jvg8h6p0Ea0lwYgB5J9qYSq2gBIWMdV2aqJSmPt+gqRAiD9ZdJ4JFtLlS6a3WFE1OwxQGruhJC6M6qLa/f7qsqTxgqZK6Sd3jUG6x5TSc0vGLKYpOnxFVnSYokVZ62bquZLrWAthS4GCEuVHiHxzrvAG9raAyGLWSCrRKBvpMr7vdjkHBfJNFdKQRCsswcdxwSFJFvXJYqwDoK2rQ+lqx1f1lDddURETYwBUnNjMUvBjzFf6i6y7blVU26d/eMwQFoXA4Q0cHdLoNRUSC1d5Wet6wXlSK1eVRfRvGeGOVAbpAAoNEkKVkMTa7vHdFGBu4+wOOz/5rgukLl2kLnG2hUWEidN09fHSAGPbWsMjgkiolaOAVKws5ik4ME2e6zstDR+xlxp3QHcuuBdWGzwL3InhBTMGfOkR+VFoOyE9Kg8B8VNWJsrtV4aCxTZVVobKKqbFBw1xCB2s3VgdE2ZVC9UauumpwZr/dDXTtPX27rCrA+2ABERKWKAFGxM1g1HL/wfYCmt3Sm8pkJK10ZKa9VoQpuujHWxDZQuP21tFToj/bvqYguYJu/ANo7LkCD9DE2WtqoIbS9NpQ/0thRCSAPrEQKUZwEq6ywx28Do8A7S/W1dc9oItgIREfmJAVKwqS6Qfl46Ceh0tVsjhCQG7xR6iwkoOwmUHgZKMqWd5U0lTV2q+lPppIAjLEWaxWfbMyykndQtpY1smO5L20KcjrPELJWAUAGqMADJQGQnIDyxdoaYLpqtQUREAcQAKViFp/o/CLchCAFUnAGK9ktrBlUXWvdGK3a7sWrzoZJafyI61+4WH5YitQo1dFBqqXHYcqXCuv4UrAOhQ6RWqtBE6aGLAdQRwG+7gMSbpACaiIgaBAMkcmWukgIgY6HULVZ8ACjeL419alZUtQOPdVHST8fZYfo20irfYR0aZ40ec6XDzLFKAKJ24U1tJBCZJpVHFymNK9OGS+Vy7KozmdxmT0REgcMAqbUzFgClR2ofFdnSStrNjtq6WGI366DorkBYx6Zb3FII6950pYDZui2LOlQKeEKTrFP5Y2oHS2sjAj9miYiI/MYAqbUxlUrdZEU/A8UHpY1XmwtNaO1aQaHta8cCGdpZNzBtqmDILA2eNjvsNwaVtCCnLlqawRaSYG0d4iKKRETNAQOkls5SLQ2cLj4gBUVlJxD044UM8bWzwUKTpZ/hqdKihU2xppOlxjpo2iRttGpbbdpSLZVHpbGOFwqvHbuki7K2EMVwJhkRUTPEAKmlMVdJM8pKDgPFv0gzyoJ1ar3aIAUT4Z2BiDRpDE7EZYHfPsNXZmPt/m0WkxTgqPXWzXi11vFLMbUrXDs+GAwREbUIDJCau+oioHAvUHpU2oes/CyCauVplVbqEgvvZJ0dllzbLaaNaPpVvoW5dpHFmnJp7JBGLw2aju4pjRfSt6ldaFFtYBBERNQKMEBqjsyVQP5uIHeLNJ4omAIiQzwQ1VMKLqJ6SsFRU40NAqRtN+yzx8qlFiGnLkbrTDd9DBDdW1rnSN9Gah0K9pXJiYiowTBAai7MRqDoJyDvB6Bgl7SIYFPRRQPRfWqDCX0MoGsjjRMyxDVduWxsW7OYKwGoajdWDesilVNjqO0y04RY9yELgtYsIiIKGgyQgpmlGij4Ecj/ASjYC1iqmqYc2ghpbFCb/kCbftKYoWCakm5rJaoukrrKtGHSrLHILtIgaX00oI1i1xgREXmNAVIwEgKqvO3A6aXSgo2NQaWTAoqoHtKAaUNc7WKKwbKFhW1toZpya3eZbfC5tZXIEAu0GyzNfGuIvdCIiKjVYIAUbKpyMdD4CrS//diw91FppDFCbfoBMZdLQVGwjbkRFqlFyGTdtFcFa3dZJBDW1bozfWTtatn6GAZFREQUEAyQgoUQwKmPoN37JJLMpQ1zj7BUKRhq018aQ9QY22v4ymyUNro1lQCwSMFQSIJ1w1hri5YuumkHfhMRUYvHb5lgUJED/PgIcO5LBHSYcEiiNDMr5nLpYYgNZO6BYTFJLUSmUqnLTK2XWoLaXil1ldkWXeQAaiIiakQMkJqSEMDJpcBPM6wtJvWhloKg6F5AZFfpoYsKSDEDQlhqd6w3V0kDzgWkgdO6KGk7jrD21jWSYoOvu4+IiFoVBkhNRQhgx51A1pr65RPZHYgfBrQbIrW8BAtby1BNuTSwWqWWuvQ04UBYEqCPs27UGikFRJqQpi4xERGRHQOkpqJSAfHX+RcgRXQB4gYD7a6RuqGCRU0FYCqWBlar1NJYoYhOtatR69tYu8s4kJqIiIIbA6Sm1O1x4OwqIG973efqooCU24C4a4DQxIYvmyeWGqDmktRVZq6SWotUANQh0kDqNv2lMoYkBM8SAURERD5ggNSUVGpg0BLgq8ulQMOddkOAtEelBQ+bijAD1cXSYowQtd1jEZ2loEgTLv3k+kNERNQCMEBqalFdgctfBn5+2vWYLhroMg1o97vGLZOwOLQOVUldZ7BIY5zaXCF1m4UkSmsScXYZERG1QAyQgkH3p4CsT4H8nfYkS9y1UHd9pPFmolmqAWMhUFMKaWXqEOlhaCutrh2aJM0y04Y3TnmIiIiaEAOkYKDWAIPeB77qB6GLwo94COndr4Za08CtMxYTYCyQgiKVRuoea9NXCoa0kdLq1Bp9w5aBiIgoCDFAChbRPYCha1Cji8eFnTkNdx8hpDWXqvOl54Z2UlAUliINqub6Q0RERAyQgkr7m4Hi4wACGCDZxhPVlFsXaayUuu2ie0ub04amsJWIiIhIhgFSS2Obgm+yTsNXWXe614YBYWlAaHsgvENwLSpJREQUZBggtQSWGqDqImAut65YHSkFQWEpUiCki5ZajbjBKxERkVf4jdmcCbMUGJkuSTPMogZJA60NsVKLEREREfmFAVJzZKkBjHnS7LOQRGnLkcgu3M+MiIgoQBggNRf22WcF0sBrQzsg7mogsiugDW3q0hEREbUoDJCag8rzUnCkiwKiewERaVKXGluMiIiIGgQDpGBXeQGABUi6CQjvyNlnREREjYABUjCrLpFmpiXeCMT0burSEBERtRrcdj1YmauAqgtA7CCpW42IiIgaDQOkYFV+FojpC8ReJS32SERERI2GAVKwiugMxA/h3mhERERNgAFSsFFppJ/trgG04U1bFiIiolaKAVKwCU2Wfhpim7YcRERErRgDpGCj4q+EiIioqQXs23jv3r3485//jEGDBiElJQUGgwGxsbHo1asXJkyYgJUrV8JoNAbqdgCALVu2QKVS1fsxffr0gJaLiIiImrd6r4OUnZ2N6dOnY/Xq1fY0tVqNxMREFBcXIzMzE5mZmVi+fDnS0tLw9ttv45ZbbqnvbYmIiIgaTL1akI4dO4bBgwc7BUdDhw7FmTNnkJOTg6KiIsyePdt+7MSJExg9ejQWLVpUn9sSERERNSi/A6TS0lLccMMNyM7OtqcZDAZ88sknSElJAQDo9XrMmjULo0aNsp8jhMC0adOwdu3aehSbiIiIqOH4HSA9//zzyMrKckobMmQIkpKSXM69++67XdKeeOIJlJSU+Hv7gGrTpk1TF4GIiIiCiF8BUnZ2Nt555x2X9D59+iie37dvX5e0c+fOYeHChf7cXpEQwuvH1q1b7deFhITg0UcfDVg5iIiIqPnzK0D68MMPYbFYXNJtXWtyqampiunLli3z5/b19o9//MP+74ceegiJiYlNUg4iIiIKTn4FSOvWrVNMj41VXtywbdu2iulHjx5FZmamP0Xw265du/B///d/AKQxUs8991yj3p+IiIiCn8/T/E0mEw4cOKB4LCoqSvkmWi3CwsJQUVHhcmzfvn3o2bOnr8UAAPTq1QsrVqzw6RrH1qPJkye7bfUiIiKi1svnFqQjR464XfAxLCzM7XXuju3fv9/XItjFx8dj3LhxGDdunFfn//TTT/jyyy8BSEHb888/7/e9iYiIqOXyuQUpNzfX7TG9Xu/zMU/5BZpj69H999+PTp06eXWd0Wh0CgpLS0sBSK1pJpMpoGW05RfofKllYP2gurCOUF1acx3x5TX7HCB5mpqv0Wh8PmYLNhrawYMH8dlnn9nL8uc//9nra1955RW89NJLLukbN2702GpWH5s2bWqQfKllYP2gurCOUF1aYx1RGurjjs8Bki+ZO1KrlXvzysrK/MrPV7Nnz4YQAgAwbtw4dOnSxetrZ86ciRkzZtifl5aWIjU1FTfddJPbcVf+MplM2LRpE2688UbodLqA5k3NH+sH1YV1hOrSmuuIL40yPgdI/raYKC0LAAARERF+5eeLI0eO4NNPPwUgBWqzZs3y6XqDwQCDweCSrtPpGqxyNWTe1PyxflBdWEeoLq2xjvjyen0epO2pxcRsNvt8LNAtMEpefvlle4B25513+j1rjoiIiFoHnwOkhIQEt8eqq6t9PhYfH+9rEXxy4sQJ+1IAKpUKL7zwQoPej4iIiJo/nwOkHj16KHY3AZ7HJ7k71q9fP1+L4JN//vOf9tarjIwMxW1PiIiIiBz5HCDpdDq3QYa7wU9msxmVlZWKx9LT030tgtfOnDmDjz76yP6crUdERETkDb+2GsnIyFBMLygoUEwvLCy0zyBz1LVrV/Tq1cufInhlzpw59jUPbr75Zlx55ZUNdi8iIiJqOfwKkCZOnKg4bT8nJ0fx/KysLMX0yZMnK6YvWrQIXbt2RUxMDDIyMnDmzBmfy5iTk4OlS5fan//lL3/xOQ8iIiJqnfwKkFJTU/HQQw+5pB88eFDx/EOHDrmkJSYmYtq0aS7pS5YswbRp03D8+HGUlJRg/fr1GDlypNsuOndee+01++rXN954I66++mqfriciIqLWy68ACZACkPbt2zul7dixA+fPn3c5d+XKlS5pCxYsQExMjEv6kiVLXNKOHj2K7du3e122ixcv4t1337U/Z+sRERER+cLvACk6OhqbN29GcnKyPc1oNGLcuHHIzs4GIE3tnzNnDjZs2OB07fz583HHHXf4dD+VSuX1uXPnzrW3OA0bNgxDhw716V5ERETUuvkdIAFA9+7dsXPnTowdO9aetm3bNnTs2BEpKSlo06YNZs6caT/WuXNnfPbZZ3jiiSfc5vnwww+7pPXo0QNDhgzxqkz5+flYuHCh/Tlbj4iIiMhXPm81ItehQwesXbsWe/bswerVq7F582bk5OQgLy8PYWFhSE1NRXp6OsaMGYOxY8ciJCTEY36TJ0+G0WjE3LlzkZ+fj2HDhmHevHkIDQ31qjxvvvkmysvLAQCDBw/GDTfcUN+XSERERK1MvQMkmwEDBmDAgAEByWvq1KmYOnWqX9e+/PLLePnllwNSDiIiImqd6tXFRkRERNQSMUAiIiIikmGARERERCQTsDFIrdHx3EuIqPR++QFv1JhqcL4COHaxDFqd669Hr1GjU1y4z/mezi9HtdkSiCL6rFtCpM/XnCuuRJmxpgFKU7cObcMQotP4dE1+mRGF5dUNVKJaSvUjMToEUSE6n/IprTLhQklVQxSxTm3D9YiLUN7w2p0qkxlnC91vht2QIgxaJMd4N0nE0W8XLzVAaeqmFv79P+dnhPeC+TNCCT8japVd8v7/JQOkehj77x+gNoQ1QM5azPnlB8UjXeMjsGnGMJ9zfPjDvTiWW1bfgvnl9JxbfL5m9heH8eXBCw1Qmrpt/OO1Pn9gf7TzDN7efKyBSiTnXD/+fW86brk8yacctv+Wj8f/91OgC+aVp27oij/e2M2na84WVuCmN7c1UIk8u7lvIv5zn+/7ODZVebu0C8eTXXy/jp8R3gv+zwhn/IyoZTF6/4cWu9iIiIiIZBggEREREckwQCIiIiKSYYBEREREJMMAiYiIiEiGARIRERGRDAMkIiIiIhmVEEI0dSGam9LSUkRHR2PfsWxEREYFNO8aUw22bd+Ga4dey4UiuQicC6X6wUXgGlZzXCjy0O4tuPnmm6HTeV8v+BnhvWD+jFAi/4wwmUz48ssvPdaRlvoZUXapFFd2TUFJSQmiojx/f3OhyHroEh+JqCjf/2N7YjKZcCwM6JoQ4dOHW138Caqakj9fSE0pLsLg839ofwSqfkSF6HwOqppSiE7j15doU2qq8ppMJhzy4zp+RjSsxvqMCJSW+hlRGup9mxC72IiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkow1URnv37sWaNWuwefNm5OTkIC8vDxEREUhISEB6ejrGjBmDjIwMGAyGQN3SrfPnz2PDhg3YuHEjDh8+jPz8fBQVFSEyMhKxsbGIi4tD165dcfnll+Pqq6/GgAEDoNfrG7xcRERE1DzUO0DKzs7G9OnTsXr1anuaWq1GYmIiiouLkZmZiczMTCxfvhxpaWl4++23ccstt9T3toqKi4vx8ssvY8GCBaiqqrKn63Q6xMfHo6ysDMeOHcOxY8ewc+dO+/G1a9di7NixDVImIiIian7q1cV27NgxDB482Ck4Gjp0KM6cOYOcnBwUFRVh9uzZ9mMnTpzA6NGjsWjRovrcVtGZM2cwaNAgzJ071x4c9enTBxs2bEBZWRmys7NRXFyMnJwcPPfcc1Cr2btIREREyvyOEkpLS3HDDTcgOzvbnmYwGPDJJ58gJSUFAKDX6zFr1iyMGjXKfo4QAtOmTcPatWvrUWxneXl5GDJkCH777Td7Wv/+/bFz507ccsstTt1nycnJmDNnDubNmxew+xMREVHL4neA9PzzzyMrK8spbciQIUhKSnI59+6773ZJe+KJJ1BSUuLv7Z08/vjjToEaAMyfPx8RERFur5k2bRouu+yygNyfiIiIWha/AqTs7Gy88847Lul9+vRRPL9v374uaefOncPChQv9ub2TrVu3YtWqVU5paWlpuOaaazxep1arceLECQghOP6IiIiInPgVIH344YewWCwu6bauNbnU1FTF9GXLlvlzeydKgdq1115b73yJiIio9fIrQFq3bp1iemxsrGJ627ZtFdOPHj2KzMxMf4oAACgvL1ccy9StWze/8yQiIiLyeZq/yWTCgQMHFI9FRUUp30SrRVhYGCoqKlyO7du3Dz179vS1GACAn376yWk6v01cXByqqqqwevVqbNq0CUeOHEFpaSkiIyPRsWNHDB8+HOPHj0dMTIxf9yUiIqKWzecWpCNHjsBoNCoeCwsLc3udu2P79+/3tQh2+/btU0zfsmULLrvsMkyYMAEffPABdu/ejczMTPz4449YtWoVHnvsMXTu3LlBlhsgIiKi5s/nFqTc3Fy3xzytRu3umKf86nL06FHF9OXLl0OtVmPu3LmYMmUKhBBYvHgxZs6cCSEEAGlRyWnTpiE7O9tprSYlRqPRKSi0zb4rLCyEyWTyu/xKTCYTKioqUFBQAJ1OF9C8qflj/aC6sI5QXVpzHbl06RIA2GMBj4SPVq9eLQAoPr777ju316Wmpipek5GR4WsR7MaPH++2LA899JDL+ZMmTVI894svvvB4nxdffNHtffjggw8++OCDj+b1yMrKqjPG8LkFSWkckTfcrVxdVlbmV34APK6jdN9997mkTZgwQXHm3KxZs3DzzTe7zWvmzJmYMWOG/bnFYkFhYSFiY2OhUql8K3QdSktLkZqaiqysLLdjuqj1Yv2gurCOUF1acx0RQuDSpUtITk6u81yfAyRP44w8UVoWAIDHxRzrUl1d7fZY//79XdLS09MVz92/fz8OHTqE3r17Kx43GAwum+w29ADvqKioVldxyXusH1QX1hGqS2utI9HR0V6d5/MgbU9vptls9vlYfX457q4NDw9XfAPatGnjNsD7/vvv/S4HERERtSw+B0gJCQluj3lq0XF3LD4+3tci2LmLAj0FXZGRkYrpOTk5fpeDiIiIWhafA6QePXq4dDfZeBqf5O5Yv379fC2Cnbu91DyNync3m842sr2pGQwGvPjii27fY2rdWD+oLqwjVBfWEe/4HCDpdDrFvdUAaeCXErPZjMrKSsVj7sYFeeOqq65STK+pqXF7jbtp+cGyaKTBYMDf/vY3VlxSxPpBdWEdobqwjnjHr61GMjIyFNMLCgoU0wsLCxXXHOjatSt69erlTxEAAFdffbXiL9jTzLjy8nLF9A4dOvhdDiIiImpZ/AqQJk6cqDht3904nqysLMX0yZMnK6YvWrQIXbt2RUxMDDIyMnDmzBnF82JiYnD77be7pJeWlip26ZWXl7vtSrvuuusU04mIiKj18StASk1NxUMPPeSSfvDgQcXzDx065JKWmJiIadOmuaQvWbIE06ZNw/Hjx1FSUoL169dj5MiRbrvoZsyYoRis/frrry5p7vaQu/baa9GpUyfFY0RERNT6+BUgAcBrr72G9u3bO6Xt2LED58+fdzl35cqVLmkLFixQHPezZMkSl7SjR49i+/btiuW46qqr8Mwzz7ikr1mzxiVt9erVLmlarRavvPKKYt5ERETUOvkdIEVHR2Pz5s1Oq1EajUaMGzcO2dnZAKSp/XPmzMGGDRucrp0/fz7uuOMOn+7nacXql19+GRMmTHBKe/vtt/H555/bn69duxYLFixwyXPBggX43e9+51NZiIiIqGVTCaXR0z44e/YsnnrqKaxbt86eplarkZSUhKKiIqexQJ07d8Zbb72FMWPGuM1v6dKlePDBB53SevTogZ9++gmhoaFurxNC4M0338TLL7+MwsJCe3pcXByEEC4DyFNTU/Huu+9i5MiR3r5UF3v37sWaNWuwefNm5OTkIC8vDxEREUhISEB6ejrGjBmDjIyMBp8pcOTIEXz66af45ptvcPbsWeTm5sJgMCAhIQF9+vTB6NGjcfvtt7fKFVObWlPVkaqqKuzduxd79+7FoUOH8NtvvyEnJwf5+fn2/5Ph4eGIj49H9+7dMWTIENx+++3o0qVLQMtBngXLZwgAnD9/Hhs2bMDGjRtx+PBh5Ofno6ioCJGRkYiNjUVcXBy6du2Kyy+/HFdffTUGDBjgcYNyCoxgqCN79uzBxx9/jN27d+PkyZMoKiqCWq1GXFwcOnbsiBEjRuC2225zO8O92fJjj1hFP/74o3juuefEVVddJZKSkoRerxcxMTGie/fuYvz48WLFihWisrLSq7wWLlwo0tLSRHR0tBgzZow4ffq01+UoKioSixcvFnfccYfo2rWriImJEVqtVrRt21b06tVLTJw4UXz88cfCZDL5+1JFVlaWuOOOO5w2vlOr1SI5OVmEhYU5paelpYkNGzb4fS9PCgsLxSOPPCLUarX9fiqVSiQmJorIyEinciQkJIhly5Y1SDnIVVPWkZqaGqHX6102Z9Tr9SI1NVWEh4crbt6oVqvFuHHjRF5eXsDKQsqC5TNECOkz85lnnhEhISFO99XpdKJ9+/YiOjpasb6sXbu2wcpEwVFHTp8+La6//nqX331ISIhISUkRGo3G6btn/Pjx4ty5cwEvR1MJWIDUWvz2228iJSXFqbIMHTrUvjOw0WgUs2fPdjquUqnEwoULA1qOixcvir59+zrdp1evXiIzM1MIIYTZbBbvvvuu0Gq1TufMnDkzoOUgV01dR0wmk1PeQ4YMEbt27RJms1kIIdWNrVu3ivT0dMUvvs6dO4vc3NyAlIVcNXX9cHT69GnRrVs3p3v16dNHbNiwQRiNRvt5OTk54rnnnnP6Y4wBUsMJhjpy6NAh0bZtW5fPh0mTJolLly4JIYQ4f/68GDJkiMvnx7FjxwJWjqbEAMkHJSUlIjU11akyGAwGxYh51KhRLhVrzZo1ASmHyWQSV155pUv++/btczl32rRpLue9+eabASkHuQqGOuIYIPXr109UVVW5LWunTp0Ug6Tx48fXuxzkKhjqh01ubq7Ll3D//v3tX35KFixYwACpgQVDHamqqhKXXXaZS97x8fFOgbMQQpw4cUKoVCqn87p06SLKy8vrXY6mxgDJB0rBxg033KB47tKlS13OTU5OFsXFxfUux6uvvuqSd1pamuK53333ncu54eHh4tSpU/UuB7kKhjriGCCtX7/e47mvvfaaYoCk1+tFWVlZvcpBroKhftjcddddLvnv2LHD4zVms9n+xckAqWEEQx2ZN2+e4ufCxIkTFc/v16+fy7l//OMf61WGYOD3LLbWJjs7G++8845Lep8+fRTPVxqsdu7cOSxcuLBe5aisrMQ///nPepWjvLwcc+bMqVc5yFWw1BGVSoVBgwZh8ODBGD58uMdz3Q2qrK6uxtmzZ+tVDnIWLPUDALZu3YpVq1Y5paWlpeGaa67xeJ1arcaJEycghMDYsWPrXQ5yFix1RGlpHgBud77o3bu3S9rixYvdbj/WXDBA8tKHH34Ii8Xikp6SkqJ4fmpqqmL6smXL6lWOtWvXoqSkxOtyxMbGKs7++/jjj90uvkn+CZY6otFosGvXLvzwww+IiIjweK6nfQs9bfpMvguW+gFA8Uv42muvrXe+VD/BUEeEENi9e7fisYSEBK/Ty8vLsWLFCr/LEQwYIHnJcRkDR7GxsYrpbdu2VUw/evQoMjMzG60c7o6VlJRgy5YtfpeDXAVLHfHF/v37FdPj4+Nx2WWXNUoZWotgqR/l5eVYu3atS3q3bt38zpMCIxjqSGFhodtN3UNCQhTT3S3Bs3XrVr/KECwYIHnBZDK53abE3dpCWq0WYWFhisf27dvnd1n27t3rUzk8HatPOchZMNURbxUUFLhtip81a5biFj7kn2CqHz/99BOqqqpc0uPi4lBVVYXly5dj0qRJuPrqq9GrVy8MGjQId999NxYuXIji4mK/70ueBUsdcRcc+WPPnj0By6sp8BPQC0eOHIHRaFQ85q5yejrm7q/2upSWluLUqVNNXg5yFSx1xBtGoxGff/45hgwZgnPnzjkdU6lUePbZZ/GHP/yhwe7fGgVT/XD3xbllyxZcdtllmDBhAj744APs3r0bmZmZ+PHHH7Fq1So89thj6Ny5MxYtWuT3vcm9YKkj7lqlALgdluEu3d33VXPBAMkLubm5bo95WknW3TFP+XmSl5cXFOUgV8FSRzwZPHgwUlNTERkZiTFjxuDIkSP2Yx06dMDDDz+Mffv24dVXXw34vVu7YKofR48eVUxfvnw5Ll68iLlz56KoqAiFhYWYM2eO0zZPxcXFmDZtGl544QW/70/KgqWO6PV69OzZU/HYxYsXfUo3m80oKyvzqxzBgAGSF5QGRdtoNBqfj/k7sj9YykGumsPv5tSpU8jOzlZsQlepVDAajU7b9FDgBFP98FSWBx98EE8//TRiYmLQpk0bPPfcc5g4caLLeS+//DK+/PJLv8tAroKpjowePVox3d24pkOHDrnNy9PrCnYMkLzguJ+cL9yN4fA3og6WcpCr5vC7uXDhAqqqqnDixAksXLgQnTp1sh87c+YMPvzwQ4wYMQIjRoxg62KABVP98PSFdd9997mkyTcCt5k1a5bfZSBXwVRHpk+frth19/XXX6O6utop7eTJk/jll1/c5tUY+wg2FAZIXvDU/+uJ0nRNAHVOvQ72cpCr5vK7MRgMuOyyyzB16lTs378fV199tcs5mzdvxrXXXotLly41SBlao2CqH/IvOEf9+/d3SUtPT1c8d//+/R5bDsg3wVRHkpKSsGTJEqfuVUDqSnv00UdRXl4OQPqja+LEiRAe9ryPjo72uxxNjQGSFzzNEDObzT4f85RfcygHuWqOv5vo6Gh8/PHHiusdHT16FLNnz27wMrQWwVQ/3F0bHh6u+GXWpk0bt1/e33//vd/lIGfBVEcAYNy4cVi9ejViYmKc0pctW4a4uDh06NABqamp2LFjB+644w7FPMLCwpr1emoMkLzgbnEswPNfY+6OxcfH+1UOT9c1ZjnIVbDUEV917NgRt9xyi+Kx999/3+NfhuS9YKof7v6i9/SFGhkZqZiek5PjdznIWTDVEZvbbrsNp0+fxty5czFixAgkJiZCr9dDo9EgPDwckyZNwg8//OB2Ycru3bvXuwxNSdvUBWgOevToAYPBoDgF01O/sbtj/fr186scUVFR6Ny5s+LUycYsB7kKljrij4EDByouUJefn4+TJ08iLS2t0crSUgVT/XC3AKinv/TdzZRiN2zgBFMdcRQdHY2nn34aTz/9tNtzLly4oJjurnu2uWALkhd0Op3bPavczRQwm81u14aoT6W58sorfSoH4P5DrLlX3mASTHXEV3FxcW6PcbB2YART/bjqqqsU0z1tO+Nu8UB59wv5L5jqiK/OnDmjmD548OBGK0NDYIDkpYyMDMX0goICxfTCwkLF7omuXbu63fCvIcrh7lhUVFSdG5mSb4KljsybNw9Dhgzxeh8kT3vycSB/4ARL/bj66qsVZxZ5mvVkG5Qr16FDB7/LQa6CpY74ynFNNZuwsDDceeedjVaGhsAAyUsTJ05UnE7prg8+KytLMX3y5MmK6YsWLULXrl0RExODjIwMtxH5HXfcoThWwF05CgsLFZtgx40b53b/HPJPsNSRkydP4vvvv8emTZu8Kre7mUharRYdO3b0Kg+qW7DUj5iYGNx+++0u6aWlpYqfFeXl5W5boa+77jrFdPJPsNQRQNo4d8GCBV6tjfbtt9+6pN19993NegYbAECQ1x555BEBwOlxww03KJ774YcfupybmJgoioqKXM597733XM7t3r27qKioUMz7n//8p8v5aWlpiudu27bN5dywsDBx8uRJv98Hci8Y6shTTz0lAIi4uDhRXl7usbyVlZUiPj7eJW8A4uabb/brPSD3gqF+CCHEnj17hFqtdrlm9+7dLuf+8MMPivXj2muvrdd7QcqCpY507NhRABD/+te/PJa3oKBAREREOOUbHR0tsrOzfX7twYYBkg+Ki4tF+/btnSqCwWAQ586dczn31ltvdamMn376qWK+gwcPVvwA+uabbxTPN5lMon///i7n79u3z+XcJ554wuW8N954o35vBLkVDHXEFiABEE899ZTH8j722GOK+er1evHLL7/49R6Qe8FQP2yeffZZl/Ofe+45l/Oefvppl/O0Wq34/vvv/X8jyK1gqSO2ACk5OdljsHPfffc55adSqcRHH33k34sPMgyQfHTkyBGRnJzs8pdUVlaWEEIIo9EoXnnlFZdKOH/+fLd5uqu4GzdudHvNhQsXRO/evZ3O79Wrl8jMzBRCCGE2m8XSpUuFVqt1OueZZ54J7BtCLpq6jjgGSADEvffeKw4fPmw/brFYxN69e0VGRoZiniEhIWLVqlWBf2NICNH09cPGZDKJCRMmuPzu169fbz9nzZo1wmAwuHwBLlq0KHBvCLkIhjpiC5AAiG7duonPPvtMVFdX24/v27dP3HLLLU55aTQasXTp0oC+F02JAZIfzpw5I8aOHetUMdRqtWjfvr0ICwtzSu/cubP47LPPPOb3/vvvu1TaHj16uG36tMnPzxdTpkxxaipXqVQiKSlJREVFOeUXHx8vlixZEsi3gTxoyjry+uuvu3ypARAxMTGiY8eOLs3hjo+RI0ey5agRBMtniMViEW+88YZo27at07VxcXEiNjbWJc/U1FTx9ddfB/KtIDeauo44BkiOAVBKSoriZ8jQoUPFrl27GuKtaDIqIbgSnL/27NmD1atXY/PmzcjJyUFBQQHCwsKQkJCA9PR0jBkzBmPHjkVISEideS1atAhz585Ffn4+hg0bhnnz5nk9QPbw4cP49NNP8c033+Ds2bPIy8uDwWBAfHw8+vTpg9GjR+POO+/kytlNoKnqSFVVFXbt2oW9e/di//79OHHiBLKyslBcXIzKykro9XpEREQgKSkJPXv2xMCBAzF27FiuedTIguUzpLi4GKtWrcI333yDAwcOIC8vD2VlZYiKikJiYiIGDBiAUaNG4Y477oBWy+XzGlNT1ZHTp0/jhx9+wL59+/Drr7/i3LlzKCgoQGFhIXQ6HeLi4pCSkoLrrrsOo0aNwu9+97tAv/QmxwCJiIiISIbT/ImIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIiGQZIRERERDIMkIiIiIhkGCARERERyTBAIiIiIpJhgEREREQkwwCJiIiISIYBEhEREZEMAyQiIiIimf8HyLEW+MeK+XkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot boxplot of the differences with pretty fill colors\n",
    "# medianprops = dict(linestyle=None, linewidth=0)\n",
    "# plt.boxplot(acc[:,1:], 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",
    "# draw error bars with ys and y_error\n",
    "plt.grid()\n",
    "# plt.ylabel('Recall')\n",
    "# plt.xlabel('Warmup ratio')\n",
    "plt.title(f\"k={budget}, LR, {dataset.capitalize()}\")\n",
    "\n",
    "plt.axhline(y=ys[1], color='C0', linestyle='--', label=\"i.i.d.\")\n",
    "\n",
    "x_ticks = []\n",
    "for warmup in warmups[1:]:\n",
    "    x_ticks.append(f\"{warmup}\")\n",
    "plt.xticks(np.arange(min(partitions), max(partitions)+0.2, 0.3))\n",
    "# plt.errorbar(range(1, len(x_ticks)+1), ys[1:], yerr=y_error[1:], fmt='o', markersize=10, capsize=10)\n",
    "plt.plot(partitions, ys[2:], 'o-', markersize=1, color=\"orange\", label=\"corr.\")\n",
    "plt.fill_between(partitions, np.array(ys[2:]) - np.array(y_error[2:]), np.array(ys[2:]) + np.array(y_error[2:]), alpha=0.3, color=\"orange\")\n",
    "# fix y axis range from 0.2 to 0.9\n",
    "plt.ylim(0.6, 1.0)\n",
    "# draw horizontal dotted line at acc.T[0].mean()\n",
    "plt.axhline(y=ys[0], color='green', linestyle='--', label=\"no DP\")\n",
    "\n",
    "# plt.legend(loc=\"lower right\")\n",
    "# set xtick labels as [\"0\", \"0.1\", \"0.3\", \"0.5\", \"0.7\", \"0.9\"]\n",
    "# plt.xticks(num_x_ticks, [\"0\", \"0.1\", \"0.3\", \"0.5\", \"0.7\", \"0.9\"])\n",
    "plt.savefig(f'../figs/label_flip_{dataset}_{eps}_{model_name}_{budget}_{metric}_{utility}_acc.pdf', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.905 0.001\n"
     ]
    }
   ],
   "source": [
    "print(\"{:.3f} {:.3f}\".format(ys[0], y_error[0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.675 0.006\n"
     ]
    }
   ],
   "source": [
    "print(\"{:.3f} {:.3f}\".format(ys[1], y_error[1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.735 0.020\n"
     ]
    }
   ],
   "source": [
    "print(\"{:.3f} {:.3f}\".format(ys[2], y_error[2]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.762 0.010\n"
     ]
    }
   ],
   "source": [
    "print(\"{:.3f} {:.3f}\".format(ys[int(len(partitions) * 0.3)], y_error[int(len(partitions) * 0.3)]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.774 0.008\n"
     ]
    }
   ],
   "source": [
    "print(\"{:.3f} {:.3f}\".format(ys[int(len(partitions) * 0.5)], y_error[int(len(partitions) * 0.5)]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.788 0.004\n"
     ]
    }
   ],
   "source": [
    "print(\"{:.3f} {:.3f}\".format(ys[int(len(partitions) * 0.9)], y_error[int(len(partitions) * 0.9)]))"
   ]
  },
  {
   "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
}
