{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "import random\n",
    "import copy\n",
    "import os\n",
    "import pickle\n",
    "\n",
    "import cl_gym as cl\n",
    "from metrics import MetricCollector2, FairMetricCollector\n",
    "from configs import make_params\n",
    "\n",
    "EER_dataset = [\"MNIST\", \"FashionMNIST\", \"CIFAR10\", \"CIFAR100\"]\n",
    "color_list = ['#1f77b4', '#ff7f0e', '#2ca02c', '#d62728', '#9467bd', '#8c564b', '#e377c2', '#7f7f7f', '#bcbd22', '#17becf']"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "LOG_PATH = f\"scripts_output\"\n",
    "OUT_PATH = f\"outputs\"\n",
    "\n",
    "def is_number(value):\n",
    "    flag=True\n",
    "    try:\n",
    "        num=float(value)\n",
    "        flag = num == num\n",
    "    except ValueError:\n",
    "        flag=False\n",
    "    return flag\n",
    "\n",
    "\n",
    "def load(dataset, seed, epoch, lr, tau, alpha, lmbd, method, fair_metric, eps=None, randinx = False, verbose=2):\n",
    "    # if dataset == \"CIFAR10\":\n",
    "    #     dataset+=\"(prev)\"\n",
    "    path = f\"dataset={dataset}\"\n",
    "    if randinx:\n",
    "        path+=\"_randidx\"\n",
    "    if eps is None:\n",
    "        eps = 0\n",
    "    # if method != \"FSW\":\n",
    "    #     fair_metric = \"no_metrics\"\n",
    "    path = os.path.join(path, method)\n",
    "    path = os.path.join(path, fair_metric)\n",
    "\n",
    "    # Get log_path\n",
    "    runs = list()\n",
    "    for d in os.listdir(os.path.join(LOG_PATH, path)):\n",
    "        info_dict = dict()\n",
    "        info_dict['path'] = d\n",
    "        # print(f\"{d=}\")\n",
    "        for elem in d.split(\"_\"):\n",
    "            k, v = elem.split(\"=\")\n",
    "            info_dict[k] = int(v) if v.isdigit() else float(v) if is_number(v) else v\n",
    "            info_dict['path'] = d\n",
    "        runs.append(info_dict)\n",
    "    avails = list()\n",
    "    for run in runs:\n",
    "        seed_flag = seed == run.get(\"seed\", None)\n",
    "        epoch_flag = epoch == run.get(\"epoch\", None)\n",
    "        lr_flag = lr == run.get(\"lr\", None)\n",
    "        tau_flag = tau == run.get(\"tau\", 0)\n",
    "        alpha_flag = alpha == run.get(\"alpha\", 0)\n",
    "        lmbd_flag = lmbd == run.get(\"lmbd\", 0)\n",
    "        eps_flag = eps == run.get(\"eps\", 0)\n",
    "        flag = seed_flag & epoch_flag & lr_flag & tau_flag & alpha_flag & lmbd_flag & eps_flag\n",
    "        if flag:\n",
    "            avails.append(run)\n",
    "    \n",
    "    if len(avails) == 0:\n",
    "        if verbose > 2:\n",
    "            print(runs)\n",
    "        return False\n",
    "    target = avails[0]\n",
    "    \n",
    "    log_path = os.path.join(path, target['path'])\n",
    "\n",
    "    out = os.path.join(os.path.join(LOG_PATH, log_path), \"log.out\")\n",
    "    err = os.path.join(os.path.join(LOG_PATH, log_path), \"log.err\")\n",
    "    if os.path.exists(err):\n",
    "        with open(err, \"r\") as f:\n",
    "            lines = f.readlines()\n",
    "        if len(lines) and len(lines) not in [2, 5]:\n",
    "            print(f\"{len(lines)=}\")\n",
    "            if verbose:\n",
    "                print(f\"Error in {err} - error during running\")\n",
    "                for line in lines:\n",
    "                    print(line)\n",
    "            return False\n",
    "    else:\n",
    "        if verbose:\n",
    "            print(f\"error in {os.path.join(LOG_PATH, path)} - not exists\")\n",
    "        return False\n",
    "    if os.path.exists(out):\n",
    "        with open(out, \"r\") as f:\n",
    "            lines = f.readlines()\n",
    "        if len(lines) == 0:\n",
    "            if verbose:\n",
    "                print(f\"{os.path.join(LOG_PATH, path)} - currently running\")\n",
    "            return False\n",
    "        \n",
    "    # Get out_path\n",
    "    runs = list()\n",
    "    for d in os.listdir(os.path.join(OUT_PATH, path)):\n",
    "        info_dict = dict()\n",
    "        info_dict['path'] = d\n",
    "        # print(f\"{d=}\")\n",
    "        for elem in d.split(\"_\"):\n",
    "            k, v = elem.split(\"=\")\n",
    "            info_dict[k] = int(v) if v.isdigit() else float(v) if is_number(v) else v\n",
    "            info_dict['path'] = d\n",
    "        runs.append(info_dict)\n",
    "\n",
    "    avails = list()\n",
    "    for run in runs:\n",
    "        seed_flag = seed == run.get(\"seed\", None)\n",
    "        epoch_flag = epoch == run.get(\"epoch\", None)\n",
    "        lr_flag = lr == run.get(\"lr\", None)\n",
    "        tau_flag = tau == run.get(\"tau\", 0)\n",
    "        alpha_flag = alpha == run.get(\"alpha\", 0)\n",
    "        lmbd_flag = lmbd == run.get(\"lmbd\", 0)\n",
    "        eps_flag = eps == run.get(\"eps\", 0)\n",
    "        flag = seed_flag & epoch_flag & lr_flag & tau_flag & alpha_flag & lmbd_flag & eps_flag\n",
    "        if flag:\n",
    "            avails.append(run)\n",
    "    if len(avails) == 0:\n",
    "        if verbose > 2:\n",
    "            print(runs)\n",
    "        return False\n",
    "    target = avails[0]\n",
    "    out_path = os.path.join(path, target['path'])\n",
    "    return out_path\n",
    "\n",
    "def print_log(path, option='err'):\n",
    "    out = os.path.join(os.path.join(LOG_PATH, path), \"log.out\")\n",
    "    err = os.path.join(os.path.join(LOG_PATH, path), \"log.err\")    \n",
    "    if option == \"err\":\n",
    "        if os.path.exists(err):\n",
    "            with open(out, \"r\") as f:\n",
    "                lines = f.readlines()\n",
    "                print(lines)\n",
    "    elif option == \"out\":\n",
    "        if os.path.exists(out):\n",
    "            with open(out, \"r\") as f:\n",
    "                lines = f.readlines()\n",
    "                print(lines)\n",
    "\n",
    "def load_metrics(path, verbose=0):\n",
    "    metrics_dir = os.path.join(os.path.join(OUT_PATH, path), \"metrics/metrics.pickle\")\n",
    "    try:\n",
    "        with open(metrics_dir, \"rb\") as f:\n",
    "            metric_manager_callback = pickle.load(f)\n",
    "    except:\n",
    "        # print(f\"{path} still running\")\n",
    "        return -1\n",
    "\n",
    "    if verbose>0:\n",
    "        print(f\"{metric_manager_callback.meters.keys()}\")\n",
    "    return metric_manager_callback"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, \\\n",
    "             method, eps_range = None, randinx = False, verbose=1, metric=None):\n",
    "    randinx = False\n",
    "    acc_list = list()\n",
    "    fair_list = list()\n",
    "    fair_2_list = list()\n",
    "    info_list = list()\n",
    "\n",
    "    acc_data_list = list()\n",
    "    fair_data_list = list()\n",
    "\n",
    "    if eps_range is None:\n",
    "        eps_range = [0.0]\n",
    "\n",
    "    if dataset in EER_dataset:\n",
    "        disp_metric = \"EER\"\n",
    "        disp_metric2 = \"EER\"\n",
    "        metric = \"EER\"\n",
    "    else:\n",
    "        if metric is None or metric == \"no_metrics\":\n",
    "            disp_metric = \"EO\"\n",
    "            disp_metric2 = \"DP\"\n",
    "        else:\n",
    "            if metric == \"EO\":\n",
    "                disp_metric = \"EO\"\n",
    "                disp_metric2 = \"DP\"\n",
    "            elif metric == \"DP\":\n",
    "                disp_metric = \"DP\"\n",
    "                disp_metric2 = \"EO\"\n",
    "\n",
    "    # MNIST\n",
    "    # if method in ['joint', 'vanilla', 'finetune']:\n",
    "    if method in ['joint', 'vanilla', 'finetune', 'AGEM', \"GSS\", \"iCaRL\", \"WA\", \"OCS\", \"FaIRL\", \"CLAD_1.0\"]:\n",
    "        metric = \"no_metrics\"\n",
    "    for tau in tau_range:\n",
    "        for lr in lr_range:\n",
    "            for alpha in alpha_range:\n",
    "                for lmbd in lambda_range:\n",
    "                    for eps in eps_range:\n",
    "                        cnt = 0\n",
    "                        acc_temp = list()\n",
    "                        acc_std_temp = list()\n",
    "                        fair_temp = list()\n",
    "                        fair_2_temp = list()\n",
    "\n",
    "                        acc_data_temp = list()\n",
    "                        fair_data_temp = list()\n",
    "                        fair_2_data_temp = list()\n",
    "                        \n",
    "                        fair_std_temp = list()\n",
    "                        # print(f\"{info=}\")\n",
    "                        avail_seed = copy.deepcopy(seed_range)\n",
    "                        for seed in seed_range:\n",
    "                            path = load(dataset, seed, epoch, lr, tau, alpha, lmbd, method, metric, eps=eps, randinx=randinx)\n",
    "                            if not path:\n",
    "                                if verbose>1:\n",
    "                                    print(\"Remove\")\n",
    "                                    print(f\"{dataset=}, {randinx=}, {method=}, {metric=}\")\n",
    "                                    print(f\"{seed=}, {epoch=}, {lr=}, {tau=}, {alpha=}, {lmbd=}, {eps=}\")\n",
    "                                avail_seed.remove(seed)\n",
    "                                # print(seed)\n",
    "                                # print(target_dir)\n",
    "                                continue\n",
    "                            mmc = load_metrics(path, verbose=verbose-1)\n",
    "                            if mmc == -1:\n",
    "                                continue\n",
    "                            acc_temp.append(np.mean(mmc.meters['accuracy'].compute_overall()))\n",
    "                            fair_temp.append(np.mean(mmc.meters[disp_metric].compute_overall()))\n",
    "                            fair_2_temp.append(np.mean(mmc.meters[disp_metric2].compute_overall()))\n",
    "                            acc_data_temp.append(mmc.meters['accuracy'].get_data())\n",
    "                            fair_data_temp.append(mmc.meters[disp_metric].get_data())\n",
    "                            # print(f\"{mmc.meters[disp_metric].get_data()=}\")\n",
    "                            fair_2_data_temp.append(mmc.meters[disp_metric2].get_data())\n",
    "                            cnt+=1\n",
    "                        info = f\"lr={lr}_tau={tau}_alpha_{alpha}_lmbd={lmbd}_eps={eps}({cnt=}, {avail_seed})\"\n",
    "                        if cnt == 0:\n",
    "                            print(f\"{info=}: check if boom?\")\n",
    "                            continue\n",
    "                        else:\n",
    "                            acc_mean = np.mean(acc_temp)\n",
    "                            acc_std = np.std(acc_temp)\n",
    "                            fair_mean = np.mean(fair_temp)\n",
    "                            fair_std = np.std(fair_temp)\n",
    "                            fair_2_mean = np.mean(fair_2_temp)\n",
    "                            fair_2_std = np.std(fair_2_temp)\n",
    "\n",
    "                            # acc_data_mean = np.round(np.mean(acc_data_temp, axis=0), 3)\n",
    "                            # fair_data_mean = np.round(np.mean(fair_data_temp, axis=0), 3)\n",
    "                            # fair_2_data_mean = np.round(np.mean(fair_2_data_temp, axis=0), 3)\n",
    "\n",
    "                            # acc_data_list.append(acc_data_mean)\n",
    "                            # fair_data_list.append(fair_data_mean)\n",
    "\n",
    "                            info_list.append(info)\n",
    "                            acc_list.append(acc_mean)\n",
    "                            fair_list.append(fair_mean)\n",
    "                            fair_2_list.append(fair_2_mean)\n",
    "                            out = f\"{info}\\nacc:{np.round(acc_mean, 3)}±{np.round(acc_std,3 )}\\nfair:{np.round(fair_mean, 3)}±{np.round(fair_std, 3)}\"\n",
    "                            # if dataset not in EER_dataset:\n",
    "                            #     out+=f\"\\nfair2:{fair_2_mean}±{fair_2_std}\"\n",
    "                            if verbose:\n",
    "                                print(out)\n",
    "    if verbose:\n",
    "        print()\n",
    "\n",
    "    return info_list, acc_list, fair_list, fair_2_list, acc_data_list, fair_data_list\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def plot(acc_list, fair_list, marker = \"o\"):\n",
    "    plt.scatter(acc_list, fair_list, marker=marker, s = 10)\n",
    "    plt.xlabel('acc')\n",
    "    plt.ylabel('fairness')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Main Result"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## MNIST - EER"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=0.1_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.97±0.004\n",
      "fair:0.014±0.006\n",
      "\n",
      "method='finetune'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.453±0.0\n",
      "fair:0.323±0.0\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.934±0.004\n",
      "fair:0.037±0.003\n",
      "\n",
      "method='WA'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.911±0.007\n",
      "fair:0.052±0.006\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.835±0.015\n",
      "fair:0.099±0.015\n",
      "\n",
      "method='GSS'\n",
      "lr=0.001_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.886±0.007\n",
      "fair:0.08±0.009\n",
      "\n",
      "method='OCS'\n",
      "lr=0.001_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.901±0.003\n",
      "fair:0.061±0.004\n",
      "\n",
      "method='FaIRL'\n",
      "lr=0.001_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.458±0.008\n",
      "fair:0.306±0.004\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.924±0.003\n",
      "fair:0.032±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e734e7c0>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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+vpCT0+vzW0EQUB2djZsbW27pnAiIiIN03d2hun48Qw/XUirt8AiIyOxbds2xMXFITc3F4sWLUJRUREiIiIAtNyamj17tqJ/REQELl++jMjISOTm5iIuLg7bt2/HkiX/ex/CP/7xD+zfvx/5+fnIzs5GeHg4srOzFWMSERERafVN0KGhoSgrK8OHH34ImUyG4cOHIzk5GU5OTgAAmUym9E4gFxcXJCcnY9GiRdi8eTPs7OywceNGPPvss4o+FRUVeO2111BSUgKpVApvb2+kp6dj9OjRGj8+IiIi6p4kwt1ZxKRQVVUFqVSKyspKmJmZabscIiIiaoeO/P3W+lNgRERERJrGAERERESiwwBEREREoqPVSdBERESkeYWVhSi+XQxHM0c4mTlpuxytYAAiIiISicq6SixNX4oj144o2gLsArB6/GpIDaRarEzzeAuMiIhIJJamL8Ux2TGltmOyY1iavlRLFWkPAxAREZEIFFYW4si1I2gSmpTam4QmHLl2BJerLmupMu1gACIiIhKB4tuqP/RdVFWkcn1vwzlAREREvYxcXgB57WUYGznB2NgFAODQ10HlNo5mjpoordtgACIiIuolGhoqcObsQpSXZyjaLCzGYfiwDXCWOiPALgDHZMeUboPpSnQx1nas6J4G4y0wIiKiXqIl/BxVaisvP4ozZxcAAFaPX42xtmOV1o+1HYvV41drrMbugleAiIiIegG5vEDpys//NKG8PANyeQGkxi6InRSLy1WXUVRVxPcAERERUc8mr1X9FJe89rJiPpCTmZNog89dvAVGRETUCxgbqQ40D1ovNgxAREREvYCxsQssLMYB0L1njS4sLMYprv5QCwYgIiKiXmL4sA2wsPBXarOw8MfwYRu0VFH3xTlAREREvYSenhTeXvFtvgeIlDEAERER9TLGxi4MPg/AW2BEREQkOgxAREREJDoMQERERCQ6DEBEREQkOgxAREREJDoMQERERCQ6DEBEREQkOgxAREREJDoMQERERCQ6DEBEREQkOvwUBhEREWlU/s1qXC6Xw9nSBC5WJlqpgQGIiIiINKJCXo/5CdlIv3hT0TZ+UH9sesEbUmM9jdbCW2BERESkEfMTsnEkr1Sp7UheKeYlZGm8FgYgIiIiUrv8m9VIv3gTTYKg1N4kCEi/eBMFpTUarYcBiIiIiNTucrlc5frCMgYg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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"MNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 5\n",
    "metric=\"EER\"\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "metric=\"no_metrics\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EER')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## FashionMNIST - EER"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.895±0.01\n",
      "fair:0.035±0.004\n",
      "\n",
      "method='finetune'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.45±0.0\n",
      "fair:0.324±0.0\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.862±0.002\n",
      "fair:0.053±0.003\n",
      "\n",
      "method='WA'\n",
      "lr=0.001_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.809±0.005\n",
      "fair:0.088±0.003\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.775±0.018\n",
      "fair:0.115±0.019\n",
      "\n",
      "method='GSS'\n",
      "lr=0.001_tau=5.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.73±0.013\n",
      "fair:0.15±0.011\n",
      "\n",
      "method='OCS'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.785±0.012\n",
      "fair:0.092±0.007\n",
      "\n",
      "method='FaIRL'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.455±0.005\n",
      "fair:0.316±0.001\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.001_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.825±0.006\n",
      "fair:0.037±0.007\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f21bc318ca0>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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rFmztH4LTK+Pwffr1098++23Vdr8/f3F999//4H77Ny5UzQzMxP37NnTrGPU1dWJQUFB4htvvNHsuvgYPBFR+6Cpx+ArSqvEvWtTxU//fki57F2bKlaUVmmo0qbduHFDnDp1quju7i6ampqKXbt2FZ977jkxMTFRFMX6x83RxKtftm/fLvbq1UucMmVKk/3Gx8eLHTp0EPPy8pSPwQMQBUEQraysxMcff1x87733RIVC0exas7KymqwlNDRUuc2iRYtEd3d3lf3+85//iIMGDRJlMpno6OgoLl68+IGPwIui5h6DF0RRB69bfIC4uDhEREQgJiYGwcHB2LRpEzZv3oxz587B3d0d8+fPx/Xr1/HFF18AqL/t9dprr2Ht2rV44YUXlP2Ym5tDLpcDAP71r39hwIAB8PX1RUlJCdatW4cvv/wSR44cQb9+/ZpVV0lJCeRyOYqLi3k7jIioDbt37x6ysrLg6empkdehFN0sR/HtCsg7m2tt5IfUU3dNW/L3u4M2i3yY8PBwFBQUYMmSJVAoFOjZsycSEhLg7u4OAFAoFCrvBNq4cSNqamowdepUlbdgvv7664iNjQVQf1/0rbfeQl5envJ13snJyc0OP0RERA9i42DB4NNO6HUEyFBxBIiIqH3Q9AiQlHXs2PGB63766ScMGjRIJ3W0ixEgIiIiahvS0tIeuK5r1666K0RDGICIiIjooXx8fPRdgkbp/T1ARERERLrGAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMAREREZKDy8vIwY8YM+Pj4wMzMDA4ODnjyyScRExOD8vJyAEBqairGjBmDLl26wMzMDB4eHggPD0d+fr6yn/j4ePTv3x9yuRxWVlbo0aMHZs+era/TMgh8DxAREZEByszMREhICGxsbLBs2TL06tULNTU1uHTpErZt2wZnZ2cMGDAATz/9NJ599lns378fNjY2yMrKwr59+5QB6ZdffsHLL7+MZcuW4bnnnoMgCEhPT8ehQ4f0fIb6xU9hNIGfwiAiah80/SmMwhvXUXxTARtHJ3Ry0u7bj0eOHIlz587hwoULsLS0bLReFEXs3bsXL774IioqKtChQ9NjGjNnzsTp06eRmJio1Xp1hZ/CICIi0pGK0rtIWPcxsk//oWzzeLwvRk+fCzM138hqrYKCAhw4cADLli1rMvwAgCAIcHR0RE1NDfbs2YNx48ZBEIRG2zk6OmLnzp04e/YsevbsqfFa2yrOASIiInqIhHUf4+qZNJW2q2fS8OO6lVo5XkZGBkRRRPfu3VXa7e3t0bFjR3Ts2BHz5s3DgAED8I9//AOvvPIK7O3tMWrUKHz88ce4efOmcp9p06bhiSeeQK9eveDh4YGXX34Z27ZtQ2VlpVZqbysYgIiIiNQovHEd2af/gFhXp9Iu1tUh+/QfuKO4rrVj3z+i8/vvvyMtLQ09evRQBpilS5ciLy8PMTExCAgIQExMDPz8/HDmzBkAgKWlJX788UdkZGRg4cKF6NixI2bPno1+/fop5wlJEQMQERGRGsU3FWrXF+WpX98aPj4+EAQBFy5cUGn38vKCj48PzM3NVdrt7Ozw4osvYvXq1Th//jycnZ2xatUqlW28vb0xefJkbNmyBX/88QfS09MRFxen8drbCgYgIiIiNeQOTmrX2ziqX98adnZ2GDZsGD799FOUlZW1aF9TU1N4e3ur3c/DwwMWFhYt7rs94SRoIiIiNWydu8Lj8b64eiZN5TaYYGQE9169tfY0WHR0NEJCQhAUFITFixfjscceg5GREU6cOIELFy4gMDAQP/zwA3bv3o2XX34Z3bp1gyiK+P7775GQkIDt27cDABYvXozy8nI888wzcHd3R1FREdatW4fq6moMGzZMK7W3BQxAREREDzF6+lz8uG6lylNg7r16Y/T0uVo7pre3N1JTU7Fs2TLMnz8f165dg0wmQ0BAAObMmYMpU6YgLy8PFhYWmD17NnJzcyGTyeDr64stW7YgIiICABAaGooNGzbgtddew82bN9GpUyf06dMHBw4caDTJWkr4HqAm8D1ARETtg6bfA3RHcR1Febp5DxA1je8BIiIi0rFOTl0ZfNoJToImIiIiyWEAIiIiIslhACIiIiLJYQAiIiIiyWEAIiIiIslhACIiIiLJYQAiIiIiyWEAIiIiIslhACIiIiLJYQAiIiIyULm5uZg0aRKcnZ1hamoKd3d3zJgxAwUFBSrbZWRk4I033oCLiwtkMhk8PT0xfvx4nDx5UrlNYmIiwsLCYGtrCwsLC/j6+uL1119HTU2Nrk/LIDAAERERGaDMzEwEBQXh0qVL2LVrFzIyMhATE4NDhw4hODgYhYWFAICTJ08iMDAQly5dwsaNG5Geno49e/bAz88Ps2fPBgCcO3cOo0aNwhNPPIHk5GScOXMG69evh4mJCer+9IV7KeHHUJvAj6ESEbUPmv4YavXtctQU3kMHO3OY2JtroMIHGzVqFM6ePYtLly7B3Px/x8rLy4O3tzdee+01REdHo1evXjAzM8Pvv/8OIyPVcY2ioiLY2NggKioKa9euRVZWllZr1gV+DJWIiEhH6sqrUbDrAiovFynbZL42sBvvByMLE40fr7CwEPv378fSpUtVwg8AODo64tVXX0VcXBzeeustnDt3Djt37mwUfgDAxsZGuY9CoUBycjIGDx6s8XrbIt4CIyIieoiCXRdQmVGk0laZUYSCXRe0crzLly9DFEX4+/s3ud7f3x937tzB5cuXAQB+fn5q+3vxxRcxfvx4hIaGwsnJCX/5y1/w6aefoqSkROO1txUMQERERGpU3y6vH/m5f8KICFReLkJ1foXOa2qYvdLwv4IgqN3e2NgY27dvx7Vr17By5Uo4Oztj6dKl6NGjBxQKhdbrNUQMQERERGrUFN5Tv75A8wHIx8cHgiAgPT29yfUXLlxAp06d0K1bNwDA+fPnm9Vv165dERERgQ0bNiA9PR337t1DTEyMxupuSxiAiIiI1Ohgq37ydAc7zU+GtrOzw7BhwxAdHY2KCtWAlZeXhx07diA8PBy9e/dGQEAAVq9e3eTTXEVFRQ88RqdOneDk5ISysjJNl98mMAARERGpYdLZAjJfG+D+u0xC/URobT0N9umnn6KyshIjRoxAcnIycnNz8fPPP2PYsGHo2rUrli5dCkEQsH37dly6dAmDBw9GQkICMjMz8Z///AdLly7F2LFjAQAbN27E22+/jQMHDuDKlSs4d+4c5s2bh3PnzuHZZ5/VSv2GjgGIiIjoIezG+0HmY6PSJvOpfwpMW3x9fXHy5El4e3sjPDwc3t7eeOuttxAWFoZjx47B1tYWANCvXz/ldm+++Sb8/f3x3HPP4dy5c4iKilJuU1paisjISPTo0QOhoaE4fvw4vvvuO4SGhmrtHAwZ3wPUBL4HiIiofdD4e4DyK1BTUKGT9wBR0/geICIiIh0zsWfwaS94C4yIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCRH7wEoOjpa+Sx/YGAgUlJSHrjtt99+i2HDhqFz586wtrZGcHAw9u/f32i7+Ph4BAQEQCaTISAgAHv27NHmKRAREVEbo9cAFBcXh5kzZ2LBggVITU3FoEGDMGrUKOTk5DS5fXJyMoYNG4aEhAScOnUKYWFhePbZZ5Gamqrc5tixYwgPD0dERAROnz6NiIgIvPTSS/jtt990dVpERERk4PT6Juj+/fujb9+++Oyzz5Rt/v7+eP7557F8+fJm9dGjRw+Eh4fjn//8JwAgPDwcJSUl+Omnn5TbjBw5Ep06dcKuXbua7KOyshKVlZXK3yUlJXB1deWboImI2jhNvwma9E9Tb4LW2whQVVUVTp06heHDh6u0Dx8+HEePHm1WH3V1dbh7967yeyhA/QjQ/X2OGDFCbZ/Lly+HXC5XLq6uri04EyIiIs2bOHEiBEFotGRkZKjdLykpCYIgKL8E3/C7YbGzs8NTTz2FI0eOqOy3ePFi9O7dW0tnY3j0FoDy8/NRW1sLBwcHlXYHBwfk5eU1q4/Vq1ejrKwML730krItLy+vxX3Onz8fxcXFyiU3N7cFZ0JERKQdI0eOhEKhUFk8PT1b1dfFixehUCiQlJSEzp07Y/To0bh165aGK2479D4JWhAEld+iKDZqa8quXbuwePFixMXFoUuXLo/Up0wmg7W1tcpCRER0v/z8fFy+fBkFBQU6OZ5MJoOjo6PKsnbtWvTq1QuWlpZwdXXFlClTUFpa+tC+unTpAkdHR/Tq1QsLFy5EcXGxpOfH6u1jqPb29jA2Nm40MnPr1q1GIzj3i4uLw6RJk/D111/j6aefVlnn6OjYqj6JiIgepLy8HPHx8bhy5YqyzdvbG+PGjYO5uW4/jmpkZIR169bBw8MDWVlZmDJlCubOnYvo6Ohm7V9eXo7t27cDAExMTLRZqkHT2wiQqakpAgMDcfDgQZX2gwcPYuDAgQ/cb9euXZg4cSJ27tyJ0aNHN1ofHBzcqM8DBw6o7ZOIiEid+Ph4ZGZmqrRlZmbim2++0epxf/jhB3Ts2FG5vPjii5g5cybCwsLg6emJp556Ch9++CG++uqrh/bl4uKi7OeTTz5BYGAghg4dqtX6DZneRoAAYNasWYiIiEBQUBCCg4OxadMm5OTkIDIyEkD93Jzr16/jiy++AFAffl577TWsXbsWAwYMUI70mJubQy6XAwBmzJiBwYMHY8WKFRg7diz27t2LX375BYcPH9bPSRIRUZuWn5+vMvLTQBRFXLlyBQUFBbCzs9PKscPCwlSelLa0tERiYiKWLVuG9PR0lJSUoKamBvfu3UNZWRksLS0f2FdKSgosLS2RmpqKefPmITY2VtIjQHoNQOHh4SgoKMCSJUugUCjQs2dPJCQkwN3dHQCgUChU3gm0ceNG1NTUYOrUqZg6daqy/fXXX0dsbCwAYODAgdi9ezcWLlyIDz74AN7e3oiLi0P//v11em5ERNQ+3LlzR+36wsJCrQUgS0tL+Pj4KH9fvXoVzzzzDCIjI/Hhhx/C1tYWhw8fxqRJk1BdXa22L09PT9jY2KBbt264d+8e/vKXv+Ds2bOQyWRaqd3Q6TUAAcCUKVMwZcqUJtc1hJoGSUlJzepz3LhxGDdu3CNWRkREBHTq1Ent+j+/ikXbTp48iZqaGqxevRpGRvWzWJpz++t+ERERWLJkCaKjo/Huu+9qusw2Qe9PgRERERkye3t7eHt7N3qaWBAEeHt7a230pyne3t6oqanB+vXrkZmZiS+//BIxMTEt7sfIyAgzZ87ERx99hPLycmV7RUUF0tLSVJaHvXeorWIAIiIieohx48bBy8tLpc3Ly0vndxt69+6NNWvWYMWKFejZsyd27NjR7C8n3O9vf/sbqqur8emnnyrbLl26hD59+qgskydP1lT5BkWvn8IwVC15lTYRERkuTX8Ko6CgAIWFhbC1tdXpyA/9j6Y+haH3OUBERERthZ2dHYNPO8FbYERERCQ5DEBEREQkORoNQAqFAu+8844muyQiIiLSuBbPAUpPT0diYiJMTEzw0ksvwcbGBvn5+Vi6dCliYmJa/ZVaIiIiIl1p0QjQDz/8gD59+mDatGmIjIxEUFAQEhMT4e/vj7S0NHz99ddIT0/XVq1EREREGtGiALR06VJERkaipKQEq1atQmZmJiIjIxEfH4/ExESMGTNGW3USERERaUyLAtD58+cxdepUdOzYEdOnT4eRkRGioqIwePBgbdVHREREpHEtCkAlJSWwsbEBAHTo0AHm5ubo1q2bNuoiIiIi0ppWTYLOy8sDAIiiiIsXL6KsrExlm8cee0wz1RERERFpQYsfgx86dCh69+6N3r17o7y8HGPGjEHv3r3Rp08f5f8SERHRo5k4cSIEQWi0ZGRkIDU1FWPGjEGXLl1gZmYGDw8PhIeHIz8/HwDg5OSEFStWqPQ3b948CIKAQ4cOqbQPHToUr7zyis7Oy1C0aAQoKytLW3UQERHRfUaOHInt27ertAmCgP79++PZZ5/F/v37YWNjg6ysLOzbt0/5ZfchQ4YgMTER8+bNU+6XlJQEV1dXJCYmYujQoQCAqqoqHDt2DGvXrtXdSRmIFgUgd3d3bdVBRERk8MrLs1BecRUW5u6wsND+e+9kMhkcHR1V2r777juUlJRgy5Yt6NCh/s+4p6cnnnrqKeU2YWFhmD17NmpqatChQwfcvXsXqampiIqKws6dO5Xb/fbbb6ioqEBYWJjWz8XQtOgW2MqVK1FRUaH8nZycjMrKSuXvu3fvYsqUKZqrjoiIyABUVxchNW0ijh1/GqdPT8Kx408jNW0iqquLdV6Lo6MjampqsGfPHoii2OQ2YWFhKC0txYkTJwAAKSkp6NatG8aNG4cTJ04oR4oSExPh4uICHx8fndVvKFoUgObPn4+7d+8qf48ZMwbXr19X/i4vL8fGjRs1Vx0REZEBOHtuJgoLj6q0FRYexdlzM7R63B9++AEdO3ZULi+++CIGDBiAf/zjH3jllVdgb2+PUaNG4eOPP8bNmzeV+/n6+qJr165ISkoCUH/7KzQ0FF26dIGXlxeOHDmibJfi6A/QwgB0f9J8UPIkIiJqL8rLs1BYmAKg9r41tSgsTEF5ufbmx4aFhSEtLU25rFu3DkD9i4nz8vIQExODgIAAxMTEwM/PD2fOnFHuO2TIEJUANGTIEABAaGgokpKSUFlZiePHj6vcOpMSfg2eiIhIjfKKq4+0/lFYWlrCx8dHuTg5OSnX2dnZ4cUXX8Tq1atx/vx5ODs7Y9WqVcr1YWFhOHLkCAoKCpCamqp8aXFoaCgSExNx/Phxyc7/ARiAiIiI1LIwV/8A0MPW64KpqSm8vb1V3ssXFhaGsrIyrFmzBr6+vnBwcABQH4BOnjyJH3/8EZ6enpJ9wKnFL0LcsmULOnbsCACoqalBbGws7O3tAUBlfhAREVF7YGHhCVvbQf+dA/Tn22DGsLUdqJOnwf7shx9+wO7du/Hyyy+jW7duEEUR33//PRISElQemffy8oKbmxvWr1+PV199Vdnu7OwMd3d3xMTE4MUXX9Rp7YakRQHIzc0NmzdvVv52dHTEl19+2WgbIiKi9qRnj7U4e27Gf+cC1bO1HYiePXT//pyAgABYWFhg9uzZyM3NhUwmg6+vL7Zs2YKIiAiVbcPCwvD5558r5/80CA0NxdatWyV7+wsABJEzmRspKSmBXC5HcXExrK2t9V0OERG10r1795CVlQVPT0+YmZk9cn+6fg8QNabumrbk73eL5gA988wzKC7+3zsPli5diqKiIuXvgoICBAQEtKRLIiKiNsPCwhP2dkMYftqBFgWgn3/+WeXFhytWrEBhYaHyd01NDS5evKi56oiIiIi04JGeAuPdMyIiImqL+Bg8ERERSU6LApAgCBAEoVEbERGRIeMdi/ZDU9eyRY/Bi6KIiRMnQiaTAaifiR0ZGQlLS0sAUJkfREREpG8mJiYA6r9VaW5urudqSBOqqqoAAMbGxo/UT4sC0Ouvv67ye8KECY22ee211x6pICIiIk0xNjaGjY0Nbt26BQCwsLDgnYs2rK6uDrdv34aFhQU6dGjxu5xVtGjvP79hkoiIqC1wdHQEAGUIorbNyMgIbm5ujxxkHy0+ERERGThBEODk5IQuXbqgurpa3+XQIzI1NYWR0aM/w8UAREREkmBsbPzI80ao/eBj8ERERCQ5DEBEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxAREREJDkMQERERCQ5eg9A0dHR8PT0hJmZGQIDA5GSkvLAbRUKBV555RV0794dRkZGmDlzZqNtYmNjIQhCo+XevXtaPAsiIsNSeOM6slJP4o7iur5LITJIHfR58Li4OMycORPR0dEICQnBxo0bMWrUKKSnp8PNza3R9pWVlejcuTMWLFiATz755IH9Wltb4+LFiyptZmZmGq+fiMjQVJTeRcK6j5F9+g9lm8fjfTF6+lyYdeyox8qIDIteR4DWrFmDSZMmYfLkyfD390dUVBRcXV3x2WefNbm9h4cH1q5di9deew1yufyB/QqCAEdHR5WFiEgKEtZ9jKtn0lTarp5Jw4/rVuqnICIDpbcAVFVVhVOnTmH48OEq7cOHD8fRo0cfqe/S0lK4u7vDxcUFY8aMQWpqqtrtKysrUVJSorIQEbU1hTeuI/v0HxDr6lTaxbo6ZJ/+g7fDiP5EbwEoPz8ftbW1cHBwUGl3cHBAXl5eq/v18/NDbGws9u3bh127dsHMzAwhISG4fPnyA/dZvnw55HK5cnF1dW318YmI9KX4pkLt+qI89euJpETvk6AFQVD5LYpio7aWGDBgACZMmIDHH38cgwYNwldffYVu3bph/fr1D9xn/vz5KC4uVi65ubmtPj4Rkb7IHZzUrrdxVL+eSEr0Ngna3t4exsbGjUZ7bt261WhU6FEYGRnhiSeeUDsCJJPJIJPJNHZMIiJ9sHXuCo/H++LqmTSV22CCkRHce/VGJ6eueqyOyLDobQTI1NQUgYGBOHjwoEr7wYMHMXDgQI0dRxRFpKWlwcmJ/58PEbV/o6fPhXuv3ipt7r16Y/T0ufopiMhA6fUx+FmzZiEiIgJBQUEIDg7Gpk2bkJOTg8jISAD1t6auX7+OL774QrlPWloagPqJzrdv30ZaWhpMTU0REBAAAPjXv/6FAQMGwNfXFyUlJVi3bh3S0tKwYcMGnZ8fEZGumXXsiL/+YwnuKK6jKE8BG0cnjvwQNUGvASg8PBwFBQVYsmQJFAoFevbsiYSEBLi7uwOof/FhTk6Oyj59+vRR/vOpU6ewc+dOuLu7Izs7GwBQVFSEt956C3l5eZDL5ejTpw+Sk5PRr18/nZ0XEZG+dXLqyuBDpIYgiqKo7yIMTUlJCeRyOYqLi2Ftba3vcoiIiKgZWvL3W+9PgRERERHpGgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSQ4DEBEREUkOAxARERFJDgMQERERSU4HfRdARETUoOhmOYpvV0De2Rw2Dhb6LofaMQYgIiLSu3tl1Tiw9Rxy0wuVba4Bthg+qQfMLE30WBm1V7wFRkREendg6zlcu1Co0nbtQiEObD2np4qovWMAIiIivSq6WY7c9EKIdartYh2Qm16Iopvl+imM2jUGICIi0qvi2xWPtJ6oNRiAiIhIr+SdzR9pPVFrMAAREZFe2ThYwDXAFsJ9f5EEo/qJ0HwajLSBAYiIiPRu+KQecPGzVWlz8at/CoxIG/gYPBER6Z2ZpQmem96b7wEinWEAIiIig2HjYMHgQzrBW2BEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxAREREJDl6D0DR0dHw9PSEmZkZAgMDkZKS8sBtFQoFXnnlFXTv3h1GRkaYOXNmk9vFx8cjICAAMpkMAQEB2LNnj5aqJyIiorZIrwEoLi4OM2fOxIIFC5CamopBgwZh1KhRyMnJaXL7yspKdO7cGQsWLMDjjz/e5DbHjh1DeHg4IiIicPr0aUREROCll17Cb7/9ps1TISIiojZEEEVR1NfB+/fvj759++Kzzz5Ttvn7++P555/H8uXL1e47ZMgQ9O7dG1FRUSrt4eHhKCkpwU8//aRsGzlyJDp16oRdu3Y1q66SkhLI5XIUFxfD2tq6+SdEREREetOSv996GwGqqqrCqVOnMHz4cJX24cOH4+jRo63u99ixY436HDFihNo+KysrUVJSorIQERFR+6W3AJSfn4/a2lo4ODiotDs4OCAvL6/V/ebl5bW4z+XLl0MulysXV1fXVh+fiIiIDJ/eJ0ELgqDyWxTFRm3a7nP+/PkoLi5WLrm5uY90fCIiIjJsHfR1YHt7exgbGzcambl161ajEZyWcHR0bHGfMpkMMpms1cckIiKitkVvI0CmpqYIDAzEwYMHVdoPHjyIgQMHtrrf4ODgRn0eOHDgkfokIiKi9kVvI0AAMGvWLERERCAoKAjBwcHYtGkTcnJyEBkZCaD+1tT169fxxRdfKPdJS0sDAJSWluL27dtIS0uDqakpAgICAAAzZszA4MGDsWLFCowdOxZ79+7FL7/8gsOHD+v8/IiIiMgw6TUAhYeHo6CgAEuWLIFCoUDPnj2RkJAAd3d3APUvPrz/nUB9+vRR/vOpU6ewc+dOuLu7Izs7GwAwcOBA7N69GwsXLsQHH3wAb29vxMXFoX///jo7LyIi0q7q2+WoKbyHDnbmMLE313c51Abp9T1AhorvASIiMkx15dUo2HUBlZeLlG0yXxvYjfeDkYWJ/gojg9Am3gNERETUUgW7LqAyo0ilrTKjCAW7LuinIGqzGICIiKhNqL5dXj/yc/99CxGovFyE6vwKfZRFbRQDEBERtQk1hffUry9gAKLm0+skaCIioubqYGumfr2d5iZDV2ZloTo3F6ZubjD18NBYv2Q4GICIiKhNMOlsAZmvTf0coD/fBhMAmY+NRp4Gqy0qwvU576HsT69OsXzySXRdvQrGcvkj90+Gg7fAiIiozbAb7weZj41Km8yn/ikwTbg+5z2UHTum0lZ27Biuz56jkf7JcHAEiIiI2gwjCxN0ntQL1fkVqCmo0Oh7gCqzslRGfpRqa1F2+DCqsrN5O6wd4QgQERG1OSb25jDvbqvRlyBWP+RD2FX3vZiX2jYGICIiIgAmrq5q15u6uemoEtIFBiAiIiIAMk9PWD75JGBsrLrC2BiWTz7J21/tDAMQERHRf3VdvQqWwcEqbZbBwei6epWeKiJt4SRoIiKi/zKWy+G2ZTOqsrNRlZPD9wC1YwxARERE9zH18GDwaed4C4yIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkp4O+CyAiIiLdyC7ORu7dXLhZu8Hd2l3f5egVAxAREVE7V1xZjHnJ83DkxhFlW4hzCFYMXgG5TK7HyvSHt8CIiIjauXnJ83BccVyl7bjiOOYlz9NTRfqn9wAUHR0NT09PmJmZITAwECkpKWq3//XXXxEYGAgzMzN4eXkhJiZGZX1sbCwEQWi03Lt3T5unQUREZJCyi7Nx5MYR1Iq1Ku21Yi2O3DiCqyVX9VSZfuk1AMXFxWHmzJlYsGABUlNTMWjQIIwaNQo5OTlNbp+VlYVnnnkGgwYNQmpqKv7xj39g+vTpiI+PV9nO2toaCoVCZTEzM9PFKRERERmU3Lu5atfnlDT9N7e90+scoDVr1mDSpEmYPHkyACAqKgr79+/HZ599huXLlzfaPiYmBm5uboiKigIA+Pv74+TJk1i1ahX++te/KrcTBAGOjo46OQciIiJD5mrlqna9m7WbjioxLHobAaqqqsKpU6cwfPhwlfbhw4fj6NGjTe5z7NixRtuPGDECJ0+eRHV1tbKttLQU7u7ucHFxwZgxY5Camqq2lsrKSpSUlKgsRERE7YGH3AMhziEwFoxV2o0FY4Q4h0j2aTC9BaD8/HzU1tbCwcFBpd3BwQF5eXlN7pOXl9fk9jU1NcjPzwcA+Pn5ITY2Fvv27cOuXbtgZmaGkJAQXL58+YG1LF++HHK5XLm4uqpPy0RERG3JisErMMBpgErbAKcBWDF4hZ4q0j+9PwYvCILKb1EUG7U9bPs/tw8YMAADBvzvIoeEhKBv375Yv3491q1b12Sf8+fPx6xZs5S/S0pKGIKIiKjdkMvkiBkWg6slV5FTksP3AEGPAcje3h7GxsaNRntu3brVaJSngaOjY5Pbd+jQAXZ2dk3uY2RkhCeeeELtCJBMJoNMJmvhGRAREbUt7tbukg8+DfR2C8zU1BSBgYE4ePCgSvvBgwcxcODAJvcJDg5utP2BAwcQFBQEExOTJvcRRRFpaWlwcnLSTOFERETU5un1MfhZs2Zhy5Yt2LZtG86fP493330XOTk5iIyMBFB/a+q1115Tbh8ZGYmrV69i1qxZOH/+PLZt24atW7dizpw5ym3+9a9/Yf/+/cjMzERaWhomTZqEtLQ0ZZ9EREREep0DFB4ejoKCAixZsgQKhQI9e/ZEQkIC3N3rh+cUCoXKO4E8PT2RkJCAd999Fxs2bICzszPWrVun8gh8UVER3nrrLeTl5UEul6NPnz5ITk5Gv379dH5+REREZJgEsWEWMSmVlJRALpejuLgY1tbW+i6HiIiImqElf7/1/ikMIiIiIl1jACIiIiLJYQAiIiIiyWEAIiIiIsnR+5ugiYiI2pvy8iyUV1yFhbk7LCw89V0ONYEBiIiISEOqq4tw9txMFBamKNtsbQehZ4+1MDGR67Eyuh9vgREREWlIffg5qtJWWHgUZ8/N0FNFhinzdikSL95CVn6Z3mrgCBAREZEGlJdnqYz8/E8tCgtTUF6eJfnbYUXlVZi+Kw3Jl28r2wb7dsb68X0gt2j6k1bawhEgIiIiDSivuPpI66Vg+q40HMnIV2k7kpGPabtSdV4LAxAREZEGWJir/8r6w9a3d5m3S5F8+TZq7/sARa0oIvnybZ3fDmMAIiIi0gALC0/Y2g4CYHzfGmPY2g6S/O2vq4XlatdnFzAAERERtUk9e6yFre1AlTZb24Ho2WOtnioyHO62FmrXe9hZ6qiSepwETUREpCEmJnL06R3L9wA1watzRwz27YwjGfkqt8GMBQEhPvbwtNdtAOIIEBERkYZZWHjC3m4Iw8991o/vgxAfe5W2EB97rB/fR+e1cASIiIiIdEJuYYIvJvVDVn4ZsgvK4GFnqfORnwYMQERERKRTnvb6Cz4NeAuMiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIefwmiC+N+v1JaUlOi5EiIiImquhr/b4p++Nv8gDEBNuHv3LgDA1dVVz5UQERFRS929exdyuVztNoLYnJgkMXV1dbhx4wasrKwgCIK+yzFIJSUlcHV1RW5uLqytrfVdDoHXxFDxuhgeXhPDo6lrIooi7t69C2dnZxgZqZ/lwxGgJhgZGcHFxUXfZbQJ1tbW/D8gBobXxDDxuhgeXhPDo4lr8rCRnwacBE1ERESSwwBEREREksMARK0ik8mwaNEiyGQyfZdC/8VrYph4XQwPr4nh0cc14SRoIiIikhyOABEREZHkMAARERGR5DAAERERkeQwABEREZHkMADRA0VHR8PT0xNmZmYIDAxESkrKA7dNSkqCIAiNlgsXLuiw4vavJdcEACorK7FgwQK4u7tDJpPB29sb27Zt01G10tGS6zJx4sQm/1vp0aOHDitu/1r638qOHTvw+OOPw8LCAk5OTnjjjTdQUFCgo2qloaXXZMOGDfD394e5uTm6d++OL774QrMFiURN2L17t2hiYiJu3rxZTE9PF2fMmCFaWlqKV69ebXL7xMREEYB48eJFUaFQKJeamhodV95+tfSaiKIoPvfcc2L//v3FgwcPillZWeJvv/0mHjlyRIdVt38tvS5FRUUq/43k5uaKtra24qJFi3RbeDvW0muSkpIiGhkZiWvXrhUzMzPFlJQUsUePHuLzzz+v48rbr5Zek+joaNHKykrcvXu3eOXKFXHXrl1ix44dxX379mmsJgYgalK/fv3EyMhIlTY/Pz/x/fffb3L7hgB0584dHVQnTS29Jj/99JMol8vFgoICXZQnWS29Lvfbs2ePKAiCmJ2drY3yJKml1+Tjjz8Wvby8VNrWrVsnuri4aK1GqWnpNQkODhbnzJmj0jZjxgwxJCREYzXxFhg1UlVVhVOnTmH48OEq7cOHD8fRo0fV7tunTx84OTlh6NChSExM1GaZktKaa7Jv3z4EBQVh5cqV6Nq1K7p164Y5c+agoqJCFyVLwqP8t9Jg69atePrpp+Hu7q6NEiWnNddk4MCBuHbtGhISEiCKIm7evIlvvvkGo0eP1kXJ7V5rrkllZSXMzMxU2szNzfH777+jurpaI3UxAFEj+fn5qK2thYODg0q7g4MD8vLymtzHyckJmzZtQnx8PL799lt0794dQ4cORXJysi5Kbvdac00yMzNx+PBhnD17Fnv27EFUVBS++eYbTJ06VRclS0JrrsufKRQK/PTTT5g8ebK2SpSc1lyTgQMHYseOHQgPD4epqSkcHR1hY2OD9evX66Lkdq8112TEiBHYsmULTp06BVEUcfLkSWzbtg3V1dXIz8/XSF38Gjw9kCAIKr9FUWzU1qB79+7o3r278ndwcDByc3OxatUqDB48WKt1SklLrkldXR0EQcCOHTuUX0des2YNxo0bhw0bNsDc3Fzr9UpFS67Ln8XGxsLGxgbPP/+8liqTrpZck/T0dEyfPh3//Oc/MWLECCgUCrz33nuIjIzE1q1bdVGuJLTkmnzwwQfIy8vDgAEDIIoiHBwcMHHiRKxcuRLGxsYaqYcjQNSIvb09jI2NGyXzW7duNUrw6gwYMACXL1/WdHmS1Jpr4uTkhK5duyrDDwD4+/tDFEVcu3ZNq/VKxaP8tyKKIrZt24aIiAiYmppqs0xJac01Wb58OUJCQvDee+/hsccew4gRIxAdHY1t27ZBoVDooux2rTXXxNzcHNu2bUN5eTmys7ORk5MDDw8PWFlZwd7eXiN1MQBRI6ampggMDMTBgwdV2g8ePIiBAwc2u5/U1FQ4OTlpujxJas01CQkJwY0bN1BaWqpsu3TpEoyMjODi4qLVeqXiUf5b+fXXX5GRkYFJkyZps0TJac01KS8vh5GR6p/DhlEGkZ/LfGSP8t+JiYkJXFxcYGxsjN27d2PMmDGNrlWraWw6NbUrDY8sbt26VUxPTxdnzpwpWlpaKp9Uef/998WIiAjl9p988om4Z88e8dKlS+LZs2fF999/XwQgxsfH6+sU2p2WXpO7d++KLi4u4rhx48Rz586Jv/76q+jr6ytOnjxZX6fQLrX0ujSYMGGC2L9/f12XKwktvSbbt28XO3ToIEZHR4tXrlwRDx8+LAYFBYn9+vXT1ym0Oy29JhcvXhS//PJL8dKlS+Jvv/0mhoeHi7a2tmJWVpbGamIAogfasGGD6O7uLpqamop9+/YVf/31V+W6119/XQwNDVX+XrFihejt7S2amZmJnTp1Ep988knxxx9/1EPV7VtLrokoiuL58+fFp59+WjQ3NxddXFzEWbNmieXl5Tquuv1r6XUpKioSzc3NxU2bNum4Uulo6TVZt26dGBAQIJqbm4tOTk7iq6++Kl67dk3HVbdvLbkm6enpYu/evUVzc3PR2tpaHDt2rHjhwgWN1iOIIsf3iIiISFo4B4iIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIjajZ9//hlPPvkkbGxsYGdnhzFjxuDKlSvK9deuXcPLL78MW1tbWFpaIigoCL/99pty/b59+xAUFAQzMzPY29vjhRde0MdpEJEOMAARUbtRVlaGWbNm4cSJEzh06BCMjIzwl7/8BXV1dSgtLUVoaChu3LiBffv24fTp05g7dy7q6uoAAD/++CNeeOEFjB49GqmpqTh06BCCgoL0fEZEpC38GjwRtVu3b99Gly5dcObMGRw9ehRz5sxBdnY2bG1tG207cOBAeHl54d///rceKiUiXeMIEBG1G1euXMErr7wCLy8vWFtbw9PTEwCQk5ODtLQ09OnTp8nwAwBpaWkYOnSoLsslIj3qoO8CiIg05dlnn4Wrqys2b94MZ2dn1NXVoWfPnqiqqoK5ubnafR+2nojaF44AEVG7UFBQgPPnz2PhwoUYOnQo/P39cefOHeX6xx57DGlpaSgsLGxy/8ceewyHDh3SVblEpGcMQETULnTq1Al2dnbYtGkTMjIy8H//93+YNWuWcv348ePh6OiI559/HkeOHEFmZibi4+Nx7NgxAMCiRYuwa9cuLFq0COfPn8eZM2ewcuVKfZ0OEWkZAxARtQtGRkbYvXs3Tp06hZ49e+Ldd9/Fxx9/rFxvamqKAwcOoEuXLnjmmWfQq1cvfPTRRzA2NgYADBkyBF9//TX27duH3r1746mnnlJ5RJ6I2hc+BUZERESSwxEgIiIikhwGICIiIpIcBiAiIiKSHAYgIiIikhwGICIiIpIcBiAiIiKSHAYgIiIikhwGICIiIpIcBiAiIiKSHAYgIiIikhwGICIiIpKc/w/MWFy/v2Q+PAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"FashionMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 5\n",
    "metric=\"EER\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [0.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [5.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EER')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BiasedMNIST EO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.945±0.002\n",
      "fair:0.053±0.002\n",
      "\n",
      "method='finetune'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.448±0.001\n",
      "fair:0.01±0.003\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.818±0.011\n",
      "fair:0.347±0.025\n",
      "\n",
      "method='WA'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.447±0.001\n",
      "fair:0.018±0.002\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.872±0.011\n",
      "fair:0.195±0.02\n",
      "\n",
      "method='GSS'\n",
      "lr=0.001_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.819±0.009\n",
      "fair:0.313±0.021\n",
      "\n",
      "method='OCS'\n",
      "lr=0.001_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.833±0.012\n",
      "fair:0.303±0.024\n",
      "\n",
      "method='FaIRL'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.759±0.008\n",
      "fair:0.408±0.018\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=5.0_alpha_0.0005_lmbd=0.5_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.909±0.003\n",
      "fair:0.06±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e3e7f9a0>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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//79jY5JRESkLcV3H7RqPWlHs2aAtm3b1qYbj4yMRFhYGHx9feHv749NmzYhJycHERERAGqvzbl58ya2b98OoDb8zJw5E2vXroWfn596psfY2BgKhQIAMGfOHAwfPhwrV67ExIkTsWfPHhw4cACHDx9u09pbcwE4tS/8WRKRNil6NP6OzCetJ+1o9oMQ21JoaCiio6OxdOlSDBw4ECkpKUhMTFQ/SE+pVGo8E+jrr79GVVUV3n77bdja2qqXOXP+7/1ZAQEB2LVrF7Zt24annnoKcXFxiI+Px9ChQ9ukZgOD2ovVHr38kzq+iooKAIC+/uPPZSIiaj1zaxM4eFpA9thvXJle7YXQPP0lDpnAf/7WoVKpoFAoUFxcXO8F0UqlEkVFRejZsydMTExafSE4iaempga3bt2CgYEBevfuzZ8lEWkF7wLTjSf9/v4r0W6D78hsbGwA1F5cTR2fnp4eww8RaZWRqQFeeG8gnwPUjjAAtYBMJoOtrS169uyJyspKscuhVjI0NISenqhng4lIIsytTRh82gkGoFbQ19fndSNEREQdEP/ZS0RERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJIjegCKjY2Fs7MzjIyM4OPjg9TU1Ab7KpVKTJ8+Hf369YOenh7mzp1bp09cXBxkMlmd5eHDh1rcCyIiIupIRA1A8fHxmDt3LhYuXIiMjAwMGzYM48aNQ05OTr39y8vL0aNHDyxcuBBPP/10g+OamZlBqVRqLEZGRtraDSIiIupgRA1Aa9asQXh4OGbPng0PDw9ER0fDwcEBGzZsqLe/k5MT1q5di5kzZ0KhUDQ4rkwmg42NjcZCRERE9IhoAaiiogInT55ESEiIRntISAjS0tJaNXZJSQkcHR1hb2+PCRMmICMjo9H+5eXlUKlUGgsRERF1XqIFoPz8fFRXV8Pa2lqj3draGnl5eS0e193dHXFxcdi7dy927twJIyMj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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"BiasedMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 15\n",
    "metric=\"EO\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [5.0]\n",
    "alpha_range = [0.0005]\n",
    "lambda_range = [0.5]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BiasedMNIST DP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.945±0.002\n",
      "fair:0.005±0.001\n",
      "\n",
      "method='finetune'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.448±0.001\n",
      "fair:0.016±0.008\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.818±0.011\n",
      "fair:0.012±0.001\n",
      "\n",
      "method='WA'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.447±0.001\n",
      "fair:0.016±0.004\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.872±0.011\n",
      "fair:0.013±0.001\n",
      "\n",
      "method='GSS'\n",
      "lr=0.001_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.819±0.009\n",
      "fair:0.038±0.005\n",
      "\n",
      "method='OCS'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.816±0.012\n",
      "fair:0.03±0.003\n",
      "\n",
      "method='FaIRL'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.759±0.008\n",
      "fair:0.033±0.001\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.01_lmbd=0.5_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.889±0.006\n",
      "fair:0.007±0.002\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e41cda60>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkkAAAG1CAYAAADtOGDLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABUu0lEQVR4nO3deVgUV74+8LfZN202ZVGEBtwho8KoYBBJFEWTaEZz0YxGHXWGJBOjyLgmN/7MVeKWMS7IqOCSGPUmROONJEocQaJo1IBBxAVBQe2ONggoraz1+4NL37SUyNbdNLyf5+nnhlOn6nyr8D68c6r6lEQQBAFEREREpMFI3wUQERERtUUMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQi9B6SYmJiIJPJYGFhAT8/P6SmpjbYPyUlBX5+frCwsICnpydiY2Of2Xf//v2QSCSYMGFCi8clIiKijkWvIenAgQOYN28eli1bhvT0dAQFBSEsLAz5+fmi/fPy8jB27FgEBQUhPT0dS5cuxdy5c5GQkFCv761btxAVFYWgoKAWj0tEREQdj0SfL7gdMmQIBg0ahK1bt6rb+vbtiwkTJiA6Orpe/0WLFuHw4cPIzs5Wt0VERODixYtIS0tTt1VXVyM4OBgzZ85EamoqiouLcejQoWaPK6ampgZ3795Fp06dIJFImnLaREREpCeCIODhw4dwdXWFkVHDc0UmOqqpnoqKCly4cAGLFy/WaA8NDcXp06dF90lLS0NoaKhG2+jRoxEXF4fKykqYmpoCAFasWIEuXbpg1qxZ9W6jNWdcACgvL0d5ebn65zt37qBfv37PP1EiIiJqcwoKCtC9e/cG++gtJCmVSlRXV8PJyUmj3cnJCQqFQnQfhUIh2r+qqgpKpRIuLi44deoU4uLikJGR0WrjAkB0dDT+3//7f/XaCwoK0Llz52fuR0RERG1HaWkp3Nzc0KlTp+f21VtIqvP0rSpBEBq8fSXWv6794cOHmDp1KrZv3w5HR8dWHXfJkiWIjIxU/1x3kTt37syQREREZGAa86iM3kKSo6MjjI2N683e3Lt3r94sTx1nZ2fR/iYmJnBwcEBWVhZu3ryJV199Vb29pqYGAGBiYoKrV6/Czc2tyeMCgLm5OczNzZt0jkRERGS49PbtNjMzM/j5+SEpKUmjPSkpCYGBgaL7BAQE1Ot/7Ngx+Pv7w9TUFH369EFmZiYyMjLUn9deew0hISHIyMiAm5tbs8YlIiKijkevt9siIyMxbdo0+Pv7IyAgANu2bUN+fj4iIiIA1N7iunPnDvbs2QOg9ptsmzdvRmRkJObMmYO0tDTExcVh3759AAALCwv4+PhojGFrawsAGu3PG5eIiIhIryEpPDwchYWFWLFiBeRyOXx8fJCYmAh3d3cAgFwu11i7SCaTITExEfPnz8eWLVvg6uqKjRs3YuLEia06LhERdUzV1dWorKzUdxnUAqampjA2Nm6VY+l1nSRDVlpaCqlUipKSEj64TURk4ARBgEKhQHFxsb5LoVZga2sLZ2dn0Yezm/L3W+/fbiMiItK3uoDUtWtXWFlZcZFgAyUIAlQqFe7duwcAcHFxadHxGJKIiKhDq66uVgckBwcHfZdDLWRpaQmg9lvrXbt2bdGtN72/4JaIiEif6p5BsrKy0nMl1Frqfpctfb6MIYmIiAiNW1yQDENr/S4ZkoiIiIhEMCQREVG7UnT3DvLSz+OB/I6+S9G6GTNmYMKECY3qm5ycDIlEwm/wNQEf3CYionbh8aOHSNy4Fjcv/qJu8/jDIIybuxAWNjZ6rEx7PvvsMzR2JZ/AwEDI5XJIpdJGH3/GjBkoLi7GoUOHmlmhYeNMEhERtQuJG9fiVmaGRtutzAwc2bhGPwXpgFQqVb9Z4nnMzMyeuXYQiWNIIiIig1d09w5uXvwFwv++1LyOUFODmxd/0dmtt9z7j3Di6j3kKct0Mt7vb7eVl5dj7ty56Nq1KywsLPDiiy/i3Llz6r5P327btWsXbG1tcfToUfTt2xc2NjYYM2YM5HI5AGD58uXYvXs3vv32W0gkEkgkEiQnJ+vkvNoK3m4jIiKDV/KbvMHtxQo57Fy6aW38YlUF5u7LwMnr99Vtw3t2waYpAyG1MtXauL+3cOFCJCQkYPfu3XB3d8eaNWswevRo5OTkwN7eXnQflUqFdevW4fPPP4eRkRGmTp2KqKgo7N27F1FRUcjOzkZpaSl27twJAM88TnvFmSQiIjJ4UqeGV1a2dW7ZysvPM3dfBk7lKDXaTuUo8d6+dK2OW6esrAxbt27F2rVrERYWhn79+mH79u2wtLREXFzcM/errKxEbGws/P39MWjQIPz973/H8ePHAQA2NjawtLSEubk5nJ2d4ezsDDMzM52cT1vBkERERAbP3rUbPP4wCBIjzT9rEiMjePxhkFZnkXLvP8LJ6/dR/dQD1NWCgJPX7+vk1tuNGzdQWVmJYcOGqdtMTU0xePBgZGdnP3M/KysreHl5qX92cXFRv9KDGJKIiKidGDd3Idx9B2i0ufsOwLi5C7U67q0iVYPbbxZqPyTVfcPt6YeyBUFo8EFtU1PNW4ESiaTR35brCPhMEhERtQsWNjaYuHQFHsjvoFghh62zi1ZnkOq42zf8OhMPB2ut1+Dt7Q0zMzP89NNPePPNNwHU3ko7f/485s2b1+zjmpmZobq6upWqNDwMSURE1K7YuXTTSTiq49nFBsN7dsGpHKXGLTdjiQTDvB0hc9R+SLK2tsbbb7+Nf/zjH7C3t0ePHj2wZs0aqFQqzJo1q9nH9fDwwNGjR3H16lU4ODhAKpXWm31qz3i7jYiIqIU2TRmIYd6OGm3DvB2xacpAndXwySefYOLEiZg2bRoGDRqEnJwcHD16FHZ2ds0+5pw5c9C7d2/4+/ujS5cuOHXqVCtW3PZJBN58bJbS0lJIpVKUlJSgc+fO+i6HiIia6cmTJ8jLy4NMJoOFhUWLjpWnLMPNwjJ4OFjrZAZpypQpMDY2xhdffKH1sQxJQ7/Tpvz95kwSERFRK5E5WiOkd1etB6SqqipcvnwZaWlp6N+/v1bH6sgYkoiIiAzMpUuX4O/vj/79+yMiIkLf5bRbfHCbiIjIwAwYMAAqVcNLD1DLcSaJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIiIiMlCCIOCvf/0r7O3tIZFIYGtr26IX2pImrpNERERkoH744Qfs2rULycnJ8PT0hJGRESwtLVt1jBkzZqC4uBiHDh1q1eMaAoYkIiIiA3Xjxg24uLggMDBQ36W0S7zdRkRE1FqUOcD1JKDwhtaHmjFjBt577z3k5+dDIpHAw8MDI0aM0Ljd5uHhgVWrVuEvf/kLOnXqhB49emDbtm0ax7lz5w7Cw8NhZ2cHBwcHjB8/Hjdv3gQALF++HLt378a3334LiUQCiUSC5ORkJCcnQyKRoLi4WH2cjIwMSCQS9b67du2Cra0tjh49ir59+8LGxgZjxoyBXC7XGH/nzp3o27cvLCws0KdPH8TExGjjcjULQxIREVFLqYqAz/8EbPYD9k4CNg2q/fnxA60N+dlnn2HFihXo3r075HI5zp07J9pv/fr18Pf3R3p6Ot555x28/fbbuHLlSm3ZKhVCQkJgY2ODkydP4qefflKHmYqKCkRFReE//uM/1OFGLpc3adZKpVJh3bp1+Pzzz3Hy5Enk5+cjKipKvX379u1YtmwZVq5ciezsbKxatQoffvghdu/e3bKL00p4u42IiKilEmYDucmabbnJwNezgGnfaGVIqVSKTp06wdjYGM7Ozs/sN3bsWLzzzjsAgEWLFuGf//wnkpOT0adPH+zfvx9GRkbYsWMHJBIJgNqZHVtbWyQnJyM0NBSWlpYoLy9vcIxnqaysRGxsLLy8vAAAf//737FixQr19o8//hjr16/Hn/70JwCATCbD5cuX8a9//QvTp09v8nitjSGJiIioJZQ5wI3j9duF6tr2whuAg5fu6/pfL7zwgvq/JRIJnJ2dce/ePQDAhQsXkJOTg06dOmns8+TJE9y40fJbhlZWVuqABAAuLi7qse/fv4+CggLMmjULc+bMUfepqqqCVCpt8ditgSGJiIioJR7kNby9KFevIcnU1FTjZ4lEgpqaGgBATU0N/Pz8sHfv3nr7denS5ZnHNDKqfVpHEAR1W2VlZaPGrtunrobt27djyJAhGv2MjY2fObYuMSQRERG1hJ2s4e32nrqpoxkGDRqEAwcOoGvXrujcubNoHzMzM1RXV2u01QUouVwOOzs7ALUPbjeFk5MTunXrhtzcXPz5z39uevE6wAe3iYiIWsLRG/B6GZA8NfshMa5t1+Ms0vP8+c9/hqOjI8aPH4/U1FTk5eUhJSUF77//Pm7fvg2g9htyv/76K65evQqlUonKykp4e3vDzc0Ny5cvx7Vr13DkyBGsX7++yeMvX74c0dHR+Oyzz3Dt2jVkZmZi586d+PTTT1v7VJuFIYmIiKilJsUBniM02zxH1La3YVZWVjh58iR69OiBP/3pT+jbty/+8pe/4PHjx+qZpTlz5qB3797w9/dHly5dcOrUKZiammLfvn24cuUK/vCHP2D16tX4r//6ryaPP3v2bOzYsQO7du2Cr68vgoODsWvXLshkz5md0xGJ8PsbitRopaWlkEqlKCkpeeYUJRERtX1PnjxBXl4eZDIZLCwsWnawwhu1zyDZe7bpGaT2rqHfaVP+fvOZJCIiotbi4MVw1I7o/XZbTEyMOun5+fkhNTW1wf4pKSnw8/ODhYUFPD09ERsbq7H9m2++gb+/P2xtbWFtbY0BAwbg888/1+izfPly9cqhdZ/mrP9ARERE7ZdeQ9KBAwcwb948LFu2DOnp6QgKCkJYWBjy8/NF++fl5WHs2LEICgpCeno6li5dirlz5yIhIUHdx97eHsuWLUNaWhp+/fVXzJw5EzNnzsTRo0c1jtW/f3/16qFyuRyZmZlaPVciIiIyLHp9JmnIkCEYNGgQtm7dqm7r27cvJkyYgOjo6Hr9Fy1ahMOHDyM7O1vdFhERgYsXLyItLe2Z4wwaNAjjxo3Dxx9/DKB2JunQoUNN/rri7/GZJCKi9qFVn0miNqG1nknS20xSRUUFLly4gNDQUI320NBQnD59WnSftLS0ev1Hjx6N8+fPiy5iJQgCjh8/jqtXr2L48OEa265fvw5XV1fIZDJMnjwZubm5DdZbXl6O0tJSjQ8RERG1X3oLSUqlEtXV1XByctJod3JygkKhEN1HoVCI9q+qqoJSqVS3lZSUwMbGBmZmZhg3bhw2bdqEUaNGqbcPGTIEe/bswdGjR7F9+3YoFAoEBgaisLDwmfVGR0dDKpWqP25ubs05bSIiIjIQen9wu+6FenUEQajX9rz+T7d36tQJGRkZOHfuHFauXInIyEgkJyert4eFhWHixInw9fXFyJEjceTIEQBo8K3DS5YsQUlJifpTUFDQ6HMkIiIiw6O3JQAcHR1hbGxcb9bo3r179WaL6jg7O4v2NzExgYODg7rNyMgI3t7eAIABAwYgOzsb0dHRGDFihOhxra2t4evri+vXrz+zXnNzc5ibmzfm1IiIiKgd0NtMkpmZGfz8/JCUlKTRnpSUhMDAQNF9AgIC6vU/duwY/P39671E7/cEQUB5efkzt5eXlyM7OxsuLi5NOAMiIiJqz/R6uy0yMhI7duxAfHw8srOzMX/+fOTn5yMiIgJA7S2ut956S90/IiICt27dQmRkJLKzsxEfH4+4uDhERUWp+0RHRyMpKQm5ubm4cuUKPv30U+zZswdTp05V94mKikJKSgry8vJw9uxZTJo0CaWlpZg+fbruTp6IiKiFRowYgXnz5um7jHZLrytuh4eHo7CwECtWrIBcLoePjw8SExPh7u4OoPbtwr9fM0kmkyExMRHz58/Hli1b4Orqio0bN2LixInqPmVlZXjnnXdw+/ZtWFpaok+fPvjiiy8QHh6u7nP79m1MmTIFSqUSXbp0wdChQ3HmzBn1uERERIbgm2++0biTkpOTg5UrVyIpKQn379+Hq6srhg4digULFsDf379Rx9y1axdmzpyp/rlr164YPHgwPvnkE/Tv31/dPmPGDBQXF+PQoUOtdj5tDd/d1kxcJ4mIqH1oL+sknT9/Hi+//DJ8fHywdOlS9OnTBw8fPsS3336Lf//730hJSWnUcXbt2oX3338fV69ehSAIuHPnDhYuXIjc3Fxcu3YNZmZmANp2SDL4dZKIiIjam5slN5F6OxW3Sm/pZLy6222CIGDGjBno2bMnUlNTMW7cOHh5eWHAgAH46KOP8O2336r3WbRoEXr16gUrKyt4enriww8/rLfWYN3rulxcXODv74/58+fj1q1buHr1qk7Oq63gC26JiIhaqKS8BItOLsKpu6fUbcNch2H18NWQmku1Pn5GRgaysrLw5Zdfwsio/vyHra2t+r87deqEXbt2wdXVFZmZmZgzZw46deqEhQsXih67uLgYX375JQA0+CWp9oghiYiIqIUWnVyEM/IzGm1n5Gew6OQixI6KfcZeraduCZs+ffo8t+8HH3yg/m8PDw8sWLAABw4c0AhJdYsyC4IAlUoFAHjttdcadfz2hCGJiIioBW6W3NSYQapTLVTj1N1TuFV6C+6dtfvFILGFlZ/l66+/xoYNG5CTk4NHjx6hqqqq3rM5nTp1wi+//IKqqiqkpKRg7dq1iI3Vfthra/hMEhERUQsUPGz4DQz5pfkNbm8NvXr1AgCNF8CLOXPmDCZPnoywsDB89913SE9Px7Jly1BRUaHRr25R5j59+uBvf/sbpk2bpvEt8Y6CIYmIiKgF3Do1/C7PHp17aL2GAQMGoF+/fli/fj1qamrqbS8uLgYAnDp1Cu7u7li2bBn8/f3Rs2dP3Lr1/IfM58+fj4sXL+LgwYOtXXqbxpBERETUAh5SDwxzHQZjibFGu7HEGMNch2n9VhtQe5tt586duHbtGoYPH47ExETk5ubi119/xcqVKzF+/HgAgLe3N/Lz87F//37cuHEDGzdubFTw6dy5M2bPno2PPvoIv185qKSkBBkZGRqf369vaOgYkoiIiFpo9fDVGOoyVKNtqMtQrB6+Wmc1DB48GOfPn4eXlxfmzJmDvn374rXXXkNWVhY2bNgAABg/fjzmz5+Pv//97xgwYABOnz6NDz/8sFHHf//995GdnY2vvvpK3ZacnIyBAwdqfP7zP/9TG6enF1xMspm4mCQRUfvQmotJ3iq9hfzSfPTo3EMnM0gkrrUWk+S324iIiFqJe2d3hqN2hLfbiIiIiEQwJBERERGJ4O02IqIOSKlU4sGDB7C3t4eDg4O+yyFqkxiSiIg6EJVKhYSEBNy4cUPd5uXlhUmTJsHS0lKPlRG1PbzdRkTUgSQkJCA3N1ejLTc3F19//bWeKiJquxiSiIg6CKVSiRs3buDplV8EQcCNGzdQWFiop8qI2iaGJCKiDuLBgwcNbi8qKtJRJUSGgSGJiKiDsLOza3C7vb29jiohMgwMSUREHYSjoyO8vLwgkUg02iUSCby8vPgtN6KnMCQREXUgkyZNgqenp0abp6cnJk2apKeKqLliY2PRqVMnVFVVqdsePXoEU1NTBAUFafRNTU2FRCLBtWvXAACnT5+GsbExxowZo9OaDQ2XACAi6kAsLS0xbdo0FBYWoqioiOskGbCQkBA8evQI58+fx9ChtS/XTU1NhbOzM86dOweVSgUrKysAtS+idXV1Ra9evQAA8fHxeO+997Bjxw7k5+ejR48eejuPtowzSUREHZCDgwN69uzJgNTKyvPy8OjkSVTcvKn1sXr37g1XV1ckJyer25KTkzF+/Hh4eXnh9OnTGu0hISEAgLKyMvz3f/833n77bbzyyivYtWuX1ms1VAxJRERELVRdXIz82XOQGzYWBX/9G26MCUP+7DmoLinR6rgjRozAiRMn1D+fOHECI0aMQHBwsLq9oqICaWlp6pB04MAB9O7dG71798bUqVOxc+fOestCUC2GJCIioha6E/UPlKWlabSVpaXhzoIorY47YsQInDp1ClVVVXj48CHS09MxfPhwBAcHq2eYzpw5g8ePH6tDUlxcHKZOnQoAGDNmDB49eoTjx49rtU5DxZBERETUAuV5eSj76SegulpzQ3U1yn76Sau33kJCQlBWVoZz584hNTUVvXr1QteuXREcHIxz586hrKwMycnJ6NGjBzw9PXH16lX8/PPPmDx5MgDAxMQE4eHhiI+P11qNhowPbhMREbVAZUFBg9sr8vNh5uGhlbG9vb3RvXt3nDhxAg8ePEBwcDAAwNnZGTKZDKdOncKJEyfw0ksvAaidRaqqqkK3bt3UxxAEAaampnjw4MFz19LqaDiTRERE1AKmbm4NbjfT8jfHQkJCkJycjOTkZIwYMULdHhwcjKNHj+LMmTMICQlBVVUV9uzZg/Xr1yMjI0P9uXjxItzd3bF3716t1mmIOJNERETUAuYyGaxffLH2maTf33IzNoZ1QIDWZpHqhISE4N1330VlZaV6JgmoDUlvv/02njx5gpCQEHz33Xd48OABZs2aBalUqnGMSZMmIS4uDn//+9+1Wquh4UwSERFRC3Vbvw7WAQEabdYBAei2fp3Wxw4JCcHjx4/h7e0NJycndXtwcDAePnwILy8vuLm5IS4uDiNHjqwXkABg4sSJyMjIwC+//KL1eg0JZ5KIiIhayFgqRY8d21Fx82btM0g9emh9BqmOh4eH6Ff4u3fvrtH+P//zP888xqBBg7gMgAiGJCIiolZi5uGhs3BE2sfbbUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQi9B6SYmJiIJPJYGFhAT8/P6SmpjbYPyUlBX5+frCwsICnpydiY2M1tn/zzTfw9/eHra0trK2tMWDAAHz++ectHpeIiKgtUigUeO+99+Dp6Qlzc3O4ubnh1VdfxfHjxwHUvrZkw4YNzz3Ol19+CWNjY0RERNTblpycDIlEAolEAiMjI0ilUgwcOBALFy6EXC5vdK1ZWVmYOHEiPDw8IJFIGlUXAGRmZiI4OBiWlpbo1q0bVqxYoZPXqOg1JB04cADz5s3DsmXLkJ6ejqCgIISFhSE/P1+0f15eHsaOHYugoCCkp6dj6dKlmDt3LhISEtR97O3tsWzZMqSlpeHXX3/FzJkzMXPmTBw9erTZ4xIREbVFN2/ehJ+fH/79739jzZo1yMzMxA8//ICQkBC8++67TTpWfHw8Fi5ciP3790OlUon2uXr1Ku7evYtz585h0aJF+PHHH+Hj44PMzMxGjaFSqeDp6YlPPvkEzs7OjdqntLQUo0aNgqurK86dO4dNmzZh3bp1+PTTTxt9bs0m6NHgwYOFiIgIjbY+ffoIixcvFu2/cOFCoU+fPhptf/vb34ShQ4c2OM7AgQOFDz74oNnjiikpKREACCUlJY3eh4iI2p7Hjx8Lly9fFh4/ftziYz1QlAk3M5XCA0VZK1T2fGFhYUK3bt2ER48e1a/lwQNBEATB3d1d+Oc//9ngcfLy8gRLS0uhuLhYGDJkiLB7926N7SdOnBAAqI9ZR6VSCb179xaGDRvW5NobU5cgCEJMTIwglUqFJ0+eqNuio6MFV1dXoaamRnSfhn6nTfn7rbeZpIqKCly4cAGhoaEa7aGhoTh9+rToPmlpafX6jx49GufPn0dlZWW9/oIg4Pjx47h69SqGDx/e7HEBoLy8HKWlpRofIiIiAHhSVonDGzOw96Mz+G7zRez96AwOb8zAk7L6f5taS1FREX744Qe8++67sLa2rrfd1ta20ceKj4/HuHHjIJVKMXXqVMTFxTVqP0tLS0RERODUqVO4d+9eo8drirS0NAQHB8Pc3FzdNnr0aNy9exc3b97Uyph19BaSlEolqqur4eTkpNHu5OQEhUIhuo9CoRDtX1VVBaVSqW4rKSmBjY0NzMzMMG7cOGzatAmjRo1q9rgAEB0dDalUqv64ubk16XyJiEg7Ku+r8PhqESqVj/VWw7G4LNy+UqTRdvtKEY7FZWltzJycHAiCgD59+rToODU1Ndi1axemTp0KAJg8eTLS0tKQk5PTqP3rxtdWYHnW3/66bdqk9we3JRKJxs+CINRre17/p9s7deqEjIwMnDt3DitXrkRkZCSSk5NbNO6SJUtQUlKi/hQUFDR4XkREpF01qkrcj8vEb+svoHBnFn5bdx734zJRo9Le7I2Y4t9UKLhcBKFGs12oAQouF6H4N/Hne1pK7O9fcxw7dgxlZWUICwsDADg6OiI0NBTx8fE6raMhjfnbrw16C0mOjo4wNjaulwLv3btXLzHWcXZ2Fu1vYmICBwcHdZuRkRG8vb0xYMAALFiwAJMmTUJ0dHSzxwUAc3NzdO7cWeNDRET6U7jvCspzijXaynOKUbjvik7rKLnf8AzW87Y3V8+ePSGRSJCdnd2i48THx6OoqAhWVlYwMTGBiYkJEhMTsXv3blRXVz93/7rxPTw8WlTHszzrbz+ABv9utwa9hSQzMzP4+fkhKSlJoz0pKQmBgYGi+wQEBNTrf+zYMfj7+8PU1PSZYwmCgPLy8maPS0REbUvlfRXKrxcDT38LXADKrxfr9NabtItli7Y3l729PUaPHo0tW7agrKys3vbi4uLnHqOwsBDffvst9u/fj4yMDI3Po0eP8P333ze4/+PHj7Ft2zYMHz4cXbp0ae6pNCggIAAnT55ERUWFuu3YsWNwdXXVWjCro9fbbZGRkdixYwfi4+ORnZ2N+fPnIz8/X71Gw5IlS/DWW2+p+0dERODWrVuIjIxEdnY24uPjERcXh6ioKHWf6OhoJCUlITc3F1euXMGnn36KPXv2qO+1NmZcIiJq26qKnjS8vVB3IcnWyQpu/ewheeovqsQIcOtnD1snK62NHRMTg+rqagwePBgJCQm4fv06srOzsXHjRgQEBKj73blzp14IKioqwueffw4HBwe88cYb8PHxUX9eeOEFvPLKK/Ue4L537x4UCgWuX7+O/fv3Y9iwYVAqldi6dWuj6q2oqFCPX1FRoa7r988/bd68GS+//LL65zfffBPm5uaYMWMGLl26hIMHD2LVqlWIjIzU+u02E60e/TnCw8NRWFiIFStWQC6Xw8fHB4mJiXB3dwcAyOVyjbWLZDIZEhMTMX/+fGzZsgWurq7YuHEjJk6cqO5TVlaGd955B7dv34alpSX69OmDL774AuHh4Y0el4iI2jYTe4uGtztoZ/bmWUJn9cexuCwUXP6/h7e797FH6Kz+Wh1XJpPhl19+wcqVK7FgwQLI5XJ06dIFfn5+GsFl3bp1WLdunca+O3fuRHx8PF5//XUYGdWfM5k4cSLCw8Px22+/qdt69+4NiUQCGxsbeHp6IjQ0FJGRkY1e8+ju3bsYOHBgvbqCg4PVzw4rlUrcuHFD3UcqlSIpKQnvvvsu/P39YWdnh8jISERGRjZqzJaQCIIOlqxsh0pLSyGVSlFSUsLnk4iI9OB+XGbtM0m//ysmAcy9bdFllm+jj/PkyRPk5eWp38LQEsW/qVBy/zGkXSy1OoNEDWvod9qUv996/3YbERFRczhM6QNzb1uNNnNvWzhMadlX4lvC1skK7j4ODEjthF5vtxERETWXkZUpuszyRaXyMaoKH8PEwRKmjrq9zUaabGxsnrnt+++/R1BQkA6raTmGJCIiMmimjgxHbUVGRsYzt3Xr1k13hbQShiQiIiJqFd7e3vouoVXxmSQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIiIiIhLBkEREREQkgiGJiIjIgCkUCrz//vvw9vaGhYUFnJyc8OKLLyI2NhYqlQoAkJ6ejldeeQVdu3aFhYUFPDw8EB4eDqVSqT5OQkIChgwZAqlUik6dOqF///5YsGCBvk6rTeA6SURERAYqNzcXw4YNg62tLVatWgVfX19UVVXh2rVriI+Ph6urK4YOHYqRI0fi1VdfxdGjR2Fra4u8vDwcPnxYHaJ+/PFHTJ48GatWrcJrr70GiUSCy5cv4/jx43o+Q/3iC26biS+4JSJqH1rzBbdFd++g5Dc5bJ1dYOei/RWmx4wZg6ysLFy5cgXW1tb1tguCgG+//RZvvPEGHj9+DBMT8bmRefPm4eLFizhx4oS2S9aJ1nrBLWeSiIiIWujxo4dI3LgWNy/+om7z+MMgjJu7EBYNvM+sJQoLC3Hs2DGsWrVKNCABgEQigbOzM6qqqnDw4EFMmjQJEomkXj9nZ2d8+eWXuHTpEnx8fLRSryHiM0lEREQtlLhxLW5lZmi03crMwJGNa7Q2Zk5ODgRBQO/evTXaHR0dYWNjAxsbGyxatAhDhw7F0qVL8eabb8LR0RFhYWFYu3YtfvvtN/U+7733Hv74xz/C19cXHh4emDx5MuLj41FeXq61+g0BQxIREVELFN29g5sXf4FQU6PRLtTU4ObFX/BAfker4z89M/Tzzz8jIyMD/fv3V4eclStXQqFQIDY2Fv369UNsbCz69OmDzMxMAIC1tTWOHDmCnJwcfPDBB7CxscGCBQswePBg9XNLHRFDEhERUQuU/CZvcHuxouHtzeXt7Q2JRIIrV65otHt6esLb2xuWlpYa7Q4ODnjjjTewfv16ZGdnw9XVFevWrdPo4+XlhdmzZ2PHjh345ZdfcPnyZRw4cEAr9RsChiQiIqIWkDq5NLjd1rnh7c3l4OCAUaNGYfPmzSgrK2vSvmZmZvDy8mpwPw8PD1hZWTX52O0JH9wmIiJqAXvXbvD4wyDcyszQuOUmMTKCu+8ArX7LLSYmBsOGDYO/vz+WL1+OF154AUZGRjh37hyuXLkCPz8/fPfdd9i/fz8mT56MXr16QRAE/M///A8SExOxc+dOAMDy5cuhUqkwduxYuLu7o7i4GBs3bkRlZSVGjRqltfrbOoYkIiKiFho3dyGObFyj8e02d98BGDd3oVbH9fLyQnp6OlatWoUlS5bg9u3bMDc3R79+/RAVFYV33nkHCoUCVlZWWLBgAQoKCmBubo6ePXtix44dmDZtGgAgODgYW7ZswVtvvYXffvsNdnZ2GDhwII4dO1bvwfCOhOskNRPXSSIiah9ac52kB/I7KFbobp0kEsd1koiIiNoYO5duDEftCB/cJiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIiIiIhLBkERERGTACgoKMGvWLLi6usLMzAzu7u54//33UVhYqNEvJycHM2fORPfu3WFubg6ZTIYpU6bg/Pnz6j4nTpxASEgI7O3tYWVlhZ49e2L69OmoqqrS9Wm1CQxJREREBio3Nxf+/v64du0a9u3bh5ycHMTGxuL48eMICAhAUVERAOD8+fPw8/PDtWvX8K9//QuXL1/GwYMH0adPHyxYsAAAkJWVhbCwMPzxj3/EyZMnkZmZiU2bNsHU1BQ1NTX6PE294Qtum4kvuCUiah9a8wW3lfdVqCp6AhMHS5g6WrZShc8WFhaGS5cu4dq1a7C0/L/xFAoFvLy88NZbbyEmJga+vr6wsLDAzz//DCMjzfmR4uJi2NraYsOGDfjss8+Ql5en9bq1jS+4JSIiaiNqVJUo3HcF5deL1W3mPW3hMKUPjKxMtTJmUVERjh49ipUrV2oEJABwdnbGn//8Zxw4cAB//etfkZWVhS+//LJeQAIAW1tb9T5yuRwnT57E8OHDtVKzoeHtNiIiohYq3HcF5TnFGm3lOcUo3HdFa2Nev34dgiCgb9++otv79u2LBw8e4Pr16wCAPn36NHi8N954A1OmTEFwcDBcXFzw+uuvY/PmzSgtLW312g0FQxIREVELVN5X1c4gPf3wigCUXy9GpfKxPspC3dM0df9XIpE02N/Y2Bg7d+7E7du3sWbNGri6umLlypXo378/5HK51uttixiSiIiIWqCq6EnD2wu1E5K8vb0hkUhw+fJl0e1XrlyBnZ0devXqBQDIzs5u1HG7deuGadOmYcuWLbh8+TKePHmC2NjYVqvbkDAkERERtYCJfcMPe5s4aOcBbgcHB4waNQoxMTF4/FgziCkUCuzduxfh4eEYMGAA+vXrh/Xr14t+S624uPiZY9jZ2cHFxQVlZWWtXb5B0HtIiomJUT997ufnh9TU1Ab7p6SkwM/PDxYWFvD09KyXbrdv346goCDY2dnBzs4OI0eOxM8//6zRZ/ny5ZBIJBofZ2fnVj83IiJq/0y7WMG8py3w9N0sSe3D29r8ltvmzZtRXl6O0aNH4+TJkygoKMAPP/yAUaNGoVu3bli5ciUkEgl27tyJa9euYfjw4UhMTERubi5+/fVXrFy5EuPHjwcA/Otf/8Lbb7+NY8eO4caNG8jKysKiRYuQlZWFV199VWvn0JbpNSQdOHAA8+bNw7Jly5Ceno6goCCEhYUhPz9ftH9eXh7Gjh2LoKAgpKenY+nSpZg7dy4SEhLUfZKTkzFlyhScOHECaWlp6NGjB0JDQ3Hnzh2NY9XdY637ZGZmavVciYio/XKY0gfm3rYabebetd9u06aePXvi/Pnz8PLyQnh4OLy8vPDXv/4VISEhSEtLg729PQBg8ODB6n5z5sxB37598dprryErKwsbNmxQ93n06BEiIiLQv39/BAcH48yZMzh06BCCg4O1eh5tlV7XSRoyZAgGDRqErVu3qtv69u2LCRMmIDo6ul7/RYsW4fDhwxr3VSMiInDx4kWkpaWJjlFdXQ07Ozts3rwZb731FoDamaRDhw4hIyOj2bVznSQiovahVddJUj5GVeFjna2TROJaa50kvc0kVVRU4MKFCwgNDdVoDw0NxenTp0X3SUtLq9d/9OjROH/+PCorK0X3UalUqKysVKfpOtevX4erqytkMhkmT56M3NzcBustLy9HaWmpxoeIiOj3TB0tYdnbngGpndBbSFIqlaiuroaTk5NGu5OTExQKheg+CoVCtH9VVRWUSqXoPosXL0a3bt0wcuRIdduQIUOwZ88eHD16FNu3b4dCoUBgYGC999z8XnR0NKRSqfrj5ubW2FMlIiIiA6T3B7efXrdBEIQG13IQ6y/WDgBr1qzBvn378M0332hMt4WFhWHixInw9fXFyJEjceTIEQDA7t27nznukiVLUFJSov4UFBQ8/+SIiIjIYOnttSSOjo4wNjauN2t07969erNFdZydnUX7m5iYwMHBQaN93bp1WLVqFX788Ue88MILDdZibW0NX19f9aqkYszNzWFubt7gcYiIiKj90NtMkpmZGfz8/JCUlKTRnpSUhMDAQNF9AgIC6vU/duwY/P39YWr6f+/GWbt2LT7++GP88MMP8Pf3f24t5eXlyM7OhouLSzPOhIiIiNojvd5ui4yMxI4dOxAfH4/s7GzMnz8f+fn5iIiIAFB7i6vuG2lA7TfZbt26hcjISGRnZyM+Ph5xcXGIiopS91mzZg0++OADxMfHw8PDAwqFAgqFAo8ePVL3iYqKQkpKCvLy8nD27FlMmjQJpaWlmD59uu5OnoiIiNo0vd1uA4Dw8HAUFhZixYoVkMvl8PHxQWJiItzd3QEAcrlcY80kmUyGxMREzJ8/H1u2bIGrqys2btyIiRMnqvvExMSgoqICkyZN0hjro48+wvLlywEAt2/fxpQpU6BUKtGlSxcMHToUZ86cUY9LREREpNd1kgwZ10kiImofWnOdJGobDH6dJCIiIqK2jCGJiIiISARDEhERkYGaMWNGvRe2SyQS5OTkNLhfcnIyJBIJiouLNX6u+zg4OOCll17CqVOnNPZbvnw5BgwYoKWzaXsYkoiIiAzYmDFjNF7YLpfLIZPJmnWsq1evQi6XIzk5GV26dMG4ceNw7969Vq7YcDAkERERtRKlUonr1683+Jqr1mZubg5nZ2eNz2effQZfX19YW1vDzc0N77zzjsZSOM/StWtXODs7w9fXFx988AFKSkpw9uxZHZxF26TXJQCIiIjaA5VKhYSEBNy4cUPd5uXlhUmTJsHSUvcvuzUyMsLGjRvh4eGBvLw8vPPOO1i4cCFiYmIatb9KpcLOnTsBQGOx5o6GIYmIiKiFEhISkJubq9GWm5uLr7/+GtOmTdPq2N999x1sbGzUP4eFheGrr75S/yyTyfDxxx/j7bfffm5I6t69O4DakCQIAvz8/PDyyy9rp3ADwJBERETUAkqlUmMGqY4gCLhx4wYKCwvrvV+0NYWEhGDr1q3qn62trXHixAmsWrUKly9fRmlpKaqqqvDkyROUlZXB2tr6mcdKTU2FtbU10tPTsWjRIuzatYszSURERNQ8Dx48aHB7UVGRVkOStbU1vL291T/funULY8eORUREBD7++GPY29vjp59+wqxZs1BZWdngsWQyGWxtbdGrVy88efIEr7/+Oi5dutRhX/DOB7eJiIhawM7OrsHt9vb2Oqqk1vnz51FVVYX169dj6NCh6NWrF+7evdvk40ybNg01NTWNfo6pPWJIIiIiagFHR0d4eXlBIpFotEskEnh5eWl1FkmMl5cXqqqqsGnTJuTm5uLzzz9HbGxsk49jZGSEefPm4ZNPPoFKpVK3P378GBkZGRqf563LZKgYkoiIiFpo0qRJ8PT01Gjz9PSs97J1XRgwYAA+/fRTrF69Gj4+Pti7dy+io6Obday//OUvqKysxObNm9Vt165dw8CBAzU+s2fPbq3y2xS+4LaZ+IJbIqL2oTVfcFtYWIiioiLY29vrfAaJ/k9rveCWD24TERG1EgcHB4ajdoS324iIiIhEMCQRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZGIJi8B8NVXX+HQoUOorKzEyJEj8de//lUbdRERERHpVZNC0rZt2xAREYGePXvCwsICCQkJyMvLa/ZKnkRERERtVZNut23atAnLli3D1atXcfHiRcTFxWksVU5ERETUXjQpJOXm5mLmzJnqn6dNm4by8nIoFIpWL4yIiIgaNmPGDEgkknqfnJwcpKen45VXXkHXrl1hYWEBDw8PhIeHQ6lUAgBcXFywevVqjeMtWrQIEokEx48f12h/+eWX8eabb+rsvNqKJoWkx48fw8bGRv2zsbExzM3NNd4OTERERLozZswYyOVyjU+nTp0wcuRIODo64ujRo8jOzkZ8fDxcXFzUf7NHjBiBEydOaBwrOTkZbm5uGu0VFRVIS0tDSEiITs+rLWjyg9s7duzQCEpVVVXYtWsXHB0d1W1z585tneqIiIgMiEqVB9XjW7CydIeVlUwnY5qbm8PZ2Vmj7dChQygtLcWOHTtgYlL7p14mk+Gll15S9wkJCcGCBQtQVVUFExMTPHz4EOnp6diwYQO+/PJLdb+zZ8/i8ePHDEnP06NHD2zfvl2jzdnZGZ9//rn6Z4lEwpBEREQdSmVlMS5lzUNRUaq6zd4+CD79P4OpqVTn9Tg7O6OqqgoHDx7EpEmTIJFI6vUJCQnBo0ePcO7cOQQEBCA1NRW9evXCpEmTMH/+fKhUKlhZWeHEiRPo3r07vL29dX4e+takkHTz5k0tlUFERGS4agPSaY22oqLTuJT1PgYO2KXVsb/77juNOzxhYWH46quvsHTpUrz55puIiIjA4MGD8dJLL+Gtt96Ck5MTAKBnz57o1q0bkpOTERAQgOTkZAQHB6Nr167w9PTEqVOnMGrUKCQnJ3fIWSSgGYtJ1tTUID4+Hq+88gp8fHzg6+uL8ePHY8+ePRAEQRs1EhERtVkqVd7/ziBVP7WlGkVFqVCp8rQ6fkhICDIyMtSfjRs3AgBWrlwJhUKB2NhY9OvXD7GxsejTpw8yMzPV+44YMQLJyckAap9HGjFiBAAgODgYycnJKC8vx5kzZzRu03UkTQpJgiDg1VdfxezZs3Hnzh34+vqif//+uHnzJmbMmIHXX39dW3USERG1SarHt1q0vaWsra3h7e2t/ri4uKi3OTg44I033sD69euRnZ0NV1dXrFu3Tr09JCQEp06dQmFhIdLT0zF8+HAAtSHpxIkTOHPmTId9Hglo4u22Xbt2ITU1FcePH693wf79739jwoQJ2LNnD956661WLZKIiKitsrJ0b9F2XTEzM4OXlxfKysrUbSEhISgrK8Onn36Knj17qm/FBQcHY/r06Thy5AhkMhnc3dvGOehak2aS9u3bh6VLl4omypdeegmLFy/G3r17W604IiKits7KSgZ7+yAAxk9tMYa9fZDOvuX2e9999x2mTp2K7777DteuXcPVq1exbt06JCYmYvz48ep+np6e6NGjBzZt2oTg4GB1u6urK9zd3REbG9thZ5GAJoakX3/9FWPGjHnm9rCwMFy8eLHFRRERERkSn/6fwd4+UKPN3j4QPv0/00s9/fr1g5WVFRYsWIABAwZg6NCh+O///m/s2LED06ZN0+gbEhKChw8fqp9HqhMcHIyHDx926JAkEZrwtLWZmRlu3bqlcb/z9+7evQuZTIby8vJWK7CtKi0thVQqRUlJCTp37qzvcoiIqJmePHmCvLw8yGQyWFhYtOhY+lgniepr6HfalL/fTXomqbq6Wr0olRhjY2NUVVU15ZBERETthpWVjOGoHWlSSBIEATNmzIC5ubno9o4wg0REREQdQ5NC0vTp05/bh99sIyIiovagSSFp586d2qqDiIiIqE1p8orbRERE7RHfGtF+tNbvkiGJiIg6NFNTUwCASqXScyXUWup+l3W/2+Zq0u02bYiJicHatWshl8vRv39/bNiwAUFBQc/sn5KSgsjISGRlZcHV1RULFy5ERESEevv27duxZ88eXLp0CQDg5+eHVatWYfDgwS0al4iI2idjY2PY2tri3r17AAArKytIJBI9V0XNIQgCVCoV7t27B1tbWxgbP73AZ9PoNSQdOHAA8+bNQ0xMDIYNG4Z//etfCAsLw+XLl9GjR496/fPy8jB27FjMmTMHX3zxBU6dOoV33nkHXbp0wcSJEwHUvqBvypQpCAwMhIWFBdasWYPQ0FBkZWWhW7duzRqXiIjaN2dnZwBQByUybLa2turfaUs0aTHJ1jZkyBAMGjQIW7duVbf17dsXEyZMQHR0dL3+ixYtwuHDh5Gdna1ui4iIwMWLF5GWliY6RnV1Nezs7LB582b1N++aOq4YLiZJRNT+VFdXo7KyUt9lUAuYmpo2OIOktcUkW1NFRQUuXLiAxYsXa7SHhobi9OnTovukpaUhNDRUo2306NGIi4tDZWWl6L1HlUqFyspK2NvbN3tcoHYNqN+vA1VaWtrwCRIRkcExNjZu8S0aaj/09uC2UqlEdXW1+o3DdZycnKBQKET3USgUov2rqqqgVCpF91m8eDG6deuGkSNHNntcAIiOjoZUKlV/3NzcnnuOREREZLj0/u22px+OEwShwQfmxPqLtQPAmjVrsG/fPnzzzTf13t3S1HGXLFmCkpIS9aegoOCZfYmIiMjw6e12m6OjI4yNjevN3ty7d6/eLE8dZ2dn0f4mJiZwcHDQaF+3bh1WrVqFH3/8ES+88EKLxgUAc3PzZ76OhYiIiNofvc0kmZmZwc/PD0lJSRrtSUlJCAwMFN0nICCgXv9jx47B399f43mktWvX4uOPP8YPP/wAf3//Fo9LREREHY9elwCIjIzEtGnT4O/vj4CAAGzbtg35+fnqdY+WLFmCO3fuYM+ePQBqv8m2efNmREZGYs6cOUhLS0NcXBz27dunPuaaNWvw4Ycf4ssvv4SHh4d6xsjGxgY2NjaNGpeIiIhIryEpPDwchYWFWLFiBeRyOXx8fJCYmAh3d3cAgFwuR35+vrq/TCZDYmIi5s+fjy1btsDV1RUbN25Ur5EE1C4SWVFRgUmTJmmM9dFHH2H58uWNGpeIiIhIr+skGTKuk0RERGR4mvL3W+/fbiMiIiJqixiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiESY6LsAEqHMAR7kAfaegIOXvqshIiLqkBiS2hJVEZAwG7hx/P/avF4GJsUBlnb6q4uIiKgD4u22tiRhNpCbrNmWmwx8PUsf1RAREXVoDElthTKndgZJqEZ5qTEe3TVHxUNjQKiubS+8oe8KiYiIOhTebmsrHuShulyCO2l2KFNYqJutnZ+gW+ADGBfl8vkkIiIiHeJMUlthJ6sNSL+ZazSX/WaOO6ftah/iJiIiIp1hSGojyh8a184gCRLNDYIEZQqL2ltvREREpDMMSW1EZUFBg9sr8vN1VAkREREBDElthqmbW4PbzXr00FElREREBDAktRnmMhmsX3wRMH7qtpqxMaxffBFmHh56qYuIiKijYkhqQ7qtXwfrgACNNuuAAHRbv05PFREREXVcXAKgDTGWStFjx3ZU3LyJivx8mPXowRkkIiIiPWFIaoPMPDwYjoiIiPRM77fbYmJiIJPJYGFhAT8/P6SmpjbYPyUlBX5+frCwsICnpydiY2M1tmdlZWHixInw8PCARCLBhg0b6h1j+fLlkEgkGh9nZ+fWPC0iIiIycHoNSQcOHMC8efOwbNkypKenIygoCGFhYch/xtfd8/LyMHbsWAQFBSE9PR1Lly7F3LlzkZCQoO6jUqng6emJTz75pMHg079/f8jlcvUnMzOz1c+PiIiIDJdeb7d9+umnmDVrFmbPng0A2LBhA44ePYqtW7ciOjq6Xv/Y2Fj06NFDPTvUt29fnD9/HuvWrcPEiRMBAH/84x/xxz/+EQCwePHiZ45tYmLC2SMiIiJ6Jr3NJFVUVODChQsIDQ3VaA8NDcXp06dF90lLS6vXf/To0Th//jwqKyubNP7169fh6uoKmUyGyZMnIzc3t8H+5eXlKC0t1fgQERFR+6W3kKRUKlFdXQ0nJyeNdicnJygUCtF9FAqFaP+qqioolcpGjz1kyBDs2bMHR48exfbt26FQKBAYGIjCwsJn7hMdHQ2pVKr+uD1n8UciIiIybHp/cFsi0XxXmSAI9dqe11+svSFhYWGYOHEifH19MXLkSBw5cgQAsHv37mfus2TJEpSUlKg/Bc95jQgREREZNr09k+To6AhjY+N6s0b37t2rN1tUx9nZWbS/iYkJHBwcml2LtbU1fH19cf369Wf2MTc3h7m5ebPHICIiIsOit5kkMzMz+Pn5ISkpSaM9KSkJgYGBovsEBATU63/s2DH4+/vD1NS02bWUl5cjOzsbLi4uzT4GERERtS96vd0WGRmJHTt2ID4+HtnZ2Zg/fz7y8/MREREBoPYW11tvvaXuHxERgVu3biEyMhLZ2dmIj49HXFwcoqKi1H0qKiqQkZGBjIwMVFRU4M6dO8jIyEBOTo66T1RUFFJSUpCXl4ezZ89i0qRJKC0txfTp03V38kRERNSm6XUJgPDwcBQWFmLFihWQy+Xw8fFBYmIi3N3dAQByuVxjzSSZTIbExETMnz8fW7ZsgaurKzZu3Kj++j8A3L17FwMHDlT/vG7dOqxbtw7BwcFITk4GANy+fRtTpkyBUqlEly5dMHToUJw5c0Y9LhEREZFEqHvymZqktLQUUqkUJSUl6Ny5s77LISIiokZoyt9vvX+7jYiIiKgtYkgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCRCry+4JSIiIk3Fv6lQcv8xpF0sYetkpe9yOjSGJCIiojbgSVkljsVloeBykbrNrZ89Qmf1h4W1qR4r67h4u42IiKgNOBaXhdtXijTabl8pwrG4LD1VRAxJREREelb8mwoFl4sg1Gi2CzVAweUiFP+m0k9hHRxDEhERkZ6V3H/cou2kHQxJREREeibtYtmi7aQdDElERNQu3Cy5idTbqbhVekvfpTSZrZMV3PrZQ/LUX2WJUe3D2/yWm37w221ERGTQSspLsOjkIpy6e0rdNsx1GFYPXw2puVSPlTVN6Kz+9b7d1r1P7bfbSD8kgiAI+i7CEJWWlkIqlaKkpASdO3fWdzlERB1WRFIEzsjPoFqoVrcZS4wx1GUoYkfF6rGy5uE6SdrVlL/fnEkiIiKDdbPkpsYMUp1qoRqn7p7CrdJbcO/srofKms/WyYrhqI3gM0lERGSwCh4WNLg9vzRfR5VQe8SQREREBsutk1uD23t07qGjSqg9YkgiIiKD5SH1wDDXYTCWGGu0G0uMMcx1mMHdaqO2hSGJiIgM2urhqzHUZahG21CXoVg9fLWeKqL2gg9uExGRQZOaSxE7Kha3Sm8hvzQfPTr34AwStQqGJCIiahfcO7szHFGr4u02IiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISofeQFBMTA5lMBgsLC/j5+SE1NbXB/ikpKfDz84OFhQU8PT0RGxursT0rKwsTJ06Eh4cHJBIJNmzY0CrjEhERUcei15B04MABzJs3D8uWLUN6ejqCgoIQFhaG/Px80f55eXkYO3YsgoKCkJ6ejqVLl2Lu3LlISEhQ91GpVPD09MQnn3wCZ2fnVhmXiIiIOh6JIAiCvgYfMmQIBg0ahK1bt6rb+vbtiwkTJiA6Orpe/0WLFuHw4cPIzs5Wt0VERODixYtIS0ur19/DwwPz5s3DvHnzWjSumNLSUkilUpSUlKBz586N2oeIiIj0qyl/v/U2k1RRUYELFy4gNDRUoz00NBSnT58W3SctLa1e/9GjR+P8+fOorKzU2rgAUF5ejtLSUo0PERERtV96C0lKpRLV1dVwcnLSaHdycoJCoRDdR6FQiPavqqqCUqnU2rgAEB0dDalUqv64ubk1ajwiIiIyTHp/cFsikWj8LAhCvbbn9Rdrb+1xlyxZgpKSEvWnoKCgSeMRERGRYTHR18COjo4wNjauN3tz7969erM8dZydnUX7m5iYwMHBQWvjAoC5uTnMzc0bNQYREREZPr3NJJmZmcHPzw9JSUka7UlJSQgMDBTdJyAgoF7/Y8eOwd/fH6amplobl4iIiDoevc0kAUBkZCSmTZsGf39/BAQEYNu2bcjPz0dERASA2ltcd+7cwZ49ewDUfpNt8+bNiIyMxJw5c5CWloa4uDjs27dPfcyKigpcvnxZ/d937txBRkYGbGxs4O3t3ahxiYiIiCDo2ZYtWwR3d3fBzMxMGDRokJCSkqLeNn36dCE4OFijf3JysjBw4EDBzMxM8PDwELZu3aqxPS8vTwBQ7/P0cRoatzFKSkoEAEJJSUmT9iMiIiL9acrfb72uk2TIuE4SERGR4TGIdZKIiIiI2jKGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQgTfRdARERErUOlyoPq8S1YWbrDykqm73IMHkMSERGRgausLMalrHkoKkpVt9nbB8Gn/2cwNZXqsTLDxtttREREBq42IJ3WaCsqOo1LWe/rqaL2gSGJiIjIgKlUef87g1T91JZqFBWlQqXK00dZ7QJDEhERkQFTPb7Vou30bAxJREREBszK0r1F2+nZGJKIiIgMmJWVDPb2QQCMn9piDHv7IH7LrQUYkoiIiAycT//PYG8fqNFmbx8In/6f6ami9oFLABARERk4U1MpBg7YxXWSWhlDEhERUTthZSVjOGpFvN1GREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCL67jYiIiNqc3PuPcKtIBQ8Ha8gcrfVSg95nkmJiYiCTyWBhYQE/Pz+kpqY22D8lJQV+fn6wsLCAp6cnYmNj6/VJSEhAv379YG5ujn79+uHgwYMa25cvXw6JRKLxcXZ2btXzIiIioqYrVlXgrbif8dL6FMzceQ4h65LxVtzPKFFV6rwWvYakAwcOYN68eVi2bBnS09MRFBSEsLAw5Ofni/bPy8vD2LFjERQUhPT0dCxduhRz585FQkKCuk9aWhrCw8Mxbdo0XLx4EdOmTcN//Md/4OzZsxrH6t+/P+RyufqTmZmp1XMlIiKi55u7LwOncpQabadylHhvX7rOa5EIgiDofNT/NWTIEAwaNAhbt25Vt/Xt2xcTJkxAdHR0vf6LFi3C4cOHkZ2drW6LiIjAxYsXkZaWBgAIDw9HaWkpvv/+e3WfMWPGwM7ODvv27QNQO5N06NAhZGRkNLv20tJSSKVSlJSUoHPnzs0+DhEREdXKvf8IL61Peeb2E1EjWnzrrSl/v/U2k1RRUYELFy4gNDRUoz00NBSnT58W3SctLa1e/9GjR+P8+fOorKxssM/Tx7x+/TpcXV0hk8kwefJk5ObmNlhveXk5SktLNT5ERETUem4VqRrcfrOwTEeV1NJbSFIqlaiuroaTk5NGu5OTExQKheg+CoVCtH9VVRWUSmWDfX5/zCFDhmDPnj04evQotm/fDoVCgcDAQBQWFj6z3ujoaEilUvXHzc2tSedLREREDXO3t2pwu4eDbh/g1vuD2xKJRONnQRDqtT2v/9PtzztmWFgYJk6cCF9fX4wcORJHjhwBAOzevfuZ4y5ZsgQlJSXqT0FBwXPOjIiIiJrCs4sNhvfsAuOn/o4bSyQY3rOLzr/lpreQ5OjoCGNj43qzRvfu3as3E1TH2dlZtL+JiQkcHBwa7POsYwKAtbU1fH19cf369Wf2MTc3R+fOnTU+RERE1Lo2TRmIYd6OGm3DvB2xacpAndeit5BkZmYGPz8/JCUlabQnJSUhMDBQdJ+AgIB6/Y8dOwZ/f3+Ympo22OdZxwRqnzfKzs6Gi4tLc06FiIiIWonUyhR7Zg3GiagR2DnzjzgRNQJ7Zg2G1MpU57XodTHJyMhITJs2Df7+/ggICMC2bduQn5+PiIgIALW3uO7cuYM9e/YAqP0m2+bNmxEZGYk5c+YgLS0NcXFx6m+tAcD777+P4cOHY/Xq1Rg/fjy+/fZb/Pjjj/jpp5/UfaKiovDqq6+iR48euHfvHv7rv/4LpaWlmD59um4vABEREYmSOepvEck6eg1J4eHhKCwsxIoVKyCXy+Hj44PExES4u7sDAORyucaaSTKZDImJiZg/fz62bNkCV1dXbNy4ERMnTlT3CQwMxP79+/HBBx/gww8/hJeXFw4cOIAhQ4ao+9y+fRtTpkyBUqlEly5dMHToUJw5c0Y9LhEREZFe10kyZFwniYiIyPAYxDpJRERERG0ZQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJEKvK24bsro1OEtLS/VcCRERETVW3d/txqylzZDUTA8fPgQAuLm56bkSIiIiaqqHDx9CKpU22IevJWmmmpoa3L17F506dYJEItF3OW1GaWkp3NzcUFBQwNe1aBmvte7wWusGr7PudORrLQgCHj58CFdXVxgZNfzUEWeSmsnIyAjdu3fXdxltVufOnTvc/+PpC6+17vBa6wavs+501Gv9vBmkOnxwm4iIiEgEQxIRERGRCIYkalXm5ub46KOPYG5uru9S2j1ea93htdYNXmfd4bVuHD64TURERCSCM0lEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRE0WExMDmUwGCwsL+Pn5ITU19Zl9k5OTIZFI6n2uXLmiw4oNV1OuNQCUl5dj2bJlcHd3h7m5Oby8vBAfH6+jag1XU67zjBkzRP9N9+/fX4cVG66m/pveu3cv/vCHP8DKygouLi6YOXMmCgsLdVStYWvqtd6yZQv69u0LS0tL9O7dG3v27NFRpW2YQNQE+/fvF0xNTYXt27cLly9fFt5//33B2tpauHXrlmj/EydOCACEq1evCnK5XP2pqqrSceWGp6nXWhAE4bXXXhOGDBkiJCUlCXl5ecLZs2eFU6dO6bBqw9PU61xcXKzxb7mgoECwt7cXPvroI90WboCaeq1TU1MFIyMj4bPPPhNyc3OF1NRUoX///sKECRN0XLnhaeq1jomJETp16iTs379fuHHjhrBv3z7BxsZGOHz4sI4rb1sYkqhJBg8eLERERGi09enTR1i8eLFo/7qQ9ODBAx1U17409Vp///33glQqFQoLC3VRXrvR1Ov8tIMHDwoSiUS4efOmNsprV5p6rdeuXSt4enpqtG3cuFHo3r271mpsL5p6rQMCAoSoqCiNtvfff18YNmyY1mo0BLzdRo1WUVGBCxcuIDQ0VKM9NDQUp0+fbnDfgQMHwsXFBS+//DJOnDihzTLbheZc68OHD8Pf3x9r1qxBt27d0KtXL0RFReHx48e6KNkgteTfdJ24uDiMHDkS7u7u2iix3WjOtQ4MDMTt27eRmJgIQRDw22+/4euvv8a4ceN0UbLBas61Li8vh4WFhUabpaUlfv75Z1RWVmqt1raOIYkaTalUorq6Gk5OThrtTk5OUCgUovu4uLhg27ZtSEhIwDfffIPevXvj5ZdfxsmTJ3VRssFqzrXOzc3FTz/9hEuXLuHgwYPYsGEDvv76a7z77ru6KNkgNec6/55cLsf333+P2bNna6vEdqM51zowMBB79+5FeHg4zMzM4OzsDFtbW2zatEkXJRus5lzr0aNHY8eOHbhw4QIEQcD58+cRHx+PyspKKJVKXZTdJpnouwAyPBKJRONnQRDqtdXp3bs3evfurf45ICAABQUFWLduHYYPH67VOtuDplzrmpoaSCQS7N27V/2G608//RSTJk3Cli1bYGlpqfV6DVVTrvPv7dq1C7a2tpgwYYKWKmt/mnKtL1++jLlz5+I///M/MXr0aMjlcvzjH/9AREQE4uLidFGuQWvKtf7www+hUCgwdOhQCIIAJycnzJgxA2vWrIGxsbEuym2TOJNEjebo6AhjY+N6/0vk3r179f4XS0OGDh2K69evt3Z57UpzrrWLiwu6deumDkgA0LdvXwiCgNu3b2u1XkPVkn/TgiAgPj4e06ZNg5mZmTbLbBeac62jo6MxbNgw/OMf/8ALL7yA0aNHIyYmBvHx8ZDL5boo2yA151pbWloiPj4eKpUKN2/eRH5+Pjw8PNCpUyc4Ojrqouw2iSGJGs3MzAx+fn5ISkrSaE9KSkJgYGCjj5Oeng4XF5fWLq9dac61HjZsGO7evYtHjx6p265duwYjIyN0795dq/Uaqpb8m05JSUFOTg5mzZqlzRLbjeZca5VKBSMjzT9TdbMaAl87+kwt+XdtamqK7t27w9jYGPv378crr7xS73fQoejpgXEyUHVfK42LixMuX74szJs3T7C2tlZ/s2fx4sXCtGnT1P3/+c9/CgcPHhSuXbsmXLp0SVi8eLEAQEhISNDXKRiMpl7rhw8fCt27dxcmTZokZGVlCSkpKULPnj2F2bNn6+sUDEJTr3OdqVOnCkOGDNF1uQatqdd6586dgomJiRATEyPcuHFD+OmnnwR/f39h8ODB+joFg9HUa3316lXh888/F65duyacPXtWCA8PF+zt7YW8vDw9nUHbwJBETbZlyxbB3d1dMDMzEwYNGiSkpKSot02fPl0IDg5W/7x69WrBy8tLsLCwEOzs7IQXX3xROHLkiB6qNkxNudaCIAjZ2dnCyJEjBUtLS6F79+5CZGSkoFKpdFy14WnqdS4uLhYsLS2Fbdu26bhSw9fUa71x40ahX79+gqWlpeDi4iL8+c9/Fm7fvq3jqg1TU6715cuXhQEDBgiWlpZC586dhfHjxwtXrlzRQ9Vti0QQOGdJRERE9LQOfKORiIiI6NkYkoiIiIhEMCQRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIqIO5YcffsCLL74IW1tbODg44JVXXsGNGzfU22/fvo3JkyfD3t4e1tbW8Pf3x9mzZ9XbDx8+DH9/f1hYWMDR0RF/+tOf9HEaRKQDDElE1KGUlZUhMjIS586dw/Hjx2FkZITXX38dNTU1ePToEYKDg3H37l0cPnwYFy9exMKFC1FTUwMAOHLkCP70pz9h3LhxSE9Px/Hjx+Hv76/nMyIibZEIgiDouwgiIn25f/8+unbtiszMTJw+fRpRUVG4efMm7O3t6/UNDAyEp6cnvvjiCz1USkS6xpkkIupQbty4gTfffBOenp7o3LkzZDIZACA/Px8ZGRkYOHCgaEACgIyMDLz88su6LJeI9MhE3wUQEenSq6++Cjc3N2zfvh2urq6oqamBj48PKioqYGlp2eC+z9tORO0LZ5KIqMMoLCxEdnY2PvjgA7z88svo27cvHjx4oN7+wgsvICMjA0VFRaL7v/DCCzh+/LiuyiUiPWNIIqIOw87ODg4ODti2bRtycnLw73//G5GRkertU6ZMgbOzMyZMmIBTp04hNzcXCQkJSEtLAwB89NFH2LdvHz766CNkZ2cjMzMTa9as0dfpEJGWMSQRUYdhZGSE/fv348KFC/Dx8cH8+fOxdu1a9XYzMzMcO3YMXbt2xdixY+Hr64tPPvkExsbGAIARI0bgq6++wuHDhzFgwAC89NJLGssDEFH7wm+3EREREYngTBIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQi/j8sDeR3W87DGAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"BiasedMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 15\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.01]\n",
    "lambda_range = [0.5]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Drug EO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.441±0.015\n",
      "fair:0.179±0.052\n",
      "\n",
      "method='finetune'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.357±0.009\n",
      "fair:0.125±0.034\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.458±0.014\n",
      "fair:0.216±0.056\n",
      "\n",
      "method='WA'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.358±0.009\n",
      "fair:0.112±0.038\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.01_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.41±0.026\n",
      "fair:0.114±0.043\n",
      "\n",
      "method='GSS'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.433±0.011\n",
      "fair:0.177±0.045\n",
      "\n",
      "method='OCS'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.429±0.007\n",
      "fair:0.169±0.026\n",
      "\n",
      "method='FaIRL'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.318±0.006\n",
      "fair:0.015±0.009\n",
      "\n",
      "method='FSW'\n",
      "lr=0.01_tau=1.0_alpha_0.01_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.429±0.02\n",
      "fair:0.138±0.037\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e172a700>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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IiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIqI25ZdffsErr7wCU1NTWFhY4M0338SNGzeU++/cuYPRo0fD3NwcxsbG8PHxwW+//abcf+jQIfj4+MDAwACWlpZ45513tDENImoCDElE1KYUFhYiMjIS586dw/Hjx6Gjo4O3334bFRUVePLkCQIDA3Hv3j0cOnQIFy9exKxZs1BRUQEAOHz4MN555x0MGTIEycnJOH78OHx8fLQ8IyLSFL7glojatIcPH6Jjx464dOkSEhMTMXPmTNy8eRPm5uY16vr7+8PFxQX//Oc/tTBSImpqXEkiojblxo0bGDt2LFxcXGBiYgJnZ2cAQFZWFlJSUtC7d2/RgAQAKSkpeO2115pyuESkRe20PQAioqY0dOhQ2NvbY+vWrbCzs0NFRQU8PT1RUlICQ0PDWo990X4ial24kkREbUZubi5SU1Px2Wef4bXXXkP37t3x6NEj5f6XXnoJKSkpyMvLEz3+pZdewvHjx5tquESkZQxJRNRmmJmZwcLCAlu2bEF6ejr+9a9/ITIyUrl/zJgxsLGxwfDhw3H69GlkZGRg//79SEpKAgDMnz8f0dHRmD9/PlJTU3Hp0iUsX75cW9MhIg1jSCKiNkNHRwf79u3DhQsX4OnpienTp2PFihXK/fr6+jh69Cg6duyIN954A15eXvjqq6+gq6sLABg4cCC+//57HDp0CL169cKrr76q8ngAImpdeHcbERERkQiuJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIxP8HcytkCEyak2QAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Drug\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 25\n",
    "metric=\"EO\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.01]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Drug DP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.441±0.015\n",
      "fair:0.091±0.02\n",
      "\n",
      "method='finetune'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.357±0.009\n",
      "fair:0.102±0.013\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.458±0.014\n",
      "fair:0.098±0.02\n",
      "\n",
      "method='WA'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.358±0.009\n",
      "fair:0.076±0.019\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.01_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.41±0.026\n",
      "fair:0.069±0.019\n",
      "\n",
      "method='GSS'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.433±0.011\n",
      "fair:0.083±0.018\n",
      "\n",
      "method='OCS'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.429±0.007\n",
      "fair:0.079±0.02\n",
      "\n",
      "method='FaIRL'\n",
      "lr=0.01_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.318±0.006\n",
      "fair:0.015±0.007\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=1.0_alpha_0.002_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.405±0.013\n",
      "fair:0.043±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e15dff70>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Drug\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 25\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.002]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bios EO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=2e-05_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.823±0.003\n",
      "fair:0.075±0.001\n",
      "\n",
      "method='finetune'\n",
      "lr=2e-05_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.425±0.006\n",
      "fair:0.029±0.002\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.001_tau=2.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.828±0.002\n",
      "fair:0.083±0.003\n",
      "\n",
      "method='WA'\n",
      "lr=2e-05_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.732±0.008\n",
      "fair:0.069±0.002\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=2e-05_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.785±0.004\n",
      "fair:0.075±0.001\n",
      "\n",
      "method='GSS'\n",
      "lr=2e-05_tau=5.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.774±0.007\n",
      "fair:0.086±0.005\n",
      "\n",
      "method='FaIRL'\n",
      "lr=2e-05_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.332±0.009\n",
      "fair:0.039±0.003\n",
      "\n",
      "method='FSW'\n",
      "lr=2e-05_tau=2.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.792±0.005\n",
      "fair:0.073±0.003\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e3f43940>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Bios_128\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 10\n",
    "metric=\"EO\"\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [2.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [1.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [5.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bios DP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='joint'\n",
      "lr=2e-05_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.823±0.003\n",
      "fair:0.021±0.0\n",
      "\n",
      "method='finetune'\n",
      "lr=2e-05_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.425±0.006\n",
      "fair:0.028±0.001\n",
      "\n",
      "method='iCaRL'\n",
      "lr=0.001_tau=2.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.828±0.002\n",
      "fair:0.022±0.0\n",
      "\n",
      "method='WA'\n",
      "lr=2e-05_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.732±0.008\n",
      "fair:0.022±0.001\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=2e-05_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.785±0.004\n",
      "fair:0.022±0.0\n",
      "\n",
      "method='GSS'\n",
      "lr=2e-05_tau=5.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.774±0.007\n",
      "fair:0.022±0.001\n",
      "\n",
      "method='FaIRL'\n",
      "lr=2e-05_tau=0.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.332±0.009\n",
      "fair:0.026±0.002\n",
      "\n",
      "method='FSW'\n",
      "lr=2e-05_tau=2.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.797±0.003\n",
      "fair:0.022±0.0\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20dc739f70>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkkAAAGwCAYAAAC99fF4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABUKklEQVR4nO3de1xUdf4/8NdwGwRkuCk3uXvDWypTioaIEaZWWrKrVpql7pKWKVpeW/1qQSL6NVNkVdAuin43tFwlFV1GUTHFwEzJKwghIwICAsr1/P7g52wTRwRhZhh8PR+PeTyWz/mcc97nwDYvP+czn5EIgiCAiIiIiNQY6LoAIiIioraIIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJMNJ1Afqqrq4Ot27dQseOHSGRSHRdDhERETWBIAi4d+8enJycYGDQ+FgRQ9ITunXrFlxcXHRdBhERET2BnJwcdOnSpdE+DElPqGPHjgDqb7KlpaWOqyEiIqKmKC0thYuLi+p9vDEMSU/o4SM2S0tLhiQiIiI905SpMpy4TURERCSCIYmIiIhIBEMSERERkQjOSSIiIvr/amtrUV1dresyqAWMjY1haGjYKsdiSCIioqeeIAhQKpUoLi7WdSnUCqysrODg4NDidQwZkoiI6Kn3MCB17twZZmZmXCRYTwmCgIqKCuTn5wMAHB0dW3Q8hiQiInqq1dbWqgKSra2trsuhFurQoQMAID8/H507d27RozdO3CYioqfawzlIZmZmOq6EWsvD32VL55cxJBEREaFpiwuSfmit3yVDEhEREZEIzkmi9q/gGnA3E7DxBGy9dF0NERHpCY4kUftVUQR88zqwwQfYEQx8ObD+5/t3dV0ZEVGrmDp1KsaNG9ekvgqFAhKJhMscNIPOQ1JUVBQ8PDxgamoKHx8fJCcnN9r/2LFj8PHxgampKTw9PREdHa22fcuWLfDz84O1tTWsra0RGBiIM2fOqPWpqanB0qVL4eHhgQ4dOsDT0xMrVqxAXV1dq18f6VD8dOCGQr3thgL4bpouqiEianVffPEFtm/f3qS+Q4YMQV5eHmQyWZOP35wQ1h7pNCTt3r0bc+bMwZIlS5CWlgY/Pz+MGjUK2dnZov0zMzMxevRo+Pn5IS0tDYsXL8bs2bMRHx+v6qNQKDBp0iQkJSUhJSUFrq6uCAoKQm5urqrPqlWrEB0djQ0bNiAjIwMRERFYvXo1vvzyS41fM2lJwTXg+lFAqFVvF2rr2wuv66YuImrXbtwpQ9LlfGQWlGvlfDKZDFZWVk3qa2Ji0ioLLD5NdBqS1q5di2nTpmH69Onw9vbGunXr4OLigk2bNon2j46OhqurK9atWwdvb29Mnz4d7777LiIjI1V9duzYgZkzZ6J///7o2bMntmzZgrq6Ohw9elTVJyUlBWPHjsWYMWPg7u6O4OBgBAUFITU19ZG1VlZWorS0VO1FbdjdzMa3F93QTh1E9FQorqjClJgzGLHmGN7ZdhYBkQpMiTmDkgrNfsXJH0d6KisrMXv2bHTu3BmmpqZ4/vnncfbsWVXfPz9u2759O6ysrHDo0CF4e3vDwsICL730EvLy8gAAy5cvx1dffYUffvgBEokEEokECoVCo9fT1ugsJFVVVeHcuXMICgpSaw8KCsKpU6dE90lJSWnQf+TIkUhNTX3kWggVFRWorq6GjY2Nqu3555/H0aNHceXKFQDA+fPnceLECYwePfqR9YaHh0Mmk6leLi4uTbpO0hFrj8a323hqpw4ieirMjkvHyWsFam0nrxXgg7g0rdXw8ccfIz4+Hl999RV+/vlndO3aFSNHjkRRUdEj96moqEBkZCS++eYbHD9+HNnZ2Zg/fz4AYP78+fjrX/+qCk55eXkYMmSIti6nTdBZSCooKEBtbS3s7e3V2u3t7aFUKkX3USqVov1rampQUFAgus/ChQvh7OyMwMBAVduCBQswadIk9OzZE8bGxhgwYADmzJmDSZMmPbLeRYsWoaSkRPXKyclp6qWSLth1BbxeACR/WmlVYljfzk+5EVEruXGnDMev3kGtIKi11woCjl+9o5VHb+Xl5di0aRNWr16NUaNGoVevXtiyZQs6dOiAmJiYR+5XXV2N6OhoyOVyDBw4EO+//77qyYuFhQU6dOgAqVQKBwcHODg4wMTEROPX0pbofAmAPz8bFQSh0eelYv3F2gEgIiICcXFxUCgUMDU1VbXv3r0b3377LXbu3InevXsjPT0dc+bMgZOTE95++23R80qlUkil0iZfF7UBwTH1k7Sv//dRKzyH17cTEbWSm0UVjW7PKiyHh525Rmu4fv06qqurMXToUFWbsbExnnvuOWRkZDxyPzMzM3h5/fcfjY6OjqrvPSMdhiQ7OzsYGho2GDXKz89vMFr0kIODg2h/IyOjBt+3ExkZibCwMBw5cgT9+vVT2/bRRx9h4cKFmDhxIgCgb9++uHnzJsLDwx8ZkkgPdbAGJu+pn6RddIPrJBGRRrjZNP51Ju62mg1IwKMHDB438GBsbKz2s0QiUR2LdPi4zcTEBD4+PkhMTFRrT0xMfOQzT19f3wb9Dx8+DLlcrvaLXr16NVauXImDBw9CLpc3OE5FRQUMDNQv3dDQkEsAtFe2XkC3FxmQiEgjPDtZYFi3TjD8UxgxlEgwrFsnjY8iAUDXrl1hYmKCEydOqNqqq6uRmpoKb2/vJz6uiYkJamtrH9+xndLpp9tCQ0OxdetWxMbGIiMjA3PnzkV2djZCQkIA1M8DmjJliqp/SEgIbt68idDQUGRkZCA2NhYxMTGqSWZA/SO2pUuXIjY2Fu7u7lAqlVAqlSgrK1P1eeWVV/DZZ5/hwIEDyMrKwt69e7F27Vq89tpr2rt4IiJqN76cNABDu9qptQ3taocvJw3QyvnNzc3x3nvv4aOPPsLBgwdx6dIlzJgxAxUVFZg27cnXhnN3d8cvv/yCy5cvo6CgoMVfGKtvdDonacKECSgsLMSKFSuQl5eHPn36ICEhAW5ubgCAvLw8tTWTPDw8kJCQgLlz52Ljxo1wcnLC+vXrMX78eFWfqKgoVFVVITg4WO1cy5Ytw/LlywEAX375JT755BPMnDkT+fn5cHJywt///nf84x//0PxFExFRuyMzM8bX055DZkE5sgrL4W5rrpURpD/6/PPPUVdXh8mTJ+PevXuQy+U4dOgQrK2tn/iYM2bMgEKhgFwuR1lZGZKSkjB8+PDWK7qNkwh8+PhESktLIZPJUFJSAktLS12XQ0RET+jBgwfIzMxUffuDPpk0aRIMDQ3x7bff6rqUNqWx32lz3r91/rUkRERE1Dw1NTW4dOkSUlJS0Lt3b12X024xJBEREemZX3/9FXK5HL1791bN46XWp/N1koiIiKh5+vfvj4qKxtdnopbjSBIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiItJTgiDgb3/7G2xsbCCRSGBlZYU5c+bouqx2g0sAEBER6amDBw9i+/btUCgU8PT0hIGBATp06NCq55g6dSqKi4vx/ffft+px9QFDEhERkZ66fv06HB0dMWTIEF2X0i7xcRsREVFrKbgGXE0ECq9r/FRTp07FBx98gOzsbEgkEri7u2P48OFqj9vc3d0RFhaGd999Fx07doSrqys2b96sdpzc3FxMmDAB1tbWsLW1xdixY5GVlQUAWL58Ob766iv88MMPkEgkkEgkUCgUUCgUkEgkKC4uVh0nPT0dEolEte/27dthZWWFQ4cOwdvbGxYWFnjppZeQl5endv5t27bB29sbpqam6NmzJ6KiojRxu54IQxIREVFLVRQB37wObPABdgQDXw6s//n+XY2d8osvvsCKFSvQpUsX5OXl4ezZs6L91qxZA7lcjrS0NMycORPvvfcefvvtt/qyKyoQEBAACwsLHD9+HCdOnFCFmaqqKsyfPx9//etfVeEmLy+vWaNWFRUViIyMxDfffIPjx48jOzsb8+fPV23fsmULlixZgs8++wwZGRkICwvDJ598gq+++qplN6eV8HEbERFRS8VPB24o1NtuKIDvpgGT92jklDKZDB07doShoSEcHBwe2W/06NGYOXMmAGDBggX43//9XygUCvTs2RO7du2CgYEBtm7dColEAqB+ZMfKygoKhQJBQUHo0KEDKisrGz3Ho1RXVyM6OhpeXl4AgPfffx8rVqxQbV+5ciXWrFmD119/HQDg4eGBS5cu4Z///CfefvvtZp+vtTEkERERtUTBNeD60YbtQm19e+F1wNZL+3X9f/369VP9b4lEAgcHB+Tn5wMAzp07h2vXrqFjx45q+zx48ADXr7f8kaGZmZkqIAGAo6Oj6tx37txBTk4Opk2bhhkzZqj61NTUQCaTtfjcrYEhiYiIqCXuZja+veiGTkOSsbGx2s8SiQR1dXUAgLq6Ovj4+GDHjh0N9uvUqdMjj2lgUD9bRxAEVVt1dXWTzv1wn4c1bNmyBYMGDVLrZ2ho+MhzaxNDEhERUUtYezS+3cZTO3U8gYEDB2L37t3o3LkzLC0tRfuYmJigtrZWre1hgMrLy4O1tTWA+onbzWFvbw9nZ2fcuHEDb775ZvOL1wJO3CYiImoJu66A1wuA5E+jHxLD+nYdjiI9zptvvgk7OzuMHTsWycnJyMzMxLFjx/Dhhx/i999/B1D/CblffvkFly9fRkFBAaqrq9G1a1e4uLhg+fLluHLlCg4cOIA1a9Y0+/zLly9HeHg4vvjiC1y5cgUXLlzAtm3bsHbt2ta+1CfCkERERNRSwTGA53D1Ns/h9e1tmJmZGY4fPw5XV1e8/vrr8Pb2xrvvvov79++rRpZmzJiBHj16QC6Xo1OnTjh58iSMjY0RFxeH3377Dc888wxWrVqFTz/9tNnnnz59OrZu3Yrt27ejb9++8Pf3x/bt2+Hh8ZjROS2RCH98oEhNVlpaCplMhpKSkkcOURIRUdv34MEDZGZmwsPDA6ampi07WOH1+jlINp5tegSpvWvsd9qc92/OSSIiImottl4MR+0IH7cRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERHpqeHDh2POnDm6LqPdYkgiIiLSU3v27MHKlStVP1+7dg3vvPMOunTpAqlUCg8PD0yaNAmpqalNPub27dshkUhUL3t7e7zyyiu4ePGiWr+pU6di3LhxrXUpbRJDEhERkZ6ysbFBx44dAQCpqanw8fHBlStX8M9//hOXLl3C3r170bNnT8ybN69Zx7W0tEReXh5u3bqFAwcOoLy8HGPGjEFVVZUmLqPNYkgiIiJqJVklWUj+PRk3S29q5XwPH7cJgoCpU6eiW7duSE5OxpgxY+Dl5YX+/ftj2bJl+OGHH1T7LFiwAN27d4eZmRk8PT3xySefoLq6Wu24EokEDg4OcHR0hFwux9y5c3Hz5k1cvnxZK9fVVvALbomIiFqopLIEC44vwMlbJ1VtQ52GYtWwVZBJZRo/f3p6Oi5evIidO3fCwKDh+IeVlZXqf3fs2BHbt2+Hk5MTLly4gBkzZqBjx474+OOPRY9dXFyMnTt3AgCMjY01Un9bxZBERETUQguOL8DpvNNqbafzTmPB8QWIfjFa4+e/evUqAKBnz56P7bt06VLV/3Z3d8e8efOwe/dutZBUUlICCwsLCIKAiooKAMCrr77apOO3JwxJRERELZBVkqU2gvRQrVCLk7dO4mbpTbhZumm0BkEQANQ/Jnuc7777DuvWrcO1a9dQVlaGmpoaWFpaqvXp2LEjfv75Z9TU1ODYsWNYvXo1oqM1H/baGs5JIiIiaoGcezmNbs8uzdZ4Dd27dwcAZGRkNNrv9OnTmDhxIkaNGoX9+/cjLS0NS5YsaTAh28DAAF27dkXPnj3x97//HZMnT8aECRM0Vn9bxZBERETUAi4dXRrd7mrpqvEa+vfvj169emHNmjWoq6trsL24uBgAcPLkSbi5uWHJkiWQy+Xo1q0bbt58/CTzuXPn4vz589i7d29rl96mMSQRERG1gLvMHUOdhsJQYqjWbigxxFCnoRp/1AbUP2bbtm0brly5gmHDhiEhIQE3btzAL7/8gs8++wxjx44FAHTt2hXZ2dnYtWsXrl+/jvXr1zcp+FhaWmL69OlYtmyZ6tEeUD93KT09Xe2Vna35kTNt0XlIioqKgoeHB0xNTeHj44Pk5ORG+x87dgw+Pj4wNTWFp6dng2ekW7ZsgZ+fH6ytrWFtbY3AwECcOXNGrY+7u7vaQlkPX7NmzWr16yMiovZv1bBVGOw4WK1tsONgrBq2Sms1PPfcc0hNTYWXlxdmzJgBb29vvPrqq7h48SLWrVsHABg7dizmzp2L999/H/3798epU6fwySefNOn4H374ITIyMvCvf/1L1aZQKDBgwAC11z/+8Q9NXJ5OSIQ/RkIt2717NyZPnoyoqCgMHToU//znP7F161ZcunQJrq4NhyczMzPRp08fzJgxA3//+99x8uRJzJw5E3FxcRg/fjwA4M0338TQoUMxZMgQmJqaIiIiAnv27MHFixfh7OwMALhz5w5qa2tVx/3111/x4osvIikpCcOHD29S7aWlpZDJZCgpKWkw4Y2IiPTHgwcPkJmZqfoHe0vcLL2J7NJsuFq6amUEicQ19jttzvu3TkPSoEGDMHDgQGzatEnV5u3tjXHjxiE8PLxB/wULFmDfvn1qE9NCQkJw/vx5pKSkiJ6jtrYW1tbW2LBhA6ZMmSLaZ86cOdi/fz+uXr3apE8GAAxJRETtRWuGJGobWisk6exxW1VVFc6dO4egoCC19qCgIJw6dUp0n5SUlAb9R44cidTU1AarhT5UUVGB6upq2NjYPLKOb7/9Fu+++26jAamyshKlpaVqLyIiImq/dBaSCgoKUFtbC3t7e7V2e3t7KJVK0X2USqVo/5qaGhQUFIjus3DhQjg7OyMwMFB0+/fff4/i4mJMnTq10XrDw8Mhk8lULxeXxj/NQERERPpN5xO3/zx6IwhCoyM6Yv3F2gEgIiICcXFx2LNnzyOHUGNiYjBq1Cg4OTk1WueiRYtQUlKieuXkNL4uBhEREek3na24bWdnB0NDwwajRvn5+Q1Gix5ycHAQ7W9kZARbW1u19sjISISFheHIkSPo16+f6PFu3ryJI0eOYM+ePY+tVyqVQiqVPrYfERERtQ86G0kyMTGBj48PEhMT1doTExMxZMgQ0X18fX0b9D98+DDkcrnal+6tXr0aK1euxMGDByGXyx9Zw7Zt29C5c2eMGTOmBVdCRERE7ZFOH7eFhoZi69atiI2NRUZGBubOnYvs7GyEhIQAqH/E9cdPpIWEhODmzZsIDQ1FRkYGYmNjERMTg/nz56v6REREYOnSpYiNjYW7uzuUSiWUSiXKysrUzl1XV4dt27bh7bffhpERv8KOiIiI1Ok0HUyYMAGFhYVYsWIF8vLy0KdPHyQkJMDNrX5tiby8PLWVOz08PJCQkIC5c+di48aNcHJywvr161VrJAH1i1NWVVUhODhY7VzLli3D8uXLVT8fOXIE2dnZePfddzV7kURERKSXdLpOkj7jOklERO0D10lqf/R+nSQiIiKitowhiYiISA9FR0ejY8eOqKmpUbWVlZXB2NgYfn5+an2Tk5MhkUhw5coVAMCpU6dgaGiIl156Sas16xuGJCIiIj0UEBCAsrIypKamqtqSk5Ph4OCAs2fPoqKiQtWuUCjg5OSE7t27AwBiY2PxwQcf4MSJE2pzf0kdQxIREVErqczMRNnx46jKytL4uXr06AEnJycoFApVm0KhwNixY+Hl5aX2FV8KhQIBAQEAgPLycvzf//0f3nvvPbz88svYvn27xmvVVwxJRERELVRbXIzs6TNwY9Ro5Pzt77j+0ihkT5+B2pISjZ53+PDhSEpKUv2clJSE4cOHw9/fX9VeVVWFlJQUVUjavXs3evTogR49euCtt97Ctm3bwM9wiWNIIiIiaqHc+R+hPCVFra08JQW58+Y/Yo/WMXz4cJw8eRI1NTW4d+8e0tLSMGzYMPj7+6tGmE6fPo379++rQlJMTAzeeustAMBLL72EsrIyHD16VKN16iuGJCIiohaozMxE+YkTQG2t+obaWpSfOKHRR28BAQEoLy/H2bNnkZycjO7du6Nz587w9/fH2bNnUV5eDoVCAVdXV3h6euLy5cs4c+YMJk6cCAAwMjLChAkTEBsbq7Ea9RmXmiYiImqB6sd84XlVdjZM3N01cu6uXbuiS5cuSEpKwt27d+Hv7w+g/rtOPTw8cPLkSSQlJWHEiBEA6keRampq4OzsrDqGIAgwNjbG3bt3YW1trZE69RVHkoiIiFrA2MWl0e0mrq4aPX9AQAAUCgUUCgWGDx+uavf398ehQ4dw+vRpBAQEoKamBl9//TXWrFmD9PR01ev8+fNwc3PDjh07NFqnPuJIEhERUQtIPTxg/vzz9XOS/vjIzdAQ5r6+GhtFeiggIACzZs1CdXW1aiQJqA9J7733Hh48eICAgADs378fd+/exbRp0yCTydSOERwcjJiYGLz//vsarVXfcCSJiIiohZzXRMLc11etzdzXF85rIjV+7oCAANy/fx9du3aFvb29qt3f3x/37t2Dl5cXXFxcEBMTg8DAwAYBCQDGjx+P9PR0/PzzzxqvV59wJImIiKiFDGUyuG7dgqqsrPo5SK6uGh9Besjd3V30I/xdunRRa//3v//9yGMMHDiQywCIYEgiIiJqJSbu7loLR6R5fNxGREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiISI8plUp88MEH8PT0hFQqhYuLC1555RUcPXoUQP3Xlqxbt+6xx9m5cycMDQ0REhLSYJtCoYBEIoFEIoGBgQFkMhkGDBiAjz/+GHl5eU2u9eLFixg/fjzc3d0hkUiaVBcAXLhwAf7+/ujQoQOcnZ2xYsUKrXyNCkMSERGRnsrKyoKPjw/+85//ICIiAhcuXMDBgwcREBCAWbNmNetYsbGx+Pjjj7Fr1y5UVFSI9rl8+TJu3bqFs2fPYsGCBThy5Aj69OmDCxcuNOkcFRUV8PT0xOeffw4HB4cm7VNaWooXX3wRTk5OOHv2LL788ktERkZi7dq1Tb62J8XvbiMiImolxbcrUHLnPmSdOsDK3kzj55s5cyYkEgnOnDkDc3NzVXvv3r3x7rvvNvk4WVlZOHXqFOLj45GUlITvvvsOU6ZMadCvc+fOsLKygoODA7p3746xY8diwIABeO+993DixInHnufZZ5/Fs88+CwBYuHBhk2rbsWMHHjx4gO3bt0MqlaJPnz64cuUK1q5di9DQUEgkkiZfZ3NxJImIiKiFHpRXY9/6dOxYdhr7N5zHjmWnsW99Oh6UV2vsnEVFRTh48CBmzZqlFpAesrKyavKxYmNjMWbMGMhkMrz11luIiYlp0n4dOnRASEgITp48ifz8/CafrzlSUlLg7+8PqVSqahs5ciRu3bqFrKwsjZzzIYYkIiKiFjoccxG//1ak1vb7b0U4HHNRY+e8du0aBEFAz549W3Scuro6bN++HW+99RYAYOLEiUhJScG1a9eatP/D82sqsCiVStjb26u1PfxZqVRq5JwPMSS1QdV3KnD/chGqC+7ruhQiInqM4tsVyLlUBKFOvV2oA3IuFaH4tvj8npZ6OHG5pY+bDh8+jPLycowaNQoAYGdnh6CgIMTGxmq1jsb8+djaOCfAOUltSl1FNQrjfkPl1WJVm7SbFWwn9YSBmbHuCiMiokcqudP4P2hL7tzXyPykbt26QSKRICMjA+PGjXvi48TGxqKoqAhmZv+tsa6uDmlpaVi5ciUMDQ0b3T8jIwNA/afoNMHBwaHBiNHDR3t/HmFqbRxJakMK435D5bVitbbKa8UojPtNNwUREdFjyTp1aNH2J2VjY4ORI0di48aNKC8vb7C9uLj4sccoLCzEDz/8gF27diE9PV3tVVZWhh9//LHR/e/fv4/Nmzdj2LBh6NSp05NeSqN8fX1x/PhxVFVVqdoOHz4MJycnjQWzhxiS2ojqOxX1I0h/XvZBACqvFvPRGxFRG2VlbwaXXjaQ/OkdVWIAuPSy0ein3KKiolBbW4vnnnsO8fHxuHr1KjIyMrB+/Xr4+vqq+uXm5jYIQUVFRfjmm29ga2uLv/zlL+jTp4/q1a9fP7z88ssNJnDn5+dDqVTi6tWr2LVrF4YOHYqCggJs2rSpSfVWVVWpzl9VVaWq64/znzZs2IAXXnhB9fMbb7wBqVSKqVOn4tdff8XevXsRFham8U+2AXzc1mbUFD1ofHvhfRjbaeZfI0RE1DJB03rjcMxF5Fz67+TtLj1tEDStt0bP6+HhgZ9//hmfffYZ5s2bh7y8PHTq1Ak+Pj5qwSUyMhKRkZFq+27btg2xsbF47bXXYGDQcMxk/PjxmDBhAm7fvq1q69GjByQSCSwsLODp6YmgoCCEhoY2ec2jW7duYcCAAQ3q8vf3h0KhAAAUFBTg+vXrqj4ymQyJiYmYNWsW5HI5rK2tERoaitDQ0CadsyUkgjaWrGyHSktLIZPJUFJSAktLyxYfr/pOBW6vOffI7fbz5QxJREQa8ODBA2RmZsLDwwOmpqYtOpa210kicY39Tpvz/s2RpDbCuJMZpN2s6uck/TG2SgBpVysGJCIiPWBlb8Zw1I5wTlIbYjupJ6RdrdTapF3rP91GRETU1llYWDzylZycrOvymo0jSW2IgZkxOk3ri+qC+6gpvA8j2w4cQSIiIr2Rnp7+yG3Ozs7aK6SVMCS1QcZ2DEdERKR/unbtqusSWhUftxERERGJYEgiIiIiEqHzkBQVFaX6iJ6Pj89jJ3YdO3YMPj4+MDU1haenJ6Kjo9W2b9myBX5+frC2toa1tTUCAwNx5syZBsfJzc3FW2+9BVtbW5iZmaF///44d+7RH8EnIiKip4tOQ9Lu3bsxZ84cLFmyBGlpafDz88OoUaOQnZ0t2j8zMxOjR4+Gn58f0tLSsHjxYsyePRvx8fGqPgqFApMmTUJSUhJSUlLg6uqKoKAg5ObmqvrcvXsXQ4cOhbGxMX788UdcunQJa9asgZWVlaYvmYiIiPSETheTHDRoEAYOHKi2Kqi3tzfGjRuH8PDwBv0XLFiAffv2qb5MDwBCQkJw/vx5pKSkiJ6jtrYW1tbW2LBhA6ZMmQIAWLhwIU6ePNmijyO29mKSRESkG625mCS1Da21mKTORpKqqqpw7tw5BAUFqbUHBQXh1KlTovukpKQ06D9y5EikpqaiurpadJ+KigpUV1fDxsZG1bZv3z7I5XL85S9/QefOnTFgwABs2bKl0XorKytRWlqq9iIiIqL2S2chqaCgALW1tbC3t1drt7e3h1KpFN1HqVSK9q+pqUFBQYHoPgsXLoSzszMCAwNVbTdu3MCmTZvQrVs3HDp0CCEhIZg9eza+/vrrR9YbHh4OmUymerm4uDT1UomIiDRGqVTiww8/RNeuXWFqagp7e3s8//zziI6ORkVFBQAgLS0NL7/8Mjp37gxTU1O4u7tjwoQJau+d8fHxGDRoEGQyGTp27IjevXtj3rx5urqsNkHn6yT9+Rt8BUFo9Ft9xfqLtQNAREQE4uLioFAo1Ibb6urqIJfLERYWBgAYMGAALl68iE2bNqkeyf3ZokWL1L5Mr7S0lEGJiIh06saNGxg6dCisrKwQFhaGvn37oqamBleuXEFsbCycnJwwePBgBAYG4pVXXsGhQ4dgZWWFzMxM7Nu3TxWijhw5gokTJyIsLAyvvvoqJBIJLl26hKNHj+r4CnVLZyHJzs4OhoaGDUaN8vPzG4wWPeTg4CDa38jICLa2tmrtkZGRCAsLw5EjR9CvXz+1bY6OjujVq5dam7e3t9oE8D+TSqWQSqWPvS4iInp6Fd3KRcntPFg5OMLaUfMrTM+cORNGRkZITU2Fubm5qr1v374YP348BEHADz/8gNLSUmzduhVGRvVv+x4eHhgxYoSq//79+/H888/jo48+UrV1794d48aN0/g1tGU6e9xmYmICHx8fJCYmqrUnJiZiyJAhovv4+vo26H/48GHI5XIYGxur2lavXo2VK1fi4MGDkMvlDY4zdOhQXL58Wa3typUrcHNze9LLISKip9j9snuID/sHts39O/Z8vhyxc/6O+LB/4EFZmcbOWVhYiMOHD2PWrFlqAemPJBIJHBwcUFNTg7179+JRn9VycHDAxYsX8euvv2qsXn2k0yUAQkNDsXXrVsTGxiIjIwNz585FdnY2QkJCANQ/4vrj46+QkBDcvHkToaGhyMjIQGxsLGJiYjB//nxVn4iICCxduhSxsbFwd3eHUqmEUqlE2R/+UOfOnYvTp08jLCwM165dw86dO7F582bMmjVLexdPRETtRsL61bh5IV2t7eaFdBxYH6Gxc167dg2CIKBHjx5q7XZ2dqovlV2wYAEGDx6MxYsX44033oCdnR1GjRqF1atX4/bt26p9PvjgAzz77LPo27cv3N3dMXHiRMTGxqKyslJj9esDnYakCRMmYN26dVixYgX69++P48ePIyEhQTWik5eXp7ZmkoeHBxISEqBQKNC/f3+sXLkS69evx/jx41V9oqKiUFVVheDgYDg6OqpekZGRqj7PPvss9u7di7i4OPTp0wcrV67EunXr8Oabb2rv4omIqF0oupWLrPM/Q6irU2sX6uqQdf5n3M3LfcSerePPc3LPnDmD9PR09O7dWxVyPvvsMyiVSkRHR6NXr16Ijo5Gz549ceHCBQCAubk5Dhw4gGvXrmHp0qWwsLDAvHnz8Nxzz6nmLT2NdLpOkj7jOklERO1DS9dJykxLxZ7Plz9y++sLl8NjQMOpHy1VWFiITp06ISwsDAsXLmywffjw4ejfvz/WrVvXYFtVVRUGDBgAuVyOr776SvT4mZmZ6N69OzZv3ox33nmntcvXKL1fJ4mIiKg9kNk7NrrdyqHx7U/K1tYWL774IjZs2IDy8vJm7WtiYgIvL69G93N3d4eZmVmzj92e6HwJACIiIn1m4+QM92cG4uaFdLVHbhIDA7j17a/RT7lFRUVh6NChkMvlWL58Ofr16wcDAwOcPXsWv/32G3x8fLB//37s2rULEydORPfu3SEIAv79738jISEB27ZtAwAsX74cFRUVGD16NNzc3FBcXIz169ejuroaL774osbqb+sYkoiIiFpozOyPcWB9BLLO/6xqc+vbH2Nmf6zR83p5eSEtLQ1hYWFYtGgRfv/9d0ilUvTq1Qvz58/HzJkzoVQqYWZmhnnz5iEnJwdSqRTdunXD1q1bMXnyZACAv78/Nm7ciClTpuD27duwtrbGgAEDcPjw4QYTw58mnJP0hDgniYiofWjN7267m5eLYqX21kkica01J4kjSURERK3E2tGZ4agd4cRtIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSURERHpq6tSpkEgkDV7Xrl1rdD+FQgGJRILi4mK1nx++bG1tMWLECJw8eVJtv+XLl6N///4aupq2hyGJiIhIj7300kvIy8tTe3l4eDzRsS5fvoy8vDwoFAp06tQJY8aMQX5+fitXrD8YkoiIiFpJ9Z0K3L9chOqC+1o7p1QqhYODg9rriy++QN++fWFubg4XFxfMnDkTZWVljz1W586d4eDggL59+2Lp0qUoKSnBTz/9pIWraJv4BbdEREQtVFdRjcK431B5tVjVJu1mBdtJPWFgZqz1egwMDLB+/Xq4u7sjMzMTM2fOxMcff4yoqKgm7V9RUYFt27YBAIyNtV9/W8GQRERE1EKFcb+h8lqxWlvltWIUxv2GTtP6avTc+/fvh4WFhernUaNG4V//+pfqZw8PD6xcuRLvvffeY0NSly5dANSHJEEQ4OPjgxdeeEEzhesBhiQiIqIWqL5ToTaCpCIAlVeLUV1wH8Z2HTR2/oCAAGzatEn1s7m5OZKSkhAWFoZLly6htLQUNTU1ePDgAcrLy2Fubv7IYyUnJ8Pc3BxpaWlYsGABtm/fzpEkIiIiejI1RQ8a316o2ZBkbm6Orl27qn6+efMmRo8ejZCQEKxcuRI2NjY4ceIEpk2bhurq6kaP5eHhASsrK3Tv3h0PHjzAa6+9hl9//RVSqVRj9bdlnLhNRETUAkY2po1vt9VcQBKTmpqKmpoarFmzBoMHD0b37t1x69atZh9n8uTJqKura/I8pvaIIYmIiKgFjDuZQdrNCpD8aYOkfvK2JkeRxHh5eaGmpgZffvklbty4gW+++QbR0dHNPo6BgQHmzJmDzz//HBUVFar2+/fvIz09Xe31uHWZ9BVDEhERUQvZTuoJaVcrtTZp1/pPt2lb//79sXbtWqxatQp9+vTBjh07EB4e/kTHevfdd1FdXY0NGzao2q5cuYIBAwaovaZPn95a5bcpEkEQBF0XoY9KS0shk8lQUlICS0tLXZdDRERP6MGDB8jMzISHhwdMTRt/dPY41QX3UVN4H0a2HbQ+gkT/1djvtDnv35y4TURE1EqM7RiO2hM+biMiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBERESkp6ZOnQqJRNLgde3aNaSlpeHll19G586dYWpqCnd3d0yYMAEFBQUAAEdHR6xatUrteAsWLIBEIsHRo0fV2l944QW88cYbWruutoIhiYiISI+99NJLyMvLU3t17NgRgYGBsLOzw6FDh5CRkYHY2Fg4OjqioqICADB8+HAkJSWpHUuhUMDFxUWtvaqqCikpKQgICNDqdbUF/O42IiKiVlJQUIC7d+/CxsYGtra2WjmnVCqFg4ODWtv333+P0tJSbN26FUZG9W/1Hh4eGDFihKpPQEAA5s2bh5qaGhgZGeHevXtIS0vDunXrsHPnTlW/n376Cffv32dIIiIiouarqKhAfHw8rl+/rmrz8vJCcHAwOnTQ/hfeOjg4oKamBnv37kVwcDAkEkmDPgEBASgrK8PZs2fh6+uL5ORkdO/eHcHBwZg7dy4qKipgZmaGpKQkdOnSBV27dtX6deiazh+3RUVFwcPDA6ampvDx8UFycnKj/Y8dOwYfHx+YmprC09MT0dHRatu3bNkCPz8/WFtbw9raGoGBgThz5oxan+XLlzd4fvvnFE5ERNRU8fHxuHHjhlrbjRs38N1332n83Pv374eFhYXq9Ze//AWDBw/G4sWL8cYbb8DOzg6jRo3C6tWrcfv2bdV+3bp1g7OzMxQKBYD6R23+/v7o3LkzPD09cfLkSVX70ziKBOg4JO3evRtz5szBkiVLkJaWBj8/P4waNQrZ2dmi/TMzMzF69Gj4+fkhLS0NixcvxuzZsxEfH6/qo1AoMGnSJCQlJSElJQWurq4ICgpCbm6u2rF69+6t9vz2woULGr1WIiJqnwoKCnD9+nUIgqDWLggCrl+/jsLCQo2ePyAgAOnp6arX+vXrAQCfffYZlEoloqOj0atXL0RHR6Nnz55q73fDhw9XC0nDhw8HAPj7+0OhUKCyshKnT59We0z3NNFpSFq7di2mTZuG6dOnw9vbG+vWrYOLiws2bdok2j86Ohqurq5Yt24dvL29MX36dLz77ruIjIxU9dmxYwdmzpyJ/v37o2fPntiyZQvq6uoazNQ3MjKCg4OD6tWpUyeNXisREbVPd+/ebXR7UVGRRs9vbm6Orl27ql6Ojo6qbba2tvjLX/6CNWvWICMjA05OTmrvmQEBATh58iQKCwuRlpaGYcOGAagPSUlJSTh9+vRTOx8J0GFIqqqqwrlz5xAUFKTWHhQUhFOnTonuk5KS0qD/yJEjkZqaiurqatF9KioqUF1dDRsbG7X2q1evwsnJCR4eHpg4cWKDYdI/q6ysRGlpqdqLiIjI2tq60e1/fv/RFRMTE3h5eaG8vFzVFhAQgPLycqxduxbdunWDvb09gPqQlJqaigMHDsDDwwNubm66KlundBaSCgoKUFtbq/qFPGRvbw+lUim6j1KpFO1fU1OjWvfhzxYuXAhnZ2cEBgaq2gYNGoSvv/4ahw4dwpYtW6BUKjFkyJBGh0TDw8Mhk8lULxcXl6ZeKhERtWN2dnbw8vJqMDlaIpHAy8tLa59y+6P9+/fjrbfewv79+3HlyhVcvnwZkZGRSEhIwNixY1X9PD094erqii+//BL+/v6qdicnJ7i5uSE6OvqpHUUC2sDE7T//UQmCIDoLv7H+Yu0AEBERgbi4OOzZswempqaq9lGjRmH8+PHo27cvAgMDceDAAQDAV1999cjzLlq0CCUlJapXTk7O4y+OiIieCsHBwfD09FRr8/T0RHBwsE7q6dWrF8zMzDBv3jz0798fgwcPxv/93/9h69atmDx5slrfgIAA3Lt3TzUf6SF/f3/cu3fvqQ5JOlsCwM7ODoaGhg1GjfLz8xuMFj3k4OAg2t/IyKhBUo+MjERYWBiOHDmCfv36NVqLubk5+vbti6tXrz6yj1QqhVQqbfQ4RET0dOrQoQMmT56MwsJCFBUVaW2dpO3bt4u2e3p6YvPmzU0+hthxtm7diq1bt7agOv2ns5EkExMT+Pj4IDExUa09MTERQ4YMEd3H19e3Qf/Dhw9DLpfD2NhY1bZ69WqsXLkSBw8ehFwuf2wtlZWVyMjIUJvsRkRE1Fy2trbo1q2bTh6xUevT6eO20NBQbN26FbGxscjIyMDcuXORnZ2NkJAQAPWPuKZMmaLqHxISgps3byI0NFS1xHpMTAzmz5+v6hMREYGlS5ciNjYW7u7uUCqVUCqVKCsrU/WZP38+jh07hszMTPz0008IDg5GaWkp3n77be1dPBEREbVpOl1xe8KECSgsLMSKFSuQl5eHPn36ICEhQTWLPi8vT23NJA8PDyQkJGDu3LnYuHEjnJycsH79eowfP17VJyoqClVVVQ2eAy9btgzLly8HAPz++++YNGkSCgoK0KlTJwwePBinT59+amfvExERUUMS4c+rX1GTlJaWQiaToaSkBJaWlrouh4iIntCDBw+QmZmp+vYH0n+N/U6b8/6t80+3ERERtQUcM2g/Wut3yZBERERPtYcf/KmoqNBxJdRaHv4u//ihrieh0zlJREREumZoaAgrKyvk5+cDAMzMzBpdr4/aLkEQUFFRgfz8fFhZWcHQ0LBFx2t2SPrXv/6F77//HtXV1QgMDMTf/va3FhVARESkaw4ODgCgCkqk36ysrFS/05ZoVkjavHkzQkJC0K1bN5iamiI+Ph6ZmZkIDw9vcSFERES6IpFI4OjoiM6dOz/yu0BJPxgbG7d4BOmhZn26rW/fvhg3bhxWrlwJoH6Vzg8++AD37t1rlWL0CT/dRkREpH809um2Gzdu4J133lH9PHnyZFRWVj7yC2mJiIiI9FWzQtL9+/dhYWGh+tnQ0BBSqZSfCCAiIqJ2p9kTt7du3aoWlGpqarB9+3bY2dmp2mbPnt061RERERHpSLPmJLm7uz/2Y5ESiQQ3btxocWFtHeckERER6Z/mvH83ayQpKyurJXURERER6Y1mP26rq6vD9u3bsWfPHmRlZUEikcDT0xPjx4/H5MmTuQAXERERtQvNmrgtCAJeeeUVTJ8+Hbm5uejbty969+6NrKwsTJ06Fa+99pqm6iQiIiLSqmaNJG3fvh3Jyck4evQoAgIC1Lb95z//wbhx4/D1119jypQprVokERERkbY1ayQpLi4OixcvbhCQAGDEiBFYuHAhduzY0WrFEREREelKs0LSL7/8gpdeeumR20eNGoXz58+3uCgiIiIiXWtWSCoqKoK9vf0jt9vb2+Pu3bstLoqIiIhI15oVkmpra2Fk9OhpTIaGhqipqWlxUURERES61qyJ24IgYOrUqZBKpaLbKysrW6UoIiIiIl1rVkh6++23H9uHn2wjIiKi9qBZIWnbtm2aqoOIiIioTWnWnCQiIiKipwVDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZEInYekqKgoeHh4wNTUFD4+PkhOTm60/7Fjx+Dj4wNTU1N4enoiOjpabfuWLVvg5+cHa2trWFtbIzAwEGfOnHnk8cLDwyGRSDBnzpzWuBwiIiJqJ3Qaknbv3o05c+ZgyZIlSEtLg5+fH0aNGoXs7GzR/pmZmRg9ejT8/PyQlpaGxYsXY/bs2YiPj1f1USgUmDRpEpKSkpCSkgJXV1cEBQUhNze3wfHOnj2LzZs3o1+/fhq7RiIiItJPEkEQBF2dfNCgQRg4cCA2bdqkavP29sa4ceMQHh7eoP+CBQuwb98+ZGRkqNpCQkJw/vx5pKSkiJ6jtrYW1tbW2LBhA6ZMmaJqLysrw8CBAxEVFYVPP/0U/fv3x7p165pce2lpKWQyGUpKSmBpadnk/YiIiEh3mvP+rbORpKqqKpw7dw5BQUFq7UFBQTh16pToPikpKQ36jxw5Eqmpqaiurhbdp6KiAtXV1bCxsVFrnzVrFsaMGYPAwMAm1VtZWYnS0lK1FxEREbVfOgtJBQUFqK2thb29vVq7vb09lEql6D5KpVK0f01NDQoKCkT3WbhwIZydndXC0K5du/Dzzz+LjlY9Snh4OGQymerl4uLS5H2JiIhI/+h84rZEIlH7WRCEBm2P6y/WDgARERGIi4vDnj17YGpqCgDIycnBhx9+iG+//VbV1hSLFi1CSUmJ6pWTk9PkfYmIiEj/GOnqxHZ2djA0NGwwapSfn99gtOghBwcH0f5GRkawtbVVa4+MjERYWBiOHDmiNjH73LlzyM/Ph4+Pj6qttrYWx48fx4YNG1BZWQlDQ8MG55ZKpZBKpc2+TiIiItJPOhtJMjExgY+PDxITE9XaExMTMWTIENF9fH19G/Q/fPgw5HI5jI2NVW2rV6/GypUrcfDgQcjlcrX+L7zwAi5cuID09HTVSy6X480330R6erpoQCIiIqKnj85GkgAgNDQUkydPhlwuh6+vLzZv3ozs7GyEhIQAqH/ElZubi6+//hpA/SfZNmzYgNDQUMyYMQMpKSmIiYlBXFyc6pgRERH45JNPsHPnTri7u6tGniwsLGBhYYGOHTuiT58+anWYm5vD1ta2QTsRERE9vXQakiZMmIDCwkKsWLECeXl56NOnDxISEuDm5gYAyMvLU1szycPDAwkJCZg7dy42btwIJycnrF+/HuPHj1f1iYqKQlVVFYKDg9XOtWzZMixfvlwr10VERET6T6frJOkzrpNERESkf/RinSQiIiKitowhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYnQeUiKioqCh4cHTE1N4ePjg+Tk5Eb7Hzt2DD4+PjA1NYWnpyeio6PVtm/ZsgV+fn6wtraGtbU1AgMDcebMGbU+mzZtQr9+/WBpaQlLS0v4+vrixx9/bPVrIyIiIv2l05C0e/duzJkzB0uWLEFaWhr8/PwwatQoZGdni/bPzMzE6NGj4efnh7S0NCxevBizZ89GfHy8qo9CocCkSZOQlJSElJQUuLq6IigoCLm5uao+Xbp0weeff47U1FSkpqZixIgRGDt2LC5evKjxayYiIiL9IBEEQdDVyQcNGoSBAwdi06ZNqjZvb2+MGzcO4eHhDfovWLAA+/btQ0ZGhqotJCQE58+fR0pKiug5amtrYW1tjQ0bNmDKlCmPrMXGxgarV6/GtGnTmlR7aWkpZDIZSkpKYGlp2aR9iIiISLea8/6ts5GkqqoqnDt3DkFBQWrtQUFBOHXqlOg+KSkpDfqPHDkSqampqK6uFt2noqIC1dXVsLGxEd1eW1uLXbt2oby8HL6+vo+st7KyEqWlpWovIiIiar90FpIKCgpQW1sLe3t7tXZ7e3solUrRfZRKpWj/mpoaFBQUiO6zcOFCODs7IzAwUK39woULsLCwgFQqRUhICPbu3YtevXo9st7w8HDIZDLVy8XFpSmXSURERHpK5xO3JRKJ2s+CIDRoe1x/sXYAiIiIQFxcHPbs2QNTU1O1bT169EB6ejpOnz6N9957D2+//TYuXbr0yPMuWrQIJSUlqldOTs5jr42IiIj0l5GuTmxnZwdDQ8MGo0b5+fkNRosecnBwEO1vZGQEW1tbtfbIyEiEhYXhyJEj6NevX4NjmZiYoGvXrgAAuVyOs2fP4osvvsA///lP0XNLpVJIpdImXx8RERHpN52NJJmYmMDHxweJiYlq7YmJiRgyZIjoPr6+vg36Hz58GHK5HMbGxqq21atXY+XKlTh48CDkcnmT6hEEAZWVlc28CiIiImqvdDaSBAChoaGYPHky5HI5fH19sXnzZmRnZyMkJARA/SOu3NxcfP311wDqP8m2YcMGhIaGYsaMGUhJSUFMTAzi4uJUx4yIiMAnn3yCnTt3wt3dXTXyZGFhAQsLCwDA4sWLMWrUKLi4uODevXvYtWsXFAoFDh48qOU7QERERG2VTkPShAkTUFhYiBUrViAvLw99+vRBQkIC3NzcAAB5eXlqayZ5eHggISEBc+fOxcaNG+Hk5IT169dj/Pjxqj5RUVGoqqpCcHCw2rmWLVuG5cuXAwBu376NyZMnIy8vDzKZDP369cPBgwfx4osvav6iiYiISC/odJ0kfcZ1koiIiPSPXqyTRERERNSWMSQRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEMCQRERERiWBIIiIiIhLBkEREREQkgiGJiIiISARDEhEREZEIhiQiIiIiEQxJRERERCKMdF0AERER0Z9llWQh514OXC1d4WbpppMaGJKIiIiozSipLMGC4wtw8tZJVdtQp6FYNWwVZFKZVmvh4zYiIiJqMxYcX4DTeafV2k7nncaC4wu0XgtDEhEREbUJWSVZOHnrJGqFWrX2WqEWJ2+dxM3Sm1qthyGJiIjoCVRmZqLs+HFUZWXpupR2I+deTqPbs0uztVRJPc5JIiIiaoba4mLkzv8I5SdOqNrMn38ezmsiYSjT7pyZ9salo0uj210tXbVUST2OJBERETVD7vyPUJ6SotZWnpKC3HnzdVRR++Euc8dQp6EwlBiqtRtKDDHUaajWP+XGkERERNRElZmZ9SNItepzZlBbi/ITJ/jorRWsGrYKgx0Hq7UNdhyMVcNWab0WPm4jIiJqouqcxufMVGVnw8TdXTvFtFMyqQzRL0bjZulNZJdmc50kIiIifWDs0vicGRNX7c6Zac/cLN10Fo4e4uM2IiKiJpJ6eMD8+ecBQ/U5MzA0hPnzz3MUqZ1hSCIiImoG5zWRMPf1VWsz9/WF85pIHVVEmsLHbURERM1gKJPBdesWVGVl1c9BcnXlCFI7xZBERET0BEzc3dtkOCq6lYuS23mwcnCEtaOzrsvRawxJRERE7cD9sntIWL8aWed/VrW5PzMQY2Z/DFMLCx1Wpr84J4mIiKgdSFi/GjcvpKu13byQjgPrI3RTUDvAkERERKTnim7lIuv8zxDq6tTahbo6ZJ3/GXfzcnVUmX5jSCIiItJzJbfzGt1erGx8O4ljSCIiItJzMnvHRrdbOTS+ncQxJBEREek5GydnuD8zEBID9bd1iYEB3J8ZyE+5PSGGJCIionZgzOyP4da3v1qbW9/+GDP7Y90U1A5IBEEQdF2EPiotLYVMJkNJSQksLS11XQ4REREA4G5eLoqVXCfpUZrz/s11koiIiNoRa0dnhqNWovPHbVFRUfDw8ICpqSl8fHyQnJzcaP9jx47Bx8cHpqam8PT0RHR0tNr2LVu2wM/PD9bW1rC2tkZgYCDOnDmj1ic8PBzPPvssOnbsiM6dO2PcuHG4fPlyq18bERER6S+dhqTdu3djzpw5WLJkCdLS0uDn54dRo0YhOztbtH9mZiZGjx4NPz8/pKWlYfHixZg9ezbi4+NVfRQKBSZNmoSkpCSkpKTA1dUVQUFByM397xoRx44dw6xZs3D69GkkJiaipqYGQUFBKC8v1/g1ExERkX7Q6ZykQYMGYeDAgdi0aZOqzdvbG+PGjUN4eHiD/gsWLMC+ffuQkZGhagsJCcH58+eRkpIieo7a2lpYW1tjw4YNmDJlimifO3fuoHPnzjh27BiGDRvWpNo5J4mIiEj/NOf9W2cjSVVVVTh37hyCgoLU2oOCgnDq1CnRfVJSUhr0HzlyJFJTU1FdXS26T0VFBaqrq2FjY/PIWkpKSgCg0T6VlZUoLS1VexEREVH7pbOQVFBQgNraWtjb26u129vbQ6lUiu6jVCpF+9fU1KCgoEB0n4ULF8LZ2RmBgYGi2wVBQGhoKJ5//nn06dPnkfWGh4dDJpOpXi4uLo1dHhEREek5nU/clkgkaj8LgtCg7XH9xdoBICIiAnFxcdizZw9MTU1Fj/f+++/jl19+QVxcXKN1Llq0CCUlJapXTk5Oo/2JiIhIv+lsCQA7OzsYGho2GDXKz89vMFr0kIODg2h/IyMj2NraqrVHRkYiLCwMR44cQb9+/USP98EHH2Dfvn04fvw4unTp0mi9UqkUUqn0cZdFRETU7hQUFODu3buwsbFp8H7bnuksJJmYmMDHxweJiYl47bXXVO2JiYkYO3as6D6+vr7497//rdZ2+PBhyOVyGBsbq9pWr16NTz/9FIcOHYJcLm9wHEEQ8MEHH2Dv3r1QKBTw8PBopasiIiJqPyoqKhAfH4/r16+r2ry8vBAcHIwOHTrosDLt0OnjttDQUGzduhWxsbHIyMjA3LlzkZ2djZCQEAD1j7j++Im0kJAQ3Lx5E6GhocjIyEBsbCxiYmIwf/58VZ+IiAgsXboUsbGxcHd3h1KphFKpRFlZmarPrFmz8O2332Lnzp3o2LGjqs/9+/e1d/FERERtXHx8PG7cuKHWduPGDXz33Xc6qki7dLri9oQJE1BYWIgVK1YgLy8Pffr0QUJCAtzc3AAAeXl5amsmeXh4ICEhAXPnzsXGjRvh5OSE9evXY/z48ao+UVFRqKqqQnBwsNq5li1bhuXLlwOAasmB4cOHq/XZtm0bpk6d2voXSkREpGcKCgrURpAeEgQB169fR2FhYbt/9MbvbntCXCeJiIjas6tXr2LHjh2P3P7mm2+iW7duWqyodejFOklERETUdllbWze6vbG1BdsLhiQiIiJqwM7ODl5eXg2W2JFIJPDy8mr3j9oAhiQiIiJ6hODgYHh6eqq1eXp6Npj3217pdOI2ERERtV0dOnTA5MmTUVhYiKKiIq6TRERERPRHtra2T1U4eoiP24iIiIhEMCQRERERiWBIIiIiIhLBkEREREQkghO3iYiInkLFtytQcuc+ZJ06wMreTNfltEkMSURERE+RB+XVOBxzETmXilRtLr1sEDStN0zNjXVYWdvDx21ERERPkcMxF/H7b0Vqbb//VoTDMRd1VFHbxZBERET0lCi+XYGcS0UQ6tTbhTog51IRim9X6KawNoohiYiI6ClRcud+i7Y/bRiSiIiInhKyTh1atP1pw5BERET0lLCyN4NLLxtI/vTuLzGon7zNT7mpY0giIiJ6igRN640uPW3U2rr0rP90G6njEgBERERPEVNzY7w6uz/XSWoChiQiIqKnkJW9GcPRY/BxGxEREZEIhiQiIiIiEQxJRERERCIYkoiIiIhEcOI2ERER6dSNO2W4WVQBd1tzeNiZ67ocFYYkIiIi0oniiirMjkvH8at3VG3DunXCl5MGQGZmrMPK6vFxGxEREenE7Lh0nLxWoNZ28loBPohL01FF6hiSiIiISOtu3CnD8at3UCsIau21goDjV+8gs6BcR5X9F0MSERERad3NoopGt2cVMiQRERHRU8jNpvHVvt1tdT+BmyGJiIiItM6zkwWGdesEQ4lErd1QIsGwbp3axKfcGJKIiIhIJ76cNABDu9qptQ3taocvJw3QUUXquAQAERER6YTMzBhfT3sOmQXlyCos5zpJRERERH/kYde2wtFDfNxGREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIROg8JEVFRcHDwwOmpqbw8fFBcnJyo/2PHTsGHx8fmJqawtPTE9HR0Wrbt2zZAj8/P1hbW8Pa2hqBgYE4c+aMWp/jx4/jlVdegZOTEyQSCb7//vvWviwiIiLSczoNSbt378acOXOwZMkSpKWlwc/PD6NGjUJ2drZo/8zMTIwePRp+fn5IS0vD4sWLMXv2bMTHx6v6KBQKTJo0CUlJSUhJSYGrqyuCgoKQm5ur6lNeXo5nnnkGGzZs0Pg1EhERkX6SCIIg6OrkgwYNwsCBA7Fp0yZVm7e3N8aNG4fw8PAG/RcsWIB9+/YhIyND1RYSEoLz588jJSVF9By1tbWwtrbGhg0bMGXKlAbbJRIJ9u7di3HjxjWr9tLSUshkMpSUlMDS0rJZ+xIREZFuNOf9W2cjSVVVVTh37hyCgoLU2oOCgnDq1CnRfVJSUhr0HzlyJFJTU1FdXS26T0VFBaqrq2FjY9OieisrK1FaWqr2IiIiovZLZ19LUlBQgNraWtjb26u129vbQ6lUiu6jVCpF+9fU1KCgoACOjo4N9lm4cCGcnZ0RGBjYonrDw8PxP//zPw3aGZaIiIj0x8P37aY8SNP5d7dJJBK1nwVBaND2uP5i7QAQERGBuLg4KBQKmJqatqjORYsWITQ0VPVzbm4uevXqBRcXlxYdl4iIiLTv3r17kMlkjfbRWUiys7ODoaFhg1Gj/Pz8BqNFDzk4OIj2NzIygq2trVp7ZGQkwsLCcOTIEfTr16/F9UqlUkilUtXPFhYWyMnJQceOHRsNddQ0paWlcHFxQU5ODud4aRjvtfbwXmsP77X26Pu9FgQB9+7dg5OT02P76iwkmZiYwMfHB4mJiXjttddU7YmJiRg7dqzoPr6+vvj3v/+t1nb48GHI5XIYGxur2lavXo1PP/0Uhw4dglwu10j9BgYG6NKli0aO/TSztLTUy//T6SPea+3hvdYe3mvt0ed7/bgRpId0+rgtNDQUkydPhlwuh6+vLzZv3ozs7GyEhIQAqH/ElZubi6+//hpA/SfZNmzYgNDQUMyYMQMpKSmIiYlBXFyc6pgRERH45JNPsHPnTri7u6tGniwsLGBhYQEAKCsrw7Vr11T7ZGZmIj09HTY2NnB1ddXW5RMREVFbJujYxo0bBTc3N8HExEQYOHCgcOzYMdW2t99+W/D391frr1AohAEDBggmJiaCu7u7sGnTJrXtbm5uAoAGr2XLlqn6JCUlifZ5++23NXil1JiSkhIBgFBSUqLrUto93mvt4b3WHt5r7Xma7rXOJ27PnDkTM2fOFN22ffv2Bm3+/v74+eefH3m8rKysx55z+PDhTZrVTtojlUqxbNkytXlfpBm819rDe609vNfa8zTda50uJklERETUVun8u9uIiIiI2iKGJCIiIiIRDElEREREIhiSiIiIiEQwJJHWREVFwcPDA6ampvDx8UFycnKT9jt58iSMjIzQv39/zRbYjjTnXisUCkgkkgav3377TYsV66/m/l1XVlZiyZIlcHNzg1QqhZeXF2JjY7VUrX5rzr2eOnWq6N917969tVix/mru3/WOHTvwzDPPwMzMDI6OjnjnnXdQWFiopWo1SMdLENBTYteuXYKxsbGwZcsW4dKlS8KHH34omJubCzdv3mx0v+LiYsHT01MICgoSnnnmGe0Uq+eae68frht2+fJlIS8vT/WqqanRcuX650n+rl999VVh0KBBQmJiopCZmSn89NNPwsmTJ7VYtX5q7r0uLi5W+3vOyckRbGxs1NbMI3HNvdfJycmCgYGB8MUXXwg3btwQkpOThd69ewvjxo3TcuWtjyGJtOK5554TQkJC1Np69uwpLFy4sNH9JkyYICxdulRYtmwZQ1ITNfdePwxJd+/e1UJ17Utz7/WPP/4oyGQyobCwUBvltStP+t+Qh/bu3StIJBIhKytLE+W1K82916tXrxY8PT3V2tavXy906dJFYzVqCx+3kcZVVVXh3LlzCAoKUmsPCgrCqVOnHrnftm3bcP36dSxbtkzTJbYbT3qvAWDAgAFwdHTECy+8gKSkJE2W2S48yb3et28f5HI5IiIi4OzsjO7du2P+/Pm4f/++NkrWWy35u34oJiYGgYGBcHNz00SJ7caT3OshQ4bg999/R0JCAgRBwO3bt/Hdd99hzJgx2ihZo3S+4ja1fwUFBaitrYW9vb1au729veq79f7s6tWrWLhwIZKTk2FkxD/TpnqSe+3o6IjNmzfDx8cHlZWV+Oabb/DCCy9AoVBg2LBh2ihbLz3Jvb5x4wZOnDgBU1NT7N27FwUFBZg5cyaKioo4L6kRT3Kv/ygvLw8//vgjdu7cqakS240nuddDhgzBjh07MGHCBDx48AA1NTV49dVX8eWXX2qjZI3iuw9pjUQiUftZEIQGbQBQW1uLN954A//zP/+D7t27a6u8dqWp9xoAevTogR49eqh+9vX1RU5ODiIjIxmSmqA597qurg4SiQQ7duxQfQv52rVrERwcjI0bN6JDhw4ar1efNede/9H27dthZWWFcePGaaiy9qc59/rSpUuYPXs2/vGPf2DkyJHIy8vDRx99hJCQEMTExGijXI1hSCKNs7Ozg6GhYYN/heTn5zf41woA3Lt3D6mpqUhLS8P7778PoP7NRRAEGBkZ4fDhwxgxYoRWatc3zb3XjzJ48GB8++23rV1eu/Ik99rR0RHOzs6qgAQA3t7eEAQBv//+O7p166bRmvVVS/6uBUFAbGwsJk+eDBMTE02W2S48yb0ODw/H0KFD8dFHHwEA+vXrB3Nzc/j5+eHTTz+Fo6OjxuvWFM5JIo0zMTGBj48PEhMT1doTExMxZMiQBv0tLS1x4cIFpKenq14hISHo0aMH0tPTMWjQIG2Vrneae68fJS0tTa//w6YNT3Kvhw4dilu3bqGsrEzVduXKFRgYGKBLly4arVefteTv+tixY7h27RqmTZumyRLbjSe51xUVFTAwUI8ThoaGAKD/Xyavqxnj9HR5+JHSmJgY4dKlS8KcOXMEc3Nz1SdNFi5cKEyePPmR+/PTbU3X3Hv9v//7v8LevXuFK1euCL/++quwcOFCAYAQHx+vq0vQG8291/fu3RO6dOkiBAcHCxcvXhSOHTsmdOvWTZg+fbquLkFvPOl/Q9566y1h0KBB2i5XrzX3Xm/btk0wMjISoqKihOvXrwsnTpwQ5HK58Nxzz+nqEloNH7eRVkyYMAGFhYVYsWIF8vLy0KdPHyQkJKg+aZKXl4fs7GwdV9k+NPdeV1VVYf78+cjNzUWHDh3Qu3dvHDhwAKNHj9bVJeiN5t5rCwsLJCYm4oMPPoBcLoetrS3++te/4tNPP9XVJeiNJ/lvSElJCeLj4/HFF1/oomS91dx7PXXqVNy7dw8bNmzAvHnzYGVlhREjRmDVqlW6uoRWIxEEfR8LIyIiImp9nJNEREREJIIhiYiIiEgEQxIRERGRCIYkIiIiIhEMSUREREQiGJKIiIiIRDAkEREREYlgSCIiIiISwZBEREREJIIhiYiIiEgEQxIRERGRCIYkInqqHDx4EM8//zysrKxga2uLl19+GdevX1dt//333zFx4kTY2NjA3NwccrkcP/30k2r7vn37IJfLYWpqCjs7O7z++uu6uAwi0gKGJCJ6qpSXlyM0NBRnz57F0aNHYWBggNdeew11dXUoKyuDv78/bt26hX379uH8+fP4+OOPUVdXBwA4cOAAXn/9dYwZMwZpaWk4evQo5HK5jq+IiDRFIgiCoOsiiIh05c6dO+jcuTMuXLiAU6dOYf78+cjKyoKNjU2DvkOGDIGnpye+/fZbHVRKRNrGkSQieqpcv34db7zxBjw9PWFpaQkPDw8AQHZ2NtLT0zFgwADRgAQA6enpeOGFF7RZLhHpkJGuCyAi0qZXXnkFLi4u2LJlC5ycnFBXV4c+ffqgqqoKHTp0aHTfx20novaFI0lE9NQoLCxERkYGli5dihdeeAHe3t64e/euanu/fv2Qnp6OoqIi0f379euHo0ePaqtcItIxhiQiempYW1vD1tYWmzdvxrVr1/Cf//wHoaGhqu2TJk2Cg4MDxo0bh5MnT+LGjRuIj49HSkoKAGDZsmWIi4vDsmXLkJGRgQsXLiAiIkJXl0NEGsaQRERPDQMDA+zatQvnzp1Dnz59MHfuXKxevVq13cTEBIcPH0bnzp0xevRo9O3bF59//jkMDQ0BAMOHD8e//vUv7Nu3D/3798eIESPUlgcgovaFn24jIiIiEsGRJCIiIiIRDElEREREIhiSiIiIiEQwJBERERGJYEgiIiIiEsGQRERERCSCIYmIiIhIBEMSERERkQiGJCIiIiIRDElEREREIhiSiIiIiET8P8VVkhRkHzQtAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Bios_128\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 10\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [0.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"joint\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [0.0]\n",
    "method = \"finetune\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [2.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [1.0]\n",
    "method = \"WA\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [5.0]\n",
    "method = \"GSS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [0.0]\n",
    "method = \"FaIRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Ablation Study"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## MNIST - EER"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=0.001_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.921±0.004\n",
      "fair:0.04±0.005\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.924±0.003\n",
      "fair:0.032±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20e1599040>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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haSf/vSneuSRR3TnnXdKkq6++mp9/vnncjgcxwxJAADg/OKxe5ICAwNltVpVUVHh1l5RUaHhw4ebbpOZmdmjfv369bLZbAoICDjmsQzDcLvp+uDBg+rXz/3U/fz8eAUAAABw8ejXbXa7XZMmTZLNZlNmZqaWLl2qhoYGFRQUSDpyH9DevXtVUlIi6ciTbIsWLZLdbtfUqVPldDq1fPlyrVq1yrVPh8Mhm82mQYMGqbOzU+Xl5SopKXF7gm78+PGaP3++Bg4cqKuuukrV1dV65plndN99953dAQAAAF7LoyEpLy9P+/bt09y5c9XY2Ki0tDSVl5crKSlJktTY2KiGhgZXfXJyssrLyzVz5kwtXrxYCQkJWrBggesdSZLU3t6uadOmac+ePQoJCdHgwYO1cuVK5eXluWoWLlyoX/ziF5o2bZqam5uVkJCgH/7wh/rP//zPs3fyAADAq3n0PUm+rDfvWQAAAN7BJ96TBAAA4M0ISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACY8HpKKioqUnJys4OBgWa1Wbdq06bj1VVVVslqtCg4OVkpKioqLi93Wr127VjabTZGRkQoNDVV6erpWrFjhVnPppZfKYrH0WB544IE+Pz8AAOCbPBqS1qxZoxkzZqiwsFDV1dXKysrS2LFj1dDQYFpfX1+vcePGKSsrS9XV1ZozZ46mT5+u0tJSV01UVJQKCwvldDq1Y8cO5efnKz8/X+vWrXPVbNmyRY2Nja6loqJCknTHHXec2RMGAAA+w2IYhuGpgw8bNkwZGRlasmSJq23IkCGaMGGCHA5Hj/pZs2aprKxMtbW1rraCggJt375dTqfzmMfJyMhQbm6u5s2bZ7p+xowZeu211/TRRx/JYrGY1nR0dKijo8P1ua2tTYmJiWptbVV4ePgJzxUAAHheW1ubIiIiTurvt8dmkjo7O7Vt2zbl5OS4tefk5Gjz5s2m2zidzh71Y8aM0datW3Xo0KEe9YZhqLKyUnV1dRoxYsQx+7Fy5Urdd999xwxIkuRwOBQREeFaEhMTT3SKAADAh3ksJLW0tKi7u1txcXFu7XFxcWpqajLdpqmpybS+q6tLLS0trrbW1lb1799fgYGBys3N1cKFCzV69GjTfb766qv6+uuvNWXKlOP2d/bs2WptbXUtu3fvPomzBAAAvsrf0x345uyNYRjHndExq/9me1hYmGpqanTgwAFVVlbKbrcrJSVF2dnZPfa3fPlyjR07VgkJCcftZ1BQkIKCgk50OgAA4BzhsZAUExMjPz+/HrNGzc3NPWaLjoqPjzet9/f3V3R0tKutX79+Sk1NlSSlp6ertrZWDoejR0j6/PPP9eabb2rt2rV9cEYAAOBc4rGv2wIDA2W1Wl1Plh1VUVGh4cOHm26TmZnZo379+vWy2WwKCAg45rEMw3C76fqoF198UbGxscrNzT2FMwAAAOcyj37dZrfbNWnSJNlsNmVmZmrp0qVqaGhQQUGBpCP3Ae3du1clJSWSjjzJtmjRItntdk2dOlVOp1PLly/XqlWrXPt0OByy2WwaNGiQOjs7VV5erpKSErcn6CTp8OHDevHFFzV58mT5+3v8W0cAAOBlPJoO8vLytG/fPs2dO1eNjY1KS0tTeXm5kpKSJEmNjY1u70xKTk5WeXm5Zs6cqcWLFyshIUELFizQxIkTXTXt7e2aNm2a9uzZo5CQEA0ePFgrV65UXl6e27HffPNNNTQ06L777js7JwsAAHyKR9+T5Mt6854FAADgHXziPUkAAADejJAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABggpAEAABgok9DUmNjox588MG+3CUAAIBH+Pd2g127dmnDhg0KCAjQ97//fUVGRqqlpUXz589XcXGxkpOTz0Q/AQAAzqpezSS99tpruuaaa/TjH/9YBQUFstls2rBhg4YMGaKamhq9/PLL2rVr15nqKwAAwFnTq5A0f/58FRQUqK2tTU8//bQ+/fRTFRQUqLS0VBs2bNAtt9xypvoJAABwVlkMwzBOtjgyMlLvv/++Lr/8cnV1dSk4OFh/+tOfNHbs2DPZR6/U1tamiIgItba2Kjw83NPdAQAAJ6E3f797NZPU1tamyMhISZK/v79CQkJ0+eWXn3JHAQAAvNUp3bjd1NQkSTIMQ3V1dWpvb3erGTp0aN/0DgAAwEN69XVbv379ZLFYZLbJ0XaLxaLu7u4+7aQ34us2AAB8T2/+fvdqJqm+vv60OgYAAOArehWSkpKSzlQ/AAAAvEqvbtx+6qmn9K9//cv1+a233lJHR4fr8/79+zVt2rS+6x0AAICH9OqeJD8/PzU2Nio2NlaSFB4erpqaGqWkpEiS/vGPfyghIYF7kgAAgFc6Y68A+Gae6kW+AgAA8Cl9+gO3AAAA5wpCEgAAgIlev0zy+eefV//+/SVJXV1d+t3vfqeYmBhJR27cBgAAOBf0aiZp4MCBWrZsmX7zm9/oN7/5jeLj47VixQrX5+eff14DBw7sVQeKioqUnJys4OBgWa1Wbdq06bj1VVVVslqtCg4OVkpKioqLi93Wr127VjabTZGRkQoNDVV6erpWrFjRYz979+7Vvffeq+joaF1wwQVKT0/Xtm3betV3AABw7urVTNJnn33Wpwdfs2aNZsyYoaKiIl1//fV67rnnNHbsWO3atcs0bNXX12vcuHGaOnWqVq5cqXfeeUfTpk3TRRddpIkTJ0qSoqKiVFhYqMGDByswMFCvvfaa8vPzFRsbqzFjxkiSvvrqK11//fUaNWqU/vznPys2NlaffPKJ63fpAAAAevUKgHHjxmnVqlWKiIiQJM2fP18PPPCAK1zs27dPWVlZ2rVr10ntb9iwYcrIyNCSJUtcbUOGDNGECRPkcDh61M+aNUtlZWWqra11tRUUFGj79u1yOp3HPE5GRoZyc3M1b948SdIjjzyid95554SzVv9XR0eH2zuh2tralJiYyCsAAADwIWfsFQBvvPGGW1B48skn9eWXX7o+d3V1qa6u7qT21dnZqW3btiknJ8etPScnR5s3bzbdxul09qgfM2aMtm7dqkOHDvWoNwxDlZWVqqur04gRI1ztZWVlstlsuuOOOxQbG6trrrlGy5YtO25/HQ6HIiIiXEtiYuJJnScAAPBNp/V02+m8J6mlpUXd3d2Ki4tza4+Li1NTU5PpNk1NTab1XV1damlpcbW1traqf//+CgwMVG5urhYuXKjRo0e71n/66adasmSJLrvsMq1bt04FBQWaPn26SkpKjtnf2bNnq7W11bXs3r37VE4bAAD4iF4/3dbXLBaL22fDMHq0naj+m+1hYWGqqanRgQMHVFlZKbvdrpSUFGVnZ0uSDh8+LJvNpscff1ySdM011+iDDz7QkiVL9B//8R+mxw0KClJQUFCvzw8AAPimXoUki8XSI6QcL9AcT0xMjPz8/HrMGjU3N/eYLToqPj7etN7f31/R0dGutn79+ik1NVWSlJ6ertraWjkcDldIGjBggK688kq3/QwZMkSlpaWndC4AAODc06uQZBiGpkyZ4ppR+fe//62CggKFhoZKktv9SicSGBgoq9WqiooK3Xbbba72iooK3XrrrabbZGZm6k9/+pNb2/r162Wz2RQQEHDcfv/fvl1//fU97p368MMPlZSUdNL9BwAA57ZehaTJkye7fb733nt71Bzr6yozdrtdkyZNks1mU2ZmppYuXaqGhgYVFBRIOnIf0N69e133ChUUFGjRokWy2+2aOnWqnE6nli9frlWrVrn26XA4ZLPZNGjQIHV2dqq8vFwlJSVuT9DNnDlTw4cP1+OPP67vf//7ev/997V06VItXbq0N8MBAADOZYaHLV682EhKSjICAwONjIwMo6qqyrVu8uTJxsiRI93qN27caFxzzTVGYGCgcemllxpLlixxW19YWGikpqYawcHBxoUXXmhkZmYaq1ev7nHcP/3pT0ZaWpoRFBRkDB482Fi6dGmv+t3a2mpIMlpbW3u1HQAA8Jze/P3u1XuS8L96854FAADgHc7Ye5IAAADOF4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAE4QkAAAAEx4PSUVFRUpOTlZwcLCsVqs2bdp03PqqqipZrVYFBwcrJSVFxcXFbuvXrl0rm82myMhIhYaGKj09XStWrHCr+eUvfymLxeK2xMfH9/m5AQAA3+XRkLRmzRrNmDFDhYWFqq6uVlZWlsaOHauGhgbT+vr6eo0bN05ZWVmqrq7WnDlzNH36dJWWlrpqoqKiVFhYKKfTqR07dig/P1/5+flat26d276uuuoqNTY2upadO3ee0XMFAAC+xWIYhuGpgw8bNkwZGRlasmSJq23IkCGaMGGCHA5Hj/pZs2aprKxMtbW1rraCggJt375dTqfzmMfJyMhQbm6u5s2bJ+nITNKrr76qmpqak+5rR0eHOjo6XJ/b2tqUmJio1tZWhYeHn/R+AACA57S1tSkiIuKk/n57bCaps7NT27ZtU05Ojlt7Tk6ONm/ebLqN0+nsUT9mzBht3bpVhw4d6lFvGIYqKytVV1enESNGuK376KOPlJCQoOTkZN1555369NNPj9tfh8OhiIgI15KYmHgypwkAAHyUx0JSS0uLuru7FRcX59YeFxenpqYm022amppM67u6utTS0uJqa21tVf/+/RUYGKjc3FwtXLhQo0ePdq0fNmyYSkpKtG7dOi1btkxNTU0aPny49u3bd8z+zp49W62tra5l9+7dp3LaAADAR/h7ugMWi8Xts2EYPdpOVP/N9rCwMNXU1OjAgQOqrKyU3W5XSkqKsrOzJUljx4511V599dXKzMzUoEGD9Pvf/152u930uEFBQQoKCurVuQEAAN/lsZAUExMjPz+/HrNGzc3NPWaLjoqPjzet9/f3V3R0tKutX79+Sk1NlSSlp6ertrZWDofDFZK+KTQ0VFdffbU++uij0zgjAABwLvHY122BgYGyWq2qqKhwa6+oqNDw4cNNt8nMzOxRv379etlsNgUEBBzzWIZhuN10/U0dHR2qra3VgAEDenEGAADgXObRr9vsdrsmTZokm82mzMxMLV26VA0NDSooKJB05D6gvXv3qqSkRNKRJ9kWLVoku92uqVOnyul0avny5Vq1apVrnw6HQzabTYMGDVJnZ6fKy8tVUlLi9gTdww8/rPHjx2vgwIFqbm7WY489pra2Nk2ePPnsDgAAAPBaHg1JeXl52rdvn+bOnavGxkalpaWpvLxcSUlJkqTGxka3dyYlJyervLxcM2fO1OLFi5WQkKAFCxZo4sSJrpr29nZNmzZNe/bsUUhIiAYPHqyVK1cqLy/PVbNnzx7dddddamlp0UUXXaTrrrtO7777ruu4AAAAHn1Pki/rzXsWAACAd/CJ9yQBAAB4M0ISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACUISAACACY+HpKKiIiUnJys4OFhWq1WbNm06bn1VVZWsVquCg4OVkpKi4uJit/Vr166VzWZTZGSkQkNDlZ6erhUrVhxzfw6HQxaLRTNmzOiL0wEAAOcIj4akNWvWaMaMGSosLFR1dbWysrI0duxYNTQ0mNbX19dr3LhxysrKUnV1tebMmaPp06ertLTUVRMVFaXCwkI5nU7t2LFD+fn5ys/P17p163rsb8uWLVq6dKmGDh16xs4RAAD4JothGIanDj5s2DBlZGRoyZIlrrYhQ4ZowoQJcjgcPepnzZqlsrIy1dbWutoKCgq0fft2OZ3OYx4nIyNDubm5mjdvnqvtwIEDysjIUFFRkR577DGlp6fr2WefPeY+Ojo61NHR4frc1tamxMREtba2Kjw8/GRPGQAAeFBbW5siIiJO6u+3x2aSOjs7tW3bNuXk5Li15+TkaPPmzabbOJ3OHvVjxozR1q1bdejQoR71hmGosrJSdXV1GjFihNu6Bx54QLm5ubr55ptPqr8Oh0MRERGuJTEx8aS2AwAAvsnfUwduaWlRd3e34uLi3Nrj4uLU1NRkuk1TU5NpfVdXl1paWjRgwABJUmtrqy6++GJ1dHTIz89PRUVFGj16tGub1atX669//au2bNly0v2dPXu27Ha76/PRmSQAAHBu8lhIOspisbh9NgyjR9uJ6r/ZHhYWppqaGh04cECVlZWy2+1KSUlRdna2du/erYceekjr169XcHDwSfczKChIQUFBJ10PAAB8m8dCUkxMjPz8/HrMGjU3N/eYLToqPj7etN7f31/R0dGutn79+ik1NVWSlJ6ertraWjkcDmVnZ2vbtm1qbm6W1Wp11Xd3d+utt97SokWLXLNPAADg/Oaxe5ICAwNltVpVUVHh1l5RUaHhw4ebbpOZmdmjfv369bLZbAoICDjmsQzDcN10fdNNN2nnzp2qqalxLTabTffcc49qamoISAAAQJKHv26z2+2aNGmSbDabMjMztXTpUjU0NKigoEDSkfuA9u7dq5KSEklHnmRbtGiR7Ha7pk6dKqfTqeXLl2vVqlWufTocDtlsNg0aNEidnZ0qLy9XSUmJ6wm6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+TyOhmFo//79SkhIUL9+x39+jZmkU9SvX7+z8tqA8PDw8+4CPhMYx77BOJ4+xrBvMI5943wdxxPNIB3l0R+4BQAA8FaEJAAAABOEJC8VFBSkRx99lJ9COU2MY99gHE8fY9g3GMe+wTieHG7cBgAAMMFMEgAAgAlCEgAAgAlCEgAAgAlCEgAAgAlCUh8pKipScnKygoODZbVatWnTpuPWL168WEOGDFFISIiuuOIKlZSUuK1ftmyZsrKydOGFF+rCCy/UzTffrPfff9+t5q233tL48eOVkJAgi8WiV199tcdxpkyZIovF4rZcd911p32+Z4InxtDhcOjaa69VWFiYYmNjNWHCBNXV1bnVGIahX/7yl0pISFBISIiys7P1wQcf9M1JnwHeOo6+dC1KnhnHJUuWaOjQoa4X/GVmZurPf/6zW40vXY/eOoZciycex//L4XDIYrFoxowZbu2+dC2eMgOnbfXq1UZAQICxbNkyY9euXcZDDz1khIaGGp9//rlpfVFRkREWFmasXr3a+OSTT4xVq1YZ/fv3N8rKylw1d999t7F48WKjurraqK2tNfLz842IiAhjz549rpry8nKjsLDQKC0tNSQZr7zySo9jTZ482fjOd75jNDY2upZ9+/b1+RicLk+N4ZgxY4wXX3zR+Nvf/mbU1NQYubm5xsCBA40DBw64ap544gkjLCzMKC0tNXbu3Gnk5eUZAwYMMNra2s7cgJwibx5HX7kWDcNz41hWVma8/vrrRl1dnVFXV2fMmTPHCAgIMP72t7+5anzlevTmMeRaPPE4HvX+++8bl156qTF06FDjoYceclvnK9fi6SAk9YFvf/vbRkFBgVvb4MGDjUceecS0PjMz03j44Yfd2h566CHj+uuvP+Yxurq6jLCwMOP3v/+96frjhaRbb731+CfgBbxhDA3DMJqbmw1JRlVVlWEYhnH48GEjPj7eeOKJJ1w1//73v42IiAijuLj4hOd1tnnrOBqG71yLhuE942gYhnHhhRcazz//vGEYvnU9eusYGgbX4jcdaxz3799vXHbZZUZFRYUxcuRIt5DkS9fi6eDrttPU2dmpbdu2KScnx609JydHmzdvNt2mo6NDwcHBbm0hISF6//33dejQIdNtDh48qEOHDikqKqrXfdy4caNiY2N1+eWXa+rUqWpubu71Ps4kbxrD1tZWSXLV1NfXq6mpya1vQUFBGjly5DH75inePI5Hefu1KHnPOHZ3d2v16tVqb29XZmamJN+5Hr15DI/iWvxfxxrHBx54QLm5ubr55pt7bOMr1+LpIiSdppaWFnV3dysuLs6tPS4uTk1NTabbjBkzRs8//7y2bdsmwzC0detWvfDCCzp06JBaWlpMt3nkkUd08cUXm16sxzN27Fj94Q9/0F/+8hf9+te/1pYtW3TjjTeqo6OjV/s5k7xlDA3DkN1u1w033KC0tDRJch2/N33zFG8eR8k3rkXJ8+O4c+dO9e/fX0FBQSooKNArr7yiK6+8UpLvXI/ePIYS1+I3mY3j6tWr9de//lUOh8N0G1+5Fk+Xv6c7cK6wWCxunw3D6NF21C9+8Qs1NTXpuuuuk2EYiouL05QpU/TUU0/Jz8+vR/1TTz2lVatWaePGjT3+D+FE8vLyXP+clpYmm82mpKQkvf7667r99tt7ta8zzdNj+OCDD2rHjh16++23T6tvnuat4+hL16LkuXG84oorVFNTo6+//lqlpaWaPHmyqqqq3P7I+8r16K1jyLX4v8zGcffu3XrooYe0fv36E/7N8ZVr8VQxk3SaYmJi5Ofn1yM5Nzc390jYR4WEhOiFF17QwYMH9dlnn6mhoUGXXnqpwsLCFBMT41b79NNP6/HHH9f69es1dOjQ0+7vgAEDlJSUpI8++ui099VXvGEMf/zjH6usrEwbNmzQJZdc4mqPj4+XpF71zVO8eRzNeOO1KHl+HAMDA5WamiqbzSaHw6Fvfetb+u1vfyvJd65Hbx5DM1yL7uO4bds2NTc3y2q1yt/fX/7+/qqqqtKCBQvk7++v7u5un7kWT9tZvP/pnPXtb3/b+NGPfuTWNmTIkGPeWGdmxIgRxl133eXW9tRTTxnh4eGG0+k84fY6xo3b39TS0mIEBQWd8EbHs81TY3j48GHjgQceMBISEowPP/zQdH18fLzx5JNPuto6Ojq89uZEbx1HM956LRqGd/w3fdSNN95oTJ482TAM37oevXUMzXAtumtrazN27tzptthsNuPee+81du7caRiGb12Lp4OQ1AeOPqK5fPlyY9euXcaMGTOM0NBQ47PPPjMMwzAeeeQRY9KkSa76uro6Y8WKFcaHH35ovPfee0ZeXp4RFRVl1NfXu2qefPJJIzAw0Pif//kft8dU9+/f76rZv3+/UV1dbVRXVxuSjGeeecaorq52PRq6f/9+4yc/+YmxefNmo76+3tiwYYORmZlpXHzxxV73iKanxvBHP/qRERERYWzcuNGt5uDBg66aJ554woiIiDDWrl1r7Ny507jrrru89jFXbx1HX7oWDcNz4zh79mzjrbfeMurr640dO3YYc+bMMfr162esX7/eVeMr16O3jiHX4smN4zd98+k2w/Cda/F0EJL6yOLFi42kpCQjMDDQyMjI6PHo88iRI12fd+3aZaSnpxshISFGeHi4ceuttxp///vf3faXlJRkSOqxPProo66aDRs2mNYc/T+mgwcPGjk5OcZFF11kBAQEGAMHDjQmT55sNDQ0nMmhOGWeGEOz9ZKMF1980VVz+PBh49FHHzXi4+ONoKAgY8SIEa7/m/JG3jiOvnYtGoZnxvG+++5zHfOiiy4ybrrpJreAZBi+dT164xhyLZ7cOH6TWUjypWvxVFkMwzD6/Ds8AAAAH8eN2wAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQAAACYISQDOK2+88YZuuOEGRUZGKjo6Wrfccos++eQT1/o9e/bozjvvVFRUlEJDQ2Wz2fTee++51peVlclmsyk4OFgxMTG6/fbbPXEaAM4CQhKA80p7e7vsdru2bNmiyspK9evXT7fddpsOHz6sAwcOaOTIkfriiy9UVlam7du362c/+5kOHz4sSXr99dd1++23Kzc3V9XV1aqsrJTNZvPwGQE4UyyGYRie7gQAeMo///lPxcbGaufOndq8ebMefvhhffbZZ4qKiupRO3z4cKWkpGjlypUe6CmAs42ZJADnlU8++UR33323UlJSFB4eruTkZElSQ0ODampqdM0115gGJEmqqanRTTfddDa7C8CD/D3dAQA4m8aPH6/ExEQtW7ZMCQkJOnz4sNLS0tTZ2amQkJDjbnui9QDOLcwkAThv7Nu3T7W1tfr5z3+um266SUOGDNFXX33lWj906FDV1NToyy+/NN1+6NChqqysPFvdBeBhhCQA540LL7xQ0dHRWrp0qT7++GP95S9/kd1ud62/6667FB8frwkTJuidd97Rp59+qtLSUjmdTknSo48+qlWrVunRRx9VbW2tdu7cqaeeespTpwPgDCMkAThv9OvXT6tXr9a2bduUlpammTNn6le/+pVrfWBgoNavX6/Y2FiNGzdOV199tZ544gn5+flJkrKzs/Xyyy+rrKxM6enpuvHGG91eDwDg3MLTbQAAACaYSQIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADBBSAIAADDx/wDa/aZVtsFw3wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"MNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 5\n",
    "metric=\"EER\"\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EER')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## FashionMNIST - EER"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=0.001_tau=5.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.836±0.006\n",
      "fair:0.048±0.005\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.001_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.825±0.006\n",
      "fair:0.037±0.007\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20dc67ce80>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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lJmZqSlTpigxMVFJSUlauXKlysvLlZGRIencx2nHjh3zPLuUkZGhpUuXKjMzUzNmzFBRUZHy8vK0Zs0aSZLL5VJ8fLxXG81bGvxr+Zw5czRy5Eg9++yz+u53v6sPPvhAK1eu1MqVKztg1AAAoLuwNUhNnDhRx48fV1ZWlioqKhQfH6/8/HzPylBFRYXXnlJut1v5+fmaM2eOli1bpqioKC1ZskQTJky4qHZvvPFG/f73v9e8efOUlZUlt9utxYsXa9KkST4dHwAA6N5s3UeqK2MfKQAAup5us48UAABAV0eQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMGR7kFq+fLncbrdcLpcSEhJUWFh4wfrbtm1TQkKCXC6XYmNjlZOTc966a9eulcPhUHp6+nnrZGdny+FwaPbs2YYjAAAAlytbg9S6des0e/ZszZ8/X8XFxUpOTta4ceNUXl7eav2ysjKlpqYqOTlZxcXFevrppzVr1iytX7++Rd0jR47oySefVHJy8nnb37lzp1auXKkbbrjBZ2MCAACXD1uD1EsvvaTp06frkUce0dChQ7V48WJFR0drxYoVrdbPycnRoEGDtHjxYg0dOlSPPPKIpk2bpkWLFnnVa2xs1KRJk/Szn/1MsbGxrb7XyZMnNWnSJOXm5qpv374+HxsAAOj+bAtSZ86c0e7du5WSkuJVnpKSoh07drR6TVFRUYv6Y8eO1a5du3T27FlPWVZWlvr376/p06eft/3HHntM48eP1x133NGm/tbX16u2ttbrAAAAlzc/uxqurq5WY2OjIiIivMojIiJUWVnZ6jWVlZWt1m9oaFB1dbUGDBig7du3Ky8vTyUlJedte+3atfrwww+1c+fONvc3OztbP/vZz9pcHwAAdH+2P2zucDi8XluW1aLs6+o3l9fV1Wny5MnKzc1VWFhYq9cfPXpUTzzxhFavXi2Xy9Xmfs6bN081NTWe4+jRo22+FgAAdE+2rUiFhYXJ6XS2WH2qqqpqserULDIystX6fn5+Cg0N1UcffaTDhw8rLS3Nc76pqUmS5Ofnp9LSUu3du1dVVVVKSEjw1GlsbNR7772npUuXqr6+Xk6ns0XbgYGBCgwMNB4vAADofmwLUgEBAUpISFBBQYG+853veMoLCgp09913t3pNUlKS3nrrLa+yTZs2KTExUf7+/oqLi9PevXu9zi9YsEB1dXX65S9/qejoaIWHh7eoM3XqVMXFxWnu3LmthigAAIDW2BakJCkzM1NTpkxRYmKikpKStHLlSpWXlysjI0PSuY/Tjh07plWrVkmSMjIytHTpUmVmZmrGjBkqKipSXl6e1qxZI0lyuVyKj4/3aiMkJESSPOUBAQEt6vTu3VuhoaEtygEAAC7E1iA1ceJEHT9+XFlZWaqoqFB8fLzy8/MVExMjSaqoqPDaU8rtdis/P19z5szRsmXLFBUVpSVLlmjChAl2DQEAAFzGHFbz09q4KLW1tQoODlZNTY2CgoLs7g4AAGgDX9+/bf/WHgAAQFdFkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADBEkAIAADDk0yBVUVGhxx9/3JdvCQAA0Gn5XewF+/bt05YtW+Tv76/vfve7CgkJUXV1tRYuXKicnBy53e726CcAAECnc1ErUm+//baGDx+uH/zgB8rIyFBiYqK2bNmioUOHqqSkRG+88Yb27dvXXn0FAADoVC4qSC1cuFAZGRmqra3VokWLdOjQIWVkZGj9+vXasmWL7rzzzvbqJwAAQKfjsCzLamvlkJAQffDBB7rmmmvU0NAgl8ult956S+PGjWvPPnZKtbW1Cg4OVk1NjYKCguzuDgAAaANf378vakWqtrZWISEhkiQ/Pz/17NlT11xzzSV3AgAAoCsyeti8srJSkmRZlkpLS3Xq1CmvOjfccINvegcAANCJXdRHez169JDD4VBrlzSXOxwONTY2+rSTnREf7QEA0PX4+v59UStSZWVll9wgAABAd3FRQSomJqa9+gEAANDlXNTD5s8//7y+/PJLz+v33ntP9fX1ntd1dXWaOXOm73oHAADQiV3UM1JOp1MVFRUKDw+XJAUFBamkpESxsbGSpH/84x+KioriGSkAANAp2br9wVcz10VkMAAAgG7Hpz9aDAAAcDkhSAEAABi66A05f/3rX+uKK66QJDU0NOg3v/mNwsLCJJ172BwAAOBycVEPm1911VVyOBxfW+9y2G+Kh80BAOh6bN2Q8/Dhw5fcIAAAQHdxUc9IpaamqqamxvN64cKFOnHihOf18ePHde211/qscwAAAJ3ZRQWpd955x2sDzueee06ff/6553VDQ4NKS0t91zsAAIBO7JK+tcc+UgAA4HLG9gcAAACGLipIORyOFt/aa8u3+AAAALqji/rWnmVZevjhhxUYGChJ+uc//6mMjAz17t1bkryenwIAAOjuLipIPfTQQ16vJ0+e3KLO9773vUvrEQAAQBdxUUHqlVdeaa9+AAAAdDk8bA4AAGCIIAUAAGDI9iC1fPlyud1uuVwuJSQkqLCw8IL1t23bpoSEBLlcLsXGxionJ+e8ddeuXSuHw6H09HSv8uzsbN14443q06ePwsPDlZ6ezkaiAADgotkapNatW6fZs2dr/vz5Ki4uVnJyssaNG6fy8vJW65eVlSk1NVXJyckqLi7W008/rVmzZmn9+vUt6h45ckRPPvmkkpOTW5zbtm2bHnvsMf35z39WQUGBGhoalJKSolOnTvl8jAAAoPtyWDZuT37TTTdpxIgRWrFihads6NChSk9PV3Z2dov6c+fO1caNG7V//35PWUZGhvbs2aOioiJPWWNjo0aNGqWpU6eqsLBQJ06c0Jtvvnnefnz22WcKDw/Xtm3bdOutt7Zap76+3mt7h9raWkVHR/vs16MBAED7q62tVXBwsM/u37atSJ05c0a7d+9WSkqKV3lKSop27NjR6jVFRUUt6o8dO1a7du3S2bNnPWVZWVnq37+/pk+f3qa+NP8Qc79+/c5bJzs7W8HBwZ4jOjq6Te8NAAC6L9uCVHV1tRobGxUREeFVHhERocrKylavqaysbLV+Q0ODqqurJUnbt29XXl6ecnNz29QPy7KUmZmpW265RfHx8eetN2/ePNXU1HiOo0ePtun9AQBA93VR+0i1h6/+xIxlWRf82ZnW6jeX19XVafLkycrNzVVYWFib2n/88cf117/+Ve+///4F6wUGBnp2dAcAAJBsDFJhYWFyOp0tVp+qqqparDo1i4yMbLW+n5+fQkND9dFHH+nw4cNKS0vznG9qapIk+fn5qbS0VIMHD/ac+8EPfqCNGzfqvffe08CBA301NAAAcJmw7aO9gIAAJSQkqKCgwKu8oKBAI0eObPWapKSkFvU3bdqkxMRE+fv7Ky4uTnv37lVJSYnnuOuuuzRmzBiVlJR4nmuyLEuPP/64NmzYoD/96U9yu93tM0gAANCt2frRXmZmpqZMmaLExEQlJSVp5cqVKi8vV0ZGhqRzzyUdO3ZMq1atknTuG3pLly5VZmamZsyYoaKiIuXl5WnNmjWSJJfL1eI5p5CQEEnyKn/sscf0+uuv63/+53/Up08fzypXcHCwevbs2d7DBgAA3YStQWrixIk6fvy4srKyVFFRofj4eOXn5ysmJkaSVFFR4bWnlNvtVn5+vubMmaNly5YpKipKS5Ys0YQJEy6q3ebtFkaPHu1V/sorr+jhhx++pDEBAIDLh637SHVlvt6HAgAAtL9us48UAABAV0eQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMESQAgAAMGR7kFq+fLncbrdcLpcSEhJUWFh4wfrbtm1TQkKCXC6XYmNjlZOTc966a9eulcPhUHp6+iW3CwAA8FW2Bql169Zp9uzZmj9/voqLi5WcnKxx48apvLy81fplZWVKTU1VcnKy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hB1zWVtbaz3xxBPWoEGDLJfLZcXGxlrz58+36uvr23u47crXczl//nxryJAhlsvlsvr27WslJSVZa9euvah2uzI75rO1v11J1iuvvNKeQ213dv1t/qvuEKQsy7659MX9x2FZF1gHAwAAwHnxjBQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghQAAIAhghSAy8o777yjW265RSEhIQoNDdWdd96pgwcPes5/8sknuv/++9WvXz/17t1biYmJ+stf/uI5v3HjRiUmJsrlciksLEz33HOPHcMA0EkQpABcVk6dOqXMzEzt3LlTmzdvVo8ePfSd73xHTU1NOnnypEaNGqVPP/1UGzdu1J49e/TjH/9YTU1NkqQ//OEPuueeezR+/HgVFxdr8+bNSkxMtHlEAOzksCzLsrsTAGCXzz77TOHh4dq7d6927NihJ598UocPH1a/fv1a1B05cqRiY2O1evVqG3oKoDNiRQrAZeXgwYN68MEHFRsbq6CgILndbklSeXm5SkpKNHz48FZDlCSVlJTo9ttv78juAujk/OzuAAB0pLS0NEVHRys3N1dRUVFqampSfHy8zpw5o549e17w2q87D+Dyw4oUgMvG8ePHtX//fi1YsEC33367hg4dqi+++MJz/oYbblBJSYk+//zzVq+/4YYbtHnz5o7qLoAugCAF4LLRt29fhYaGauXKlTpw4ID+9Kc/KTMz03P+gQceUGRkpNLT07V9+3YdOnRI69evV1FRkSTpmWee0Zo1a/TMM89o//792rt3r55//nm7hgOgEyBIAbhs9OjRQ2vXrtXu3bsVHx+vOXPm6IUXXvCcDwgI0KZNmxQeHq7U1FRdf/31+o//+A85nU5J0ujRo/XGG29o48aNGjZsmG677TavrREAXH741h4AAIAhVqQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAMEaQAAAAM/T981uFy1p84PQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"FashionMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 5\n",
    "metric=\"EER\"\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [5.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EER')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BiasedMNIST - EO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "lr=0.001_tau=15.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.911±0.003\n",
      "fair:0.063±0.002\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=5.0_alpha_0.0005_lmbd=0.5_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.909±0.003\n",
      "fair:0.06±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20dc76deb0>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlIAAAGwCAYAAABiu4tnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAyhUlEQVR4nO3df1RVdb7/8dfpePilgikBByKEzAkX1SQ2io6hdsV06mZWY1kOfmemGRus0LpjZXds3Zs/ymi6TSpXw+6aGVNvmA1XmZRKyAlr1IWNNxE1IJylXIISSG4g8Pn+4fLcTqDCxx+HQ8/HWnstz2e/9/589tmdOa/57M0+DmOMEQAAALrtMl8PAAAAwF8RpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACz18fUAerP29nYdPXpU/fv3l8Ph8PVwAABAFxhj1NjYqOjoaF122dnnnAhSF9HRo0cVGxvr62EAAAALR44c0ZVXXnnWGoLURdS/f39Jp05EaGioj0cDAAC6oqGhQbGxsZ7v8bMhSF1Epy/nhYaGEqQAAPAzXbkth5vNAQAALBGkAAAALBGkAAAALHGPVA/Q1tamkydP+noY3xkul0tOp9PXwwAA9AIEKR8yxqi6ulrHjx/39VC+cwYMGKCoqCie7wUAOC8EKR86HaIiIiIUEhLCl/olYIxRU1OTampqJElut9vHIwIA+DOClI+0tbV5QtSgQYN8PZzvlODgYElSTU2NIiIiuMwHALDGzeY+cvqeqJCQEB+P5Lvp9PvOvWkAgPNBkPIxLuf5Bu87AOBCIEgBAABY4h4pAADgd8o//0qffdGkwYP6Kj68r8/GwYwUepzKyko5HA7t3btXklRYWCiHw+F5TMR//Md/aMCAAT4bHwDAd443tegnOX/VhKwi/b/Xdmn8C4X6Sc5fVd/km3teCVLocWJjY3Xs2DElJSX5eigAgB7mkXV79cHhWq+2Dw7X6uF1JT4ZD0GqFyj//CttL6tRRe0JXw/lgnA6nYqKilKfPlx5BgD8n/LPv9L7hz5XmzFe7W3G6P1Dn/vke5Ag5cd8Mb357//+74qJiVF7e7tX+z/+4z8qPT1dn376qe644w5FRkaqX79+uummm/TOO+941Q4ePFiLFy/WT3/6U/Xv319XXXWVVq1a5Vn/7Ut759KVPgEA/u+zL5rOur6yjiCFbvDF9OY999yj2tpabd++3dP25ZdfauvWrbr//vv11VdfacqUKXrnnXdUUlKiSZMm6fbbb1dVVZXXfrKysjRixAiVlJToV7/6lR566CEdOHDAakxd7RMA4N/iBp792YuDB136m84JUn7KV9ObAwcO1K233qrXX3/d0/bGG29o4MCBuuWWW3TDDTfol7/8pa677jpdc801evbZZ5WQkKC8vDyv/UyZMkW/+tWvNGTIEM2fP1/h4eEqLCy0GlNX+wQA+LeEK/rp5muukPNbzwJ0Ohy6+ZorfPLXewQpP+XL6c37779fGzduVHNzsyRp7dq1uvfee+V0OnXixAn9+te/1rBhwzRgwAD169dPBw4c6DA7dP3113v+7XA4FBUV5fn9u+7qap8AAP/3u/tu1Jgh4V5tY4aE63f33eiT8XA3r5/y5fTm7bffrvb2dm3ZskU33XSTduzYoRdffFGS9E//9E/aunWrXnjhBQ0ZMkTBwcG6++671dLS4rUPl8vl9drhcHS476qrutonAMD/hYW49Puf/UAVtSdUWXfC58+RIkj5qdPTmx8crvW6vOd0ODRmSPhF/Y8qODhY06ZN09q1a3X48GENHTpUycnJkqQdO3Zo1qxZuvPOOyWdun+psrLyoo3FV30CAHwrPty3Aeo0Lu35MV9Ob95///3asmWL1qxZowceeMDTPmTIEL355pvau3evPv74Y82YMcN6pqmrfNEnAAASM1J+zZfTmxMmTNDAgQNVVlamGTNmeNp/+9vf6qc//alGjx6t8PBwzZ8/Xw0NDRd1LL7oEwAASXIY860/+8IF09DQoLCwMNXX1ys0NNRr3ddff62KigrFx8crKCjIRyP87uL9BwCcydm+v7+NS3sAAACWCFIAAACWCFIAAACWCFIAAACWCFIAAACWCFIAAACWCFIAAACWCFIAAACWCFIAAACWCFLotlmzZsnhcHRYDh8+rJKSEt12222KiIhQUFCQBg8erOnTp6u2tlaS5Ha79dxzz3ntb/78+XI4HHr33Xe92m+55Ravn58BAKCnIUjByq233qpjx455Lf3799c//MM/KDw8XFu3blVpaanWrFkjt9utpqYmSdK4ceO0fft2r30VFhYqNjbWq72lpUU7d+7U+PHjL+lxAQDQHfxocW9Qe1j6skIamCANuvqSdBkYGKioqCivtrfeeksN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EkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAEkEKAADAks+D1IoVKxQfH6+goCAlJydrx44dZ60vKipScnKygoKClJCQoOzs7A41x48fV0ZGhtxut4KCgpSYmKj8/HzP+vfff1+33367oqOj5XA49NZbb3XYx6xZs+RwOLyWUaNGnffxAgCA3sOnQWrDhg3KzMzUggULVFJSorFjx2ry5MmqqqrqtL6iokJTpkzR2LFjVVJSoqeeekqPPPKINm7c6KlpaWnRxIkTVVlZqdzcXJWVlWn16tWKiYnx1Jw4cUI33HCDXnnllbOO79Zbb9WxY8c8yzfDGAAAgMMYY3zV+ciRIzV8+HCtXLnS05aYmKipU6dqyZIlHernz5+vvLw8lZaWetpmz56tjz/+WDt37pQkZWdna9myZTpw4IBcLtc5x+BwOLRp0yZNnTrVq33WrFk6fvx4p7NVXdXQ0KCwsDDV19crNDTUej8AAODS6c73t89mpFpaWrRnzx6lpaV5taelpam4uLjTbXbu3NmhftKkSdq9e7dOnjwpScrLy1NKSooyMjIUGRmppKQkLV68WG1tbd0eY2FhoSIiIjR06FA9+OCDqqmpOWt9c3OzGhoavBYAANB7+SxI1dbWqq2tTZGRkV7tkZGRqq6u7nSb6urqTutbW1tVW1srSSovL1dubq7a2tqUn5+vp59+WllZWVq0aFG3xjd58mStXbtW7733nrKysrRr1y5NmDBBzc3NZ9xmyZIlCgsL8yyxsbHd6hMAAPiXPjYbvfHGG1q3bp0OHjwoh8Oha665RjNmzNDdd9/d7X05HA6v18aYDm3nqv9me3t7uyIiIrRq1So5nU4lJyfr6NGjWrZsmX7zm990eVzTp0/3/DspKUkj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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"BiasedMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 15\n",
    "metric=\"EO\"\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [15.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [5.0]\n",
    "alpha_range = [0.0005]\n",
    "lambda_range = [0.5]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BiasedMNIST - DP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=0.001_tau=15.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.911±0.003\n",
      "fair:0.009±0.001\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.01_lmbd=0.5_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.889±0.006\n",
      "fair:0.007±0.002\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20dc709f40>"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Lr3++uvy8Tn2Tys6OlrXX3+9u+a6667TQw89pIaGBvn4+OjIkSMqLS3Viy++qHfffdddt2nTJn333XcEKQDAaY0Zqa7s6JfS27dKc+Okd26XXhl67O/vvvLKcMLDw9XQ0KAVK1aotd/Cvu666/TNN99o8+bNkqTi4mJdeOGFuv3227V582b3zNW6det03nnnacCAAads/AAAdBRBqivL/ZW0t9CzbW+h9N5/d/quV61apXPOOce93HHHHbryyiv12GOP6a677lJoaKhGjRqlZ599Vv/617/c211wwQU699xzVVh4bNyFhYUaMWKE+vTpo5iYGH388cfudmajAACnO4JUV1XzubRnrWQaPdtN47H2w3s6dffXXXedtm/f7l5efvllSdJTTz2lqqoqLViwQLGxsVqwYIEGDRqkTz75xL3ttdde6xGkrr32WknSiBEjVFhYqNraWm3cuNHjkiAAAKcjglRX9VVF2+u/3Nupu+/evbsGDBjgXiIiItzrQkJCdMcdd+j5559XeXm5IiMj9dxzz7nXX3fddfr44491+PBhlZaW6pprrpF0LEitW7dOGzdu5P4oAECXQJDqqnpFt72+d8ypGceP8PX11fnnn69vv/3W3Xbdddfp22+/1QsvvKALLrhAYWFhko4FqS1btuiDDz5QdHS0+vXr561hAwDQLgSprip0gHT+DZLN7tlusx9rP0Xf3vuhVatW6Re/+IVWrVqlXbt2aefOnXruuef04Ycfaty4ce66mJgY9e3bV6+88opGjBjhbo+MjFS/fv20YMECZqMAAF2C14NUdna2oqOj5e/vr7i4OBUXF7dZX1RUpLi4OPn7+ysmJkYLFixoVpObm6vY2Fj5+fkpNjZWK1as8Fjf0NCgxx9/XNHR0QoICFBMTIyefPJJNTU1tbjP++67TzabTS+++KLl4+wUt+dIMdd6tsVce6zdC2JjYxUYGKiHHnpIl112ma688kr93//9n15//XWlpqZ61F533XU6cuSI+/6o40aMGKEjR44QpAAAXYPxoiVLlhiHw2Fee+01s2PHDjN16lTTvXt3U1lZ2WL93r17TWBgoJk6darZsWOHee2114zD4TDvvfeeu2bDhg3Gbrebp59+2pSXl5unn37a+Pj4mI0bN7pr/vCHP5iQkBCzatUqU1FRYZYtW2bOOecc8+KLLzbb54oVK8yll15qIiMjzR//+McOHZ/T6TSSjNPpbLbuu+++Mzt27DDfffddh/psUc3nxuxac+y/aJeT+voDAM4obX1+n8hmTCsP/DkFhg0bpqFDh2r+/PnutsGDB2v8+PHKyspqVp+Zmam8vDyVl5e729LT01VWVqaSkhJJUkpKilwulz766CN3zciRI9WrVy8tXrxYkjR27FiFhYUpJ+c/Mze33XabAgMD9fbbb7vbDh48qGHDhmn16tUaM2aMMjIylJGR0erx1NbWqra21v23y+VSVFSUnE6ngoKCPGq///57VVRUuGfjcGrx+gMAWuNyuRQcHNzi5/eJvHZpr66uTlu3blVSUpJHe1JSkjZs2NDiNiUlJc3qk5OTtWXLFtXX17dZ88M+r776aq1du1a7du2SJJWVlWn9+vUaPXq0u6apqUmpqamaPn26LrroonYdU1ZWloKDg91LVFRUu7YDAABdk9d+IqampkaNjY3ub2wdFxYWpqqqqha3qaqqarG+oaFBNTU1ioiIaLXmh31mZmbK6XRq0KBBstvtamxs1FNPPaU777zTXTNnzhz5+PhoypQp7T6mRx99VNOmTXP/fXxGCgAAnJm8/lt7NpvN429jTLO2H6s/sf3H+ly6dKkWLVqkd999VxdddJG2b9+ujIwMRUZGKi0tTVu3btVLL72kbdu2tTmWE/n5+cnPz6/d9QAAoGvzWpAKDQ2V3W5vNvtUXV3dbEbpuPDw8BbrfXx8FBIS0mbND/ucPn26ZsyYoYkTJ0qShgwZosrKSmVlZSktLU3FxcWqrq5W37593ds0NjbqoYce0osvvqh9+/ZZPu4TefEWtbMarzsA4GTw2j1Svr6+iouLU35+vkd7fn6+EhMTW9wmISGhWf2aNWsUHx8vh8PRZs0P+zx69Ki6dfM8dLvd7n78QWpqqv7xj394/ARKZGSkpk+frtWrV1s74BMcH+/xH+nFqXX8dT9+HgAAsMKrl/amTZum1NRUxcfHKyEhQa+++qr279+v9PR0ScfuOTp48KDeeustSce+oTd37lxNmzZN9957r0pKSpSTk+P+Np4kTZ06Vddcc43mzJmjcePG6f3331dBQYHWr1/vrrnpppv01FNPqW/fvrroootUWlqqF154QZMnT5Z07CdOjs9wHedwOBQeHq6BAweelGO32+3q2bOnqqurJUmBgYEduowIa4wxOnr0qKqrq9WzZ0/Z7fYf3wgAgFZ4NUilpKTo8OHDevLJJ3Xo0CFdfPHF+vDDD90/DXLo0CHt37/fXR8dHa0PP/xQDz74oObNm6fIyEi9/PLLuu2229w1iYmJWrJkiR5//HHNmjVL559/vpYuXaphw4a5a1555RXNmjVL999/v6qrqxUZGan77rtPv/3tb0/dwevYZUhJ7jCFU6dnz57u1x8AAKu8+hypM117n0PR2NjofnwDOp/D4WAmCgDQqo48R8rr39rDsct8fLADAND1eP239gAAALoqghQAAIBFBCkAAACLCFIAAAAWEaQAAAAsIkgBAABYRJACAACwiCAFAABgEUEKAADAIoIUAACARQQpAAAAiwhSAAAAFhGkAAAALCJIAQAAWESQAgAAsIggBQAAYBFBCgAAwCKCFAAAgEUEKQAAAIsIUgAAABYRpAAAACwiSAEAAFhEkAIAALCIIAUAAGARQQoAAMAighQAAIBFBCkAAACLCFIAAAAWEaQAAAAsIkgBAABYRJACAACwiCAFAABgEUEKAADAIoIUAACARQQpAAAAiwhSAAAAFhGkAAAALCJIAQAAWOT1IJWdna3o6Gj5+/srLi5OxcXFbdYXFRUpLi5O/v7+iomJ0YIFC5rV5ObmKjY2Vn5+foqNjdWKFSs81jc0NOjxxx9XdHS0AgICFBMToyeffFJNTU2SpPr6emVmZmrIkCHq3r27IiMjdc899+iLL744eQcOAAC6PK8GqaVLlyojI0MzZ85UaWmphg8frlGjRmn//v0t1ldUVGj06NEaPny4SktL9dhjj2nKlCnKzc1115SUlCglJUWpqakqKytTamqqJkyYoE2bNrlr5syZowULFmju3LkqLy/XM888o2effVavvPKKJOno0aPatm2bZs2apW3btmn58uXatWuXbr755s59QQAAQJdiM8YYb+182LBhGjp0qObPn+9uGzx4sMaPH6+srKxm9ZmZmcrLy1N5ebm7LT09XWVlZSopKZEkpaSkyOVy6aOPPnLXjBw5Ur169dLixYslSWPHjlVYWJhycnLcNbfddpsCAwP19ttvtzjWzZs364orrlBlZaX69u3bruNzuVwKDg6W0+lUUFBQu7YBAADe1ZHPb6/NSNXV1Wnr1q1KSkryaE9KStKGDRta3KakpKRZfXJysrZs2aL6+vo2a37Y59VX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qaurU1FRUatjAwAAZyHjRUuWLDEOh8Pk5OSYHTt2mIyMDNO9e3ezb98+Y4wxM2bMMKmpqe76vXv3msDAQPPggw+aHTt2mJycHONwOMx7773nrvn444+N3W43s2fPNuXl5Wb27NnGx8fHbNy40V2TlpZmzj33XLNq1SpTUVFhli9fbkJDQ80jjzzirpk9e7YJDg42y5cvN5988om58847TUREhHG5XO0+PqfTaSQZp9P5U14mAABwCnXk89urQcoYY+bNm2f69etnfH19zdChQ01RUZF7XVpamhkxYoRHfWFhobn88suNr6+v6d+/v5k/f36zPpctW2YGDhxoHA6HGTRokMnNzfVY73K5zNSpU03fvn2Nv7+/iYmJMTNnzjS1tbXumqamJvPEE0+Y8PBw4+fnZ6655hrzySefdOjYCFIAAHQ9Hfn89upzpM50PEcKAICup0s8RwoAAKCrI0gBAABYRJACAACwiCAFAABgEUEKAADAIoIUAACARQQpAAAAiwhSAAAAFhGkAAAALCJIAQAAWESQAgAAsIggBQAAYBFBCgAAwCKCFAAAgEUEKQAAAIsIUgAAABYRpAAAACwiSAEAAFhEkAIAALCIIAUAAGARQQoAAMAighQAAIBFBCkAAACLCFIAAAAWWQpSy5Yt06233qqLL75YQ4YM0a233qr33nvvZI8NAADgtNahINXU1KSUlBSlpKRox44dGjBggGJiYvTpp58qJSVFEydOlDGms8YKAABwWvHpSPGLL76ogoIC5eXlaezYsR7r8vLy9Mtf/lIvvfSSMjIyTuYYAQAATksdmpH685//rGeffbZZiJKkm2++Wc8884xycnJO2uAAAABOZx0KUrt379aNN97Y6vobb7xRn3/++U8eFAAAQFfQoSAVEBCgr7/+utX1LpdLAQEBP3VMAAAAXUKHglRCQoLmz5/f6vp58+YpISHhJw8KAACgK+jQzeYzZ87Utddeq8OHD+vhhx/WoEGDZIxReXm5nn/+eb3//vtat25dZ40VAADgtNKhIJWYmKilS5fq17/+tXJzcz3W9erVS4sXL9ZVV111UgcIAABwurIZCw9+Onr0qFavXq3du3dLki688EIlJSUpMDDwpA+wK3O5XAoODpbT6VRQUJC3hwMAANqhI5/fHbpHavTo0XI6nQoMDNQtt9yi+vp6/frXv9b48eMV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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"BiasedMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 15\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [15.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.01]\n",
    "lambda_range = [0.5]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Drug EO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=0.01_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.423±0.013\n",
      "fair:0.162±0.034\n",
      "\n",
      "method='FSW'\n",
      "lr=0.01_tau=1.0_alpha_0.01_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.429±0.02\n",
      "fair:0.138±0.037\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20dc5b1fd0>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlQAAAGwCAYAAABvpfsgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAswUlEQVR4nO3de1SVdaL/8c8GBNQELyAXRQTvhnmBUjBHLQ9nNG3MU0clL022Ojau38iYJ2toLcupPF3HatTSbMxTmtPN8aRnjDxajHbxMOyWq8xQJKxgEEw2ZELC9/eHy31mhxDwBR6E92utZ437+zzP99Z29sfn+e5nu4wxRgAAAGgyP6c7AAAAcLkjUAEAAFgiUAEAAFgiUAEAAFgiUAEAAFgiUAEAAFgiUAEAAFgKcLoDl6uamhp988036tatm1wul9PdAQAADWCMUXl5uaKjo+Xn13zXlQhUTfTNN98oJibG6W4AAIAmOHnypPr27dts9RGomqhbt26SLvwHCQkJcbg3AACgITwej2JiYryf482FQNVEF2/zhYSEEKgAALjMNPdyHRalAwAAWCJQAQAAWCJQAQAAWGINFQAALai6ulo//PCD093oMDp16iR/f/9Wb5dABQBACzDGqKioSGfOnHG6Kx1O9+7dFRkZ2arPiSRQAQDQAi6Gqd69e6tLly48BLoVGGN09uxZFRcXS5KioqJarW0CFQAAzay6utobpnr16uV0dzqUzp07S5KKi4vVu3fvVrv9x6J0AACa2cU1U126dHG4Jx3TxXlvzbVrBCoAAFoIt/mc4cS8E6gAAAAssYaqDco7VaEvT59V/15dFRfW1enuAACAn8AVqjbkzNkqLdj0sa578j398o+HNPmJ/Vqw6WOVneX5JQCA9iE/P18ul0tut1uStH//frlcLu/jJTZv3qzu3bs71r+mIlC1Ib/e5taBYyU+ZQeOlej/bctxqEcAADSvmJgYFRYWKiEhwemuNCsCVRuRd6pC7+eeUrUxPuXVxuj93FM6UfKdQz0DADgt71SF9h0tbhefBf7+/oqMjFRAQPtadUSgaiO+PH223v35pZf/XyIAQOO09lKQ559/Xn369FFNTY1P+Y033qiFCxfq+PHj+sUvfqGIiAhdccUVuvrqq/Xuu+/6HNu/f3898sgjuv3229WtWzf169dPGzZs8O7/8S2/n9KQNtsCAlUbEduz/meV9O/F4nQA6GhaeynILbfcopKSEu3bt89b9u2332rPnj269dZbVVFRoWnTpundd99VTk6O/vmf/1kzZsxQQUGBTz1PPvmkkpKSlJOTo1/96le666679PnnnzepTw1t02kEqjYiPvwK/WxQuPx/9OwMf5dLPxsUzrf9AKCDcWIpSM+ePfXzn/9cW7du9Za99tpr6tmzp66//nqNHDlS//Zv/6YRI0Zo0KBBeuihhxQfH6+dO3f61DNt2jT96le/0sCBA7VixQqFhYVp//79TepTQ9t0GoGqDXl27miNHxjmUzZ+YJienTvaoR4BAJzi1FKQW2+9VW+88YYqKyslSa+88ormzJkjf39/fffdd7rnnns0fPhwde/eXVdccYU+//zzWleLrrrqKu+fXS6XIiMjvb+v11gNbdNp7WtF2GUutEsnbVl0jU6UfKf80u94DhUAdGBOLQWZMWOGampqtGvXLl199dXKysrSU089JUn693//d+3Zs0dPPPGEBg4cqM6dO+vmm29WVVWVTx2dOnXyee1yuWqty2qohrbpNAJVGxQXRpACgI7u4lKQA8dKfG77+btcGj8wrMU+Jzp37qxZs2bplVde0bFjxzR48GAlJiZKkrKysnTbbbfppptuknRhfVN+fn6L9OMiJ9psCm75AQDQRjm1FOTWW2/Vrl279OKLL2revHne8oEDB+rNN9+U2+3WJ598orS0tCZfeWooJ9psCq5QAQDQRjm1FOS6665Tz549dfToUaWlpXnLf//73+v2229XSkqKwsLCtGLFCnk8nhbtixNtNoXLmB99fQAN4vF4FBoaqrKyMoWEhDjdHQBAG3Lu3DmdOHFCcXFxCg4Odro7HU59899Sn9/c8gMAALBEoAIAALBEoAIAALBEoAIAALBEoAIAALBEoAIAALBEoAIAALBEoAIAALBEoAIAALBEoAIAAF633XabXC5Xre3YsWPKycnR9OnT1bt3bwUHB6t///6aPXu2SkpKJElRUVF69NFHfepbsWKFXC6X9u7d61N+/fXX+/yszeXO8UC1bt0676PhExMTlZWVVeexhYWFSktL05AhQ+Tn56f09PRLHnfmzBktWbJEUVFRCg4O1rBhw7R79+4mtwsAQEfy85//XIWFhT5bt27dNGXKFIWFhWnPnj06cuSIXnzxRUVFRens2bOSpEmTJmnfvn0+de3fv18xMTE+5VVVVfrggw80efLkVh1XS3L0x5G3b9+u9PR0rVu3TuPHj9fzzz+vqVOn6rPPPlO/fv1qHV9ZWanw8HBlZGTo97///SXrrKqq0j/90z+pd+/eev3119W3b1+dPHlS3bp1a3K7AAA4quSY9O0JqWe81GtAizcXFBSkyMhIn7IdO3bI4/HohRdeUEDAhfgQFxen6667znvM5MmTdffdd+v8+fMKCAhQeXm5cnJytGbNGm3dutV73EcffaTvv/++XQUqR69QPfXUU1q0aJHuuOMODRs2TGvWrFFMTIzWr19/yeP79++vp59+WgsWLFBoaOglj3nxxRd1+vRp7dixQ+PHj1dsbKyuvfZajRw5ssntShfCnMfj8dkAAGhRZ09L/zlL+kOi9MrN0rNjLrz+/ttW70pkZKTOnz+vt956S8aYSx4zefJkVVRU6NChQ5KkrKwsDR48WDfffLMOHTrkvZK1b98+9e3bVwMHDmy1/rc0xwJVVVWVsrOzlZqa6lOempqqgwcPNrnenTt3Kjk5WUuWLFFERIQSEhL0yCOPqLq62qrd1atXKzQ01LvFxMQ0uY8AADTIG3dIeft9y/L2S68vatFm3377bV1xxRXe7ZZbbtG4ceP029/+VmlpaQoLC9PUqVP1+OOP6+9//7v3vEGDBqlPnz7av/9Cn/fv36+JEyeqd+/eio+P14EDB7zl7enqlORgoCopKVF1dbUiIiJ8yiMiIlRUVNTkevPy8vT666+rurpau3fv1v33368nn3xSDz/8sFW79913n8rKyrzbyZMnm9xHAAB+Uskx6fheyVT7lpvqC+Wlx1us6cmTJ8vtdnu3Z555RpL08MMPq6ioSM8995yGDx+u5557TkOHDtXhw4e9506aNMknUE2aNEmSNHHiRO3fv1+VlZX68MMPfW4VtgeOL0p3uVw+r40xtcoao6amRr1799aGDRuUmJioOXPmKCMjo9btvMa2GxQUpJCQEJ8NAIAW8+2J+vefzmuxprt27aqBAwd6t6ioKO++Xr166ZZbbtGTTz6pI0eOKDo6Wk888YR3/+TJk3XgwAGVlpYqJydHP/vZzyRdCFT79u3Thx9+2O7WT0kOBqqwsDD5+/vXuipUXFxc6+pRY0RFRWnw4MHy9/f3lg0bNkxFRUWqqqpqsXYBAGhWPeLq398zvnX6UY/AwEANGDBA3333nbds8uTJ+u677/TUU09p0KBB3s/WiRMn6n//93+1a9cuxcXFKTY21qlutwjHAlVgYKASExOVmZnpU56ZmamUlJQm1zt+/HgdO3ZMNTU13rIvvvhCUVFRCgwMbLF2AQBoVmEDpQHXSy5/33KX/4XyVvi23z96++23NW/ePL399tv64osvdPToUT3xxBPavXu3fvGLX3iPi4+PV79+/fTss89q4sSJ3vLo6GjFxsbqueeea3dXpySHb/ktW7ZML7zwgl588UUdOXJEv/nNb1RQUKDFixdLurBuacGCBT7nXLyfW1FRoVOnTsntduuzzz7z7r/rrrtUWlqqpUuX6osvvtCuXbv0yCOPaMmSJQ1uFwCANuHmTVL8JN+y+EkXylvZ8OHD1aVLF919990aNWqUxo0bpz/96U964YUXNH/+fJ9jJ0+erPLycu/6qYsmTpyo8vLydhmoZBy2du1aExsbawIDA82YMWPMe++95923cOFCM3HiRJ/jJdXaYmNjfY45ePCgGTt2rAkKCjLx8fHm4YcfNufPn29wuw1RVlZmJJmysrJGnQcAaP++//5789lnn5nvv/++eSosOWbMF+9c+F/8pPrmv6U+v13G1PEwCdTL4/EoNDRUZWVlLFAHAPg4d+6cTpw44f1FDrSu+ua/pT6/Hf+WHwAAwOWOQAUAAGCJQAUAAGCJQAUAQAthmbIznJh3AhUAAM2sU6dOkuT9MWC0rovzfvG/Q2sIaLWWAADoIPz9/dW9e3cVFxdLkrp06WL1s2poGGOMzp49q+LiYnXv3t3nV1NaGoEKAIAWEBkZKUneUIXW0717d+/8txYCFQAALcDlcikqKkq9e/fWDz/84HR3OoxOnTq16pWpiwhUAAC0IH9/f0c+4NG6WJQOAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAFAABgiUAF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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Drug\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 25\n",
    "metric=\"EO\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.01]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Drug DP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=0.01_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.423±0.013\n",
      "fair:0.08±0.015\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=1.0_alpha_0.002_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.405±0.013\n",
      "fair:0.043±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20da4d8670>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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UVFROn78uP74xz/qVN+JPHr0aB05ckR/+9vfJEkFBQW65JJLdMcdd+hvf/ubd8bp3Xff1cCBA3XRRRd1WP8BAGgtQlJntnG6VLbVt6xsq/TGtHZt9s0339R5553nXe68804NHz5c8+bN01133aXw8HClpaXp2Wef1b/+9S/vdhdffLEuuOACbd16os9bt27VyJEjFRERofj4eG3fvt1bziwSAKCzIyR1VtX7pM/ekaxG33Kr8UR5zWft1vTo0aNVUlLiXZYtWyZJevrpp+XxeJSdna3LLrtM2dnZuvTSS7V7927vtqNGjfIJSaNGjZIkjRw5Ulu3blV9fb127tzpc5kOAIDOiJDUWX1d3vz6r8rarenevXvroosu8i7R0dHedf3799edd96p5557TqWlpYqJidHixYu960ePHq3t27erpqZGxcXF+tGPfiTpREh69913tXPnTu5HAgB0CYSkzup8V/Pr+8V3TD+aERQUpMGDB+ubb77xlo0ePVrffPONlixZoosvvliRkZGSToSkoqIivfXWW3K5XIqLi7Or2wAAtAghqbMKv0gafIPkcPqWO5wnyjvgKbfvevPNN3XPPffozTff1Keffqo9e/Zo8eLFys3N1a233uqtFx8fr0GDBun555/XyJEjveUxMTGKi4tTdnY2s0gAgC6BkNSZ3ZEjxY/yLYsfdaK8g1122WU699xz9eijj+qHP/yhhg8frtdee00vvviipkyZ4lN39OjROnz4sPd+pJNGjhypw4cPE5IAAF2CwzrV89xoVl1dncLCwlRbW6vQ0FCfdd9++63Ky8vlcrkUEhJy5o3VfHbiHqQOek9SV3fWf/8AgG6juc/v7+Nlkl1B/8GEIwAAOhiX2wAAAAwISQAAAAaEJAAAAANCUjvinnh78HsHAJwNhKR2EBgYKEneL3RFxzr5ez95HAAAaAuebmsHTqdTffv2VVVVlSTp3HPPlcPhsLlX3Z9lWTp69KiqqqrUt29fOZ3O028EAMApEJLaSVRUlCR5gxI6Tt++fb2/fwAA2oqQ1E4cDoeio6MVERGhY8eO2d2dHiMwMJAZJADAWUFIamdOp5MPbQAAuiBu3AYAADAgJAEAABgQkgAAAAxsD0krVqzwflu72+1WQUFBs/W3bdsmt9utkJAQxcfHKzs722f9qFGj5HA4/Jabb77ZW+eJJ57wW8/T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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Drug\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 25\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.002]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bios - EO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=2e-05_tau=5.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.79±0.003\n",
      "fair:0.076±0.001\n",
      "\n",
      "method='FSW'\n",
      "lr=2e-05_tau=2.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.792±0.005\n",
      "fair:0.073±0.003\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20da350340>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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K/TUU09p1qxZGjRokFauXKl+/fpp3bp1Xuuzs7N16623auXKlRo0aJBmzZql7373u3rxxRddNX379pXdbnct+fn5CgoK8ghSp0+f1tSpU/Xyyy/rxhtv9NqfzWZz21ffvn0veTwtLS1qampyWwAAwLWrS0EqMTGxw5AjSWvWrFFiYmKn9tXa2qqSkhIlJye7tScnJ2v37t1etykqKvKoHzNmjPbu3atz58553cbpdGrKlCkKDg52a//BD36gcePGXXKGraCgQBEREbr99ts1e/Zs1dXVXfKYsrKyFBoa6lr69et3yXoAANCzdelm88WLFyspKUkNDQ2aO3euBg4cKMMwVFFRoeXLl+t///d/tWPHjk7tq76+Xm1tbYqMjHRrj4yMVG1trddtamtrvdafP39e9fX1ioqKclu3Z88elZeXe9y3lZOTo7/85S8qLi7ucHwpKSmaPHmyYmJiVFlZqf/8z//U6NGjVVJSIpvN5nWbhQsXKjMz0/W6qamJMAUAwDWsS0Fq+PDh2rRpk773ve+53ZckSTfeeKNef/113XvvvV0agMVicXttGIZH25fVe2uX2mej4uLiNGTIEFdbdXW1fvzjHysvL0+BgYEd9pOamur6d1xcnBISEhQTE6Pt27dr0qRJXrex2WwdhiwAAHDt6VKQkqSJEydqzJgxeuedd3T48GFJ0u23367k5GQFBQV1ej/h4eGyWq0es091dXUes04X2e12r/V+fn4KCwtza29ublZOTo6WLFni1l5SUqK6ujrFx8e72tra2vT+++9r9erVamlpkdVq9eg7KipKMTExrmMGAADo0j1SY8eOVWNjo4KCgjRx4kSdO3dO3/ve9zRhwgQFBQWpoaFBd9xxR6f2FRAQoPj4eOXn57u15+fna/jw4V63SUxM9KjPy8tTQkKC/P393do3b96slpYWTZs2za39gQceUFlZmfbt2+daEhISNHXqVO3bt89riJKkhoYGVVdXe1w+BAAA168uBal33nlHLS0trtfPP/+8Pv30U9fr8+fP6+DBg53eX2Zmpl555RVt2LBBFRUVysjIUFVVldLS0iS133P05JNPuurT0tJ0/PhxZWZmqqKiQhs2bJDT6dTcuXM99u10OjVhwgSPmaqQkBDFxcW5LcHBwQoLC1NcXJyk9m/0zZ07V0VFRTp27JgKCgo0fvx4hYeHa+LE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pKREycnJbu3JycnavXt3p/bhdDr14IMPun7sWpJaWloUGBjoVterVy/t2rWry/0WFBQoIiJCt99+u2bPnq26urpOH19P5Ktz0hmVlZWqra11G5vNZtPIkSM7Pbaeqjufl4uut78VqXudl8bGRklS3759JV3ffy9XE0EKPlVfX6+2tjZFRka6tUdGRqq2tvZLt6+pqdFbb72lWbNmubWPGTNGK1as0OHDh3XhwgXl5+frf//3f1VTU9OlflNSUvTaa6/pvffe0/Lly1VcXKzRo0erpaXF7CF3e746J51xsX+zY+vJuvN5ka7PvxWp+5wXwzCUmZmp++67T3FxcZKu77+Xq4kghW7BYrG4vTYMw6PNm1//+tfq06ePJkyY4Nb+y1/+UgMGDNDAgQMVEBCgH/7wh/rOd74jq9XapX5TU1M1btw4xcXFafz48Xrrrbd06NAhbd++vYtH2PP46pxcybFdC7rrebme/1Yk35+XH/7wh/rrX/+q119//bKNDZ1DkIJPhYeHy2q1evzfUV1dncf/RX2RYRjasGGDpk+froCAALd1N910k958802dOXNGx48f19/+9jfdcMMNcjgcX6nfqKgoxcTE6PDhw105zB7FV+ekM+x2uySZGltP153PizfXw9+K1D3Oy49+9CNt27ZNO3bs0C233OJqv57/Xq4mghR8KiAgQPHx8crPz3drz8/P1/Dhwy+5bWFhoY4cOaKnnnqqw5rAwEDdfPPNOn/+vLZs2aJHHnnkK/Xb0NCg6upqRUVFfdmh9Vi+Oied4XA4ZLfb3cbW2tqqwsLCLx1bT9edz4s318PfiuTb82IYhn74wx9q69ateu+99zxC1vX893JV+eQWd+BzLn512Ol0GgcOHDDS09ON4OBg1zdYFixYYEyfPt1ju2nTphlDhw71us8PP/zQ2LJli/Hxxx8b77//vjF69GjD4XAYJ06c6HS/p06dMn7yk58Yu3fvNiorK40dO3YYiYmJxs0333zNf3XYV+fk1KlTRmlpqVFaWmpIMlasWGGUlpa6fY182bJlRmhoqLF161ajrKzMePzxx6+br3N31/NyPf+tGIbvzsv3v/99IzQ01CgoKHB7nEJzc7Or5nr+e7laCFLoFtasWWPExMQYAQEBxt133+36+q5htH+teuTIkW71J0+eNHr16mWsX7/e6/4KCgqMQYMGGTabzQgLCzOmT59ufPLJJ13qt7m52UhOTjZuuukmw9/f37j11luNGTNmGFVVVZfnoLs5X5yTHTt2GJI8lhkzZrhqLly4YDz77LOG3W43bDabcf/99xtlZWWX7bi7u+54Xq73vxXD8M158XZOJBmvvvqqq+Z6/3u5GiyGYRhXexYMAADgWsA9UgAAACYRpAAAAEwiSAEAAJhEkAIAADCJIAUAAGASQQoAAMAkghQAAIBJBCkAAACTCFIAAAAmEaQAAABMIkgBAACYRJACgC94++23dd9996lPnz4KCwvTt7/9bX388ceu9X//+981ZcoU9e3bV8HBwUpISNCf//xn1/pt27YpISFBgYGBCg8P16RJk3xxGACuAoIUAHzBmTNnlJmZqeLiYr377rv62te+pokTJ+rChQs6ffq0Ro4cqX/84x/atm2bPvroI82bN08XLlyQJG3fvl2TJk3SuHHjVFpaqnfffVcJCQk+PiIAV4rFMAzD14MAgO7sX//6lyIiIlRWVqbdu3dr7ty5OnbsmPr27etRO3z4cMXGxuo3v/mND0YK4GpjRgoAvuDjjz/WE088odjYWPXu3VsOh0OSVFVVpX379umuu+7yGqIkad++fXrggQeu5nAB+JCfrwcAAN3N+PHj1a9fP7388suKjo7WhQsXFBcXp9bWVvXq1euS237ZegDXFmakAOBzGhoaVFFRof/zf/6PHnjgAQ0aNEgnTpxwrR88eLD27dunTz/91Ov2gwcP1rvvvnu1hgvAxwhSAPA5N954o8LCwrR+/XodOXJE7733njIzM13rH3/8cdntdk2YMEEffPCBjh49qi1btqioqEiS9Oyzz+r111/Xs88+q4qKCpWVlemFF17w1eEAuMIIUgDwOV/72teUk5OjkpISxcXFKSMjQz//+c9d6wMCApSXl6eIiAiNHTtWd955p5YtWyar1SpJSkpK0u9+9ztt27ZN3/rWtzR69Gi3RyMAuLbwrT0AAACTmJECAAAwiSAFAABgEkEKAADAJIIUAACASQQpAAAAkwhSAAAAJhGkAAAATCJIAQAAmESQAgAAMIkgBQAAYBJBCgAAwKT/H6XCTqkH5BEkAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Bios_128\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 10\n",
    "metric=\"EO\"\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [5.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('EO')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bios DP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='vanilla'\n",
      "lr=2e-05_tau=5.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.79±0.003\n",
      "fair:0.022±0.0\n",
      "\n",
      "method='FSW'\n",
      "lr=2e-05_tau=2.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.797±0.003\n",
      "fair:0.022±0.0\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20da3c9880>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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j7Z169apurpazz//vHx9z0aMhIQE3Xbbbe6asWPH6he/+IUaGxvl6+ur06dPq7i4WP/5n/+pNWvWuOveffddffnllx0+SHFHCgCAzqz2M+n/3SNlJUov3yv9YdjZn788dcm7Eh0drcbGRr3++usyxnitGTt2rL744gu99957kqStW7fq2muv1b333qv33nvPfecqPz9fvXv3Vr9+/S5Z/20QpAAA6MxyfiIdKvBsO1Qg/c+P2/Wyf/nLXxQUFOTe7rvvPt10002aN2+eHnjgAUVERGjChAlavHix/vGPf7iP69+/v3r16qWCgrN9Ligo0OjRoxUZGam+ffvqnXfecbd39LtREkEKAIDOq/KAdPAtyTR5tpums+0nD7bbpceOHauSkhL39vvf/16S9Mwzz6i8vFzLly/Xddddp+XLl2vAgAHas2eP+9gxY8Z4BKkxY8ZIkkaPHq2CggLV1dVp+/btHo8EOyrHg9TSpUuVkJCgwMBAJSYmauvWrResLywsVGJiogIDA9W3b18tX77cY//KlSuVnJys0NBQhYaGKiUlRTt27PCoyczM1PDhwxUcHKzIyEilpaVp3759HjVPPfWUBgwYoG7durnP8+6777bNoAEAaAunSi+8/7ND7Xbpbt26qV+/fu6tZ8+e7n3h4eG677779Jvf/EZ79+5VTEyMlixZ4t4/duxYvfPOOzp58qSKi4t16623SjobpPLz87V9+/ZOsT5KcjhIvfrqq5o1a5bmz5+v4uJiJScna8KECSorK/NaX1paqokTJyo5OVnFxcWaN2+eZs6cqZycHHdNQUGBJk+erPz8fBUVFalPnz5KTU3V0aNH3TWFhYWaPn26tm/frry8PDU2Nio1NVU1NTXummuvvVZZWVnas2eP3n77bcXHxys1NVUnTpxovwkBAKA1QhMuvD+s76XpxwX4+/vrmmuu8fiMHTt2rGpqavTss8+qf//+ioqKknQ2SL3//vtav369EhISFBcX51S3W8446MYbbzTp6ekebQMGDDBz5szxWv/EE0+YAQMGeLQ9+uij5qabbjrvNRobG01wcLD54x//eN6aiooKI8kUFhaet6aqqspIMps2bTpvzVdffWWqqqrc25EjR4wkU1VVdd5jAABXpi+//NJ89NFH5ssvv7y4E62+25inQo1Z0P3/tqdCz7a3k6lTp5pJkyY1a//zn/9sHnzwQfPnP//Z7Nu3z3z88cdm8eLFxsfHx6xevdqjtk+fPiY4OLhZDujXr58JDg42Dz/8cLv135gLz/+5z/yWfH47dkeqvr5eO3fuVGpqqkd7amqqtm3b5vWYoqKiZvXjx4/X+++/r4aGBq/H1NbWqqGhQWFhYeftS1VVlSSdt6a+vl4rVqxQSEiIhgwZct7zZGZmKiQkxL3FxsaetxYAgDZx7yqp7xjPtr5jzrZfYtddd526du2qX/ziF7rhhht000036b//+7/1/PPPa8qUKR61Y8eO1enTp93ro84ZPXq0Tp8+3Ske60mSy5jzfD+xnR07dky9evXSO++8o1GjRrnbFy5cqD/+8Y/N1ixJZx+3TZs2TfPmzXO3bdu2TTfffLOOHTvm8Xz2nOnTp+vNN9/Uhx9+qMDAwGb7jTGaNGmSTp061Wx91l/+8hfdf//9qq2tVc+ePbVu3ToNHz78vGOqq6tTXV2d++fq6mrFxsaqqqpK3bt3v/CEAACuKF999ZVKS0vd64Qv2smDZ9dEXaL3SHV2F5r/6upqhYSEtOjz2/EXcrpcLo+fjTHN2r6t3lu7JC1atEjZ2dkqKCg47y/pjBkztHv3br399tvN9p37RkJlZaVWrlyp73//+3r33XcVGRnp9VwBAQEKCAg4b98BAGg34dcQoBzg2KO9iIgI+fj4qLy83KO9oqLCvejsm6Kjo73W+/r6Kjw83KN9yZIlWrhwoTZu3KjBgwd7Pd9jjz2m3Nxc90u/vuncNxJuuukmrVq1Sr6+vlq16tLfKgUAAB2TY0HK399fiYmJysvL82jPy8vzeNT3dSNHjmxWv3HjRiUlJcnPz8/dtnjxYj399NPasGGDkpKSmp3HGKMZM2Zo7dq12rx5sxISvuVbD1877uuP7gAAwJXN0Ud7GRkZmjJlipKSkjRy5EitWLFCZWVlSk9PlyTNnTtXR48e1erVqyVJ6enpysrKUkZGhh555BEVFRVp1apVys7Odp9z0aJFevLJJ7VmzRrFx8e772Cde/OqdHbd1Jo1a/TGG28oODjYXRMSEqIuXbqopqZGzzzzjO666y717NlTJ0+e1NKlS/X3v/9d991336WcIgAA0JG16XcJLTz33HMmLi7O+Pv7m2HDhnm8gmDq1Klm9OjRHvUFBQVm6NChxt/f38THx5tly5Z57I+LizOSmm0LFixw13jbL8m8+OKLxpizX4m8++67TUxMjPH39zc9e/Y0d911l9mxY0erxtaar08CAK4s575+X1tb63RXrki1tbVt8voDx761dyVozap/AMCVpampSZ988okiIyObrfNF+zt58qQqKip07bXXysfHx2Nfp/rWHgAAVyIfHx/16NFDFRUVkqSuXbte8FvraBvGGNXW1qqiokI9evRoFqJaiyAFAIBDoqOjJckdpnDp9OjRwz3/F4MgBQCAQ1wul3r27KnIyMjz/oUOtD0/P7+LvhN1DkEKAACH+fj4tNkHOy4tx94jBQAA0NkRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACwRpAAAACw5HqSWLl2qhIQEBQYGKjExUVu3br1gfWFhoRITExUYGKi+fftq+fLlHvtXrlyp5ORkhYaGKjQ0VCkpKdqxY4dHTWZmpoYPH67g4GBFRkYqLS1N+/btc+9vaGjQ7Nmzdf3116tbt26KiYnRQw89pGPHjrXdwAEAQKfnaJB69dVXNWvWLM2fP1/FxcVKTk7WhAkTVFZW5rW+tLRUEydOVHJysoqLizVv3jzNnDlTOTk57pqCggJNnjxZ+fn5KioqUp8+fZSamqqjR4+6awoLCzV9+nRt375deXl5amxsVGpqqmpqaiRJtbW1+uCDD/Tkk0/qgw8+0Nq1a/XJJ5/orrvuat8JAQAAnYrLGGOcuviIESM0bNgwLVu2zN02cOBApaWlKTMzs1n97NmzlZubq71797rb0tPTtWvXLhUVFXm9RlNTk0JDQ5WVlaWH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Rz+Sj49Pm1z3UnFqXjo6p+dlxowZ2r17t7Kzs63H0B6cmpfvfOc7Kikp0fbt2/XTn/5UU6dO1UcffXTR42krl3pejhw5oscff1x/+tOfmt2J6Eic+H2ZMGGC/vmf/1nXX3+9UlJStH79eknSH//4x4sfUBtxYl7OnDmjYcOGaeHChRo6dKgeffRRPfLII1q2bFmbjKmjIki1gYiICPn4+DRL+xUVFc3+X8E3GWP0wgsvaMqUKfL39/fYd/XVV2vdunWqqanRp59+qo8//lhBQUFKSEi46OteCk7NS0fXEeblscceU25urvLz89W7d++LH1QbcHpe/P391a9fPyUlJSkzM1NDhgzR7373u7YZ3EVwal527typiooKJSYmytfXV76+viosLNTvf/97+fr6qqmpqW0H2kpO/758Xbdu3XT99ddr//799gNqI07OS8+ePZvdxR04cKDKysouclQdG0GqDfj7+ysxMVF5eXke7Xl5eRo1atQFjy0sLNSBAwf04x//+Lw1gYGB6tWrlxobG5WTk6NJkyZd9HUvBafmpaNzcl6MMZoxY4bWrl2rzZs3d6jw2dF+X4wxqqura/kA2olT8zJu3Djt2bNHJSUl7i0pKUkPPvigSkpKHL8D3JF+X+rq6rR371717NmzdYNoB07Oy80339zsdSqffPKJx1qry9KlXt1+uTr3ddNVq1aZjz76yMyaNct069bN/a2HOXPmmClTpjQ77oc//KEZMWKE13Nu377d5OTkmIMHD5otW7aY2267zSQkJJhTp061+LpOc2peTp8+bYqLi01xcbGRZJ599llTXFzc4V4Lcann5ac//akJCQkxBQUFHl93rq2tbZdxtpZT8zJ37lyzZcsWU1paanbv3m3mzZtnrrrqKrNx48Z2GWdrOTUv39TRvrXn1Lz84he/MAUFBebQoUNm+/bt5o477jDBwcFX/L+7O3bsML6+vuaZZ54x+/fvNy+//LLp2rWr+dOf/tQu4+woCFJt6LnnnjNxcXHG39/fDBs2zOMr5VOnTjWjR4/2qP/8889Nly5dzIoVK7yer6CgwAwcONAEBASY8PBwM2XKFHP06NFWXbcjcGJe8vPzjaRm29SpU9t6eNacmBdvcyLJvPjii209PGtOzMvDDz/svubVV19txo0b12FC1DlO/fvydR0tSBnjzLz84Ac/MD179jR+fn4mJibG3HPPPeZvf/tbm4/tYjj1+/LnP//ZDBo0yAQEBJgBAwac93yXE5cxxjhzLwwAAKBzY40UAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAACAJYIUAHzDhg0bdMstt6hHjx4KDw/XHXfcoYMHD7r3//3vf9f999+vsLAwdevWTUlJSXr33Xfd+3Nzc5WUlKTAwEBFRETonnvucWIYAC4BghQAfENNTY0yMjL03nvv6a233tJVV12lu+++W2fOnNEXX3yh0aNH69ixY8rNzdWuXbv0xBNP6MyZM5Kk9evX65577tH3vvc9FRcX66233lJSUpLDIwLQXlzGGON0JwCgIztx4oQiIyO1Z88ebdu2Tf/6r/+qw4cPKywsrFntqFGj1LdvX/3pT39yoKcALjXuSAHANxw8eFAPPPCA+vbtq+7duyshIUGSVFZWppKSEg0dOtRriJKkkpISjRs37lJ2F4CDfJ3uAAB0NHfeeadiY2O1cuVKxcTE6MyZMxo0aJDq6+vVpUuXCx77bfsBXF64IwUAX3Py5Ent3btXv/zlLzVu3DgNHDhQp06dcu8fPHiwSkpK9Nlnn3k9fvDgwXrrrbcuVXcBOIwgBQBfExoaqvDwcK1YsUIHDhzQ5s2blZGR4d4/efJkRUdHKy0tTe+8844OHTqknJwcFRUVSZIWLFig7OxsLViwQHv37tWePXu0aNEip4YDoJ0RpADga6666iq98sor2rlzpwYNGqSf//znWrx4sXu/v7+/Nm7cqMjISE2cOFHXX3+9fvWrX8nHx0eSNGbMGL322mvKzc3VDTfcoNtuu83j1QgALi98aw8AAMASd6QAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAsEaQAAAAs/X9kuK3YSWQUWQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Bios_128\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 10\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [5.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"vanilla\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, label=method)\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CL + epsilon-fairness"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BiasedMNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.818±0.011\n",
      "fair:0.012±0.001\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.872±0.011\n",
      "fair:0.013±0.001\n",
      "\n",
      "method='OCS'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.816±0.012\n",
      "fair:0.03±0.003\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=10.0_alpha_0.01_lmbd=0.5_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.889±0.006\n",
      "fair:0.007±0.002\n",
      "\n",
      "method='iCaRL_eps_fairness'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.05(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.805±0.014\n",
      "fair:0.007±0.002\n",
      "\n",
      "method='CLAD_1.0_eps_fairness'\n",
      "lr=0.001_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.01(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.868±0.015\n",
      "fair:0.006±0.002\n",
      "\n",
      "method='OCS_eps_fairness'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.02(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.825±0.016\n",
      "fair:0.005±0.001\n",
      "\n",
      "method='FSW_eps_fairness'\n",
      "lr=0.001_tau=10.0_alpha_0.01_lmbd=0.5_eps=0.01(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.883±0.007\n",
      "fair:0.005±0.001\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20da2abee0>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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plAohEKhENra2iI5OVlt46nN1PWz1bVrV9G9e3eVNuHh4QKAyM/Pr8IRvDzU9V516dJFTJs2TaXN119/LQwMDERRUVEVjqB24EwSvXB0dXXh7u6Oo0ePqpQfPXoUXl5esvs8fPgQWlqq/521tbUBFP/lVeKzzz7DokWLcPjwYXh4eFRx5C8ndbxfzs7OuHTpEuLi4qStX79+8PX1RVxcHGxsbNQzmFpOXT9bnTt3RnJyMpRKpdTmypUrsLS0hK6ublUO4aWhrveqrDai+EKuqgq/9tBkhkZUlpJLX7du3SoSEhLE5MmThZGRkUhLSxNCCDFz5kwxYsQIqX1oaKjQ0dER69atE1evXhW//fab8PDwEB06dJDaLF26VOjq6oq9e/eKjIwMabt37161j6+2Ucf79SRe3VY11PFepaenC2NjYzFhwgRx+fJl8dNPP4nGjRuLjz/+uNrHV5uo472aN2+eMDExETt37hQpKSkiIiJCNGvWTAwePLjax1cTMEmiF9batWuFra2t0NXVFe3atRMnTpyQ6kaNGiV8fHxU2q9evVq0bNlSGBgYCEtLSzFs2DCVeyDZ2toKAKW2efPmVdOIareqfr+exCSp6qjjvTpz5ozo2LGj0NPTEw4ODmLx4sWisLCwOoZTq1X1e/X48WMxf/580axZM6Gvry9sbGzEuHHjxD///FNNI6pZFEJwfo2IiIjoSVyTRERERCSDSRIRERGRDCZJRERERDKYJBERERHJYJJEREREJINJEhEREZEMJklEREREMpgkEREREclgkkREREQkg0kSERERkQwmSUREREQymCQR0Uvl8OHD6NKlC+rWrYsGDRrgtddew9WrV6X6GzduYMiQIahfvz6MjIzg4eGBc+fOSfUHDx6Eh4cH9PX10bBhQ7zxxhuaGAYRVQMmSUT0Unnw4AGmTJmC8+fP49ixY9DS0sLrr78OpVKJ+/fvw8fHB7du3cLBgwdx4cIFTJ8+HUqlEgDw888/44033kCfPn0QGxuLY8eOwcPDQ8MjIiJ1UQghhKaDICLSlL///huNGzfGpUuXcObMGUybNg1paWmoX79+qbZeXl5wcHDAN998o4FIiai6cSaJiF4qV69exZtvvgkHBweYmprC3t4eAJCeno64uDi0bdtWNkECgLi4OHTv3r06wyUiDdLRdABERNWpb9++sLGxwebNm2FlZQWlUglXV1cUFBTAwMCg3H2fVk9EtQtnkojopZGdnY3ExETMmTMH3bt3h4uLC/755x+pvk2bNoiLi8OdO3dk92/Tpg2OHTtWXeESkYYxSSKil0a9evXQoEEDbNq0CcnJyfj1118xZcoUqX7o0KGwsLBAYGAgTp8+jZSUFOzbtw9RUVEAgHnz5mHnzp2YN28eEhMTcenSJSxbtkxTwyEiNWOSREQvDS0tLezatQsxMTFwdXVFSEgIPvvsM6leV1cXERERaNy4MXr37o3WrVvj008/hba2NgCgW7du2LNnDw4ePAg3Nze8+uqrKrcHIKLahVe3EREREcngTBIRERGRDCZJRERERDKYJBERERHJYJJEREREJINJEhEREZEMJklEREREMpgkEREREclgkkREREQkg0kSERERkQwmSUREREQymCQRERERyfg/V3urrkRmze0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"BiasedMNIST\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 15\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[0], label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[1], label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[2], label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.01]\n",
    "lambda_range = [0.5]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[3], label=method)\n",
    "\n",
    "\n",
    "eps_range = [0.05]\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"iCaRL_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[0], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.01]\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[1], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.02]\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[2], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.01]\n",
    "lr_range = [0.001]\n",
    "tau_range = [10.0]\n",
    "alpha_range = [0.01]\n",
    "lambda_range = [0.5]\n",
    "method = \"FSW_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[3], marker='v', label=method)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Drug"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='iCaRL'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.458±0.014\n",
      "fair:0.098±0.02\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=0.01_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.41±0.026\n",
      "fair:0.069±0.019\n",
      "\n",
      "method='OCS'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.429±0.007\n",
      "fair:0.079±0.02\n",
      "\n",
      "method='FSW'\n",
      "lr=0.001_tau=1.0_alpha_0.002_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.405±0.013\n",
      "fair:0.043±0.004\n",
      "\n",
      "method='iCaRL_eps_fairness'\n",
      "lr=0.1_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.46±0.015\n",
      "fair:0.035±0.013\n",
      "\n",
      "method='CLAD_1.0_eps_fairness'\n",
      "lr=0.01_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.411±0.023\n",
      "fair:0.03±0.01\n",
      "\n",
      "method='OCS_eps_fairness'\n",
      "lr=0.01_tau=10.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.431±0.021\n",
      "fair:0.033±0.007\n",
      "\n",
      "method='FSW_eps_fairness'\n",
      "lr=0.001_tau=1.0_alpha_0.002_lmbd=0.1_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.403±0.01\n",
      "fair:0.02±0.004\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20da209eb0>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Drug\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 25\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[0], label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[1], label=method)\n",
    "\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[2], label=method)\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.002]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[3], label=method)\n",
    "\n",
    "eps_range = [0.0]\n",
    "lr_range = [0.1]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"iCaRL_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[0], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.0]\n",
    "lr_range = [0.01]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[1], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.0]\n",
    "lr_range = [0.01]\n",
    "tau_range = [10.0]\n",
    "method = \"OCS_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[2], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.0]\n",
    "lr_range = [0.001]\n",
    "tau_range = [1.0]\n",
    "alpha_range = [0.002]\n",
    "lambda_range = [0.1]\n",
    "method = \"FSW_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[3], marker='v', label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bios"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method='iCaRL'\n",
      "lr=0.001_tau=2.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.828±0.002\n",
      "fair:0.022±0.0\n",
      "\n",
      "method='CLAD_1.0'\n",
      "lr=2e-05_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.785±0.004\n",
      "fair:0.022±0.0\n",
      "\n",
      "method='FSW'\n",
      "lr=2e-05_tau=2.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.797±0.003\n",
      "fair:0.022±0.0\n",
      "\n",
      "method='iCaRL_eps_fairness'\n",
      "lr=0.001_tau=2.0_alpha_0.0_lmbd=0.0_eps=0.0(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.828±0.001\n",
      "fair:0.016±0.0\n",
      "\n",
      "method='CLAD_1.0_eps_fairness'\n",
      "lr=2e-05_tau=1.0_alpha_0.0_lmbd=0.0_eps=0.03(cnt=5, [0, 1, 2, 3, 4])\n",
      "acc:0.759±0.049\n",
      "fair:0.017±0.0\n",
      "\n",
      "method='FSW_eps_fairness'\n",
      "lr=2e-05_tau=2.0_alpha_0.001_lmbd=1.0_eps=0.0(cnt=3, [0, 1, 2, 3, 4])\n",
      "acc:0.796±0.003\n",
      "fair:0.016±0.0\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f20da2af940>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset = \"Bios_128\"\n",
    "seed_range = [0, 1, 2, 3, 4]\n",
    "epoch = 10\n",
    "metric=\"DP\"\n",
    "\n",
    "lr_range = [0.001]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"iCaRL\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[0], label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[1], label=method)\n",
    "\n",
    "lr_range = [2e-5]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[3], label=method)\n",
    "\n",
    "eps_range = [0.0]\n",
    "lr_range = [0.001]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.0]\n",
    "lambda_range = [0.0]\n",
    "method = \"iCaRL_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[0], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.03]\n",
    "lr_range = [2e-5]\n",
    "tau_range = [1.0]\n",
    "method = \"CLAD_1.0_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[1], marker='v', label=method)\n",
    "\n",
    "eps_range = [0.0]\n",
    "lr_range = [2e-5]\n",
    "tau_range = [2.0]\n",
    "alpha_range = [0.001]\n",
    "lambda_range = [1.0]\n",
    "method = \"FSW_eps_fairness\"\n",
    "print(f\"{method=}\")\n",
    "info_list, acc_list, fair_list, *_ = get_best(dataset, seed_range, epoch, lr_range, tau_range, alpha_range, lambda_range, method, eps_range=eps_range, metric=metric, verbose=1)\n",
    "plt.scatter(acc_list, fair_list, s = 20, color = color_list[3], marker='v', label=method)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('acc')\n",
    "plt.ylabel('DP')\n",
    "\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cil",
   "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
}
