{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plotting for NAS-Bench-Suite Black-Box Optimizers"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This notebook was used to plot the black-box optimizer experiments from Section 4 of \n",
    "[NAS-Bench-Suite: NAS Evaluation is (Now) Surprisingly Easy](https://arxiv.org/abs/2201.13396). This includes plotting the results of Random Search, Regularized Evolution, Local Search, BANANAS, and NPENAS."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 268,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "import copy\n",
    "import numpy as np\n",
    "import json\n",
    "import pickle\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from scipy.stats import kendalltau\n",
    "matplotlib.rcParams['pdf.fonttype'] = 42"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# method that gathers all of the results\n",
    "\n",
    "# example result path:\n",
    "# ~/results_nas_bench_suite/bbo_results_oct1/bbo_results_oct1_0/nasbench201/cifar100/npenas/config_28/7\n",
    "\n",
    "# and the result dict structure:\n",
    "# results_dict[28][nb201_c10][npenas] = [np.mean(values), np.std(values)]\n",
    "\n",
    "def get_hpo_results(optimizers, search_spaces, root):\n",
    "    errors = 0\n",
    "    results_dict = {}\n",
    "    root = os.path.expanduser(root)\n",
    "    for seed_header in os.listdir(root):\n",
    "        for search_space in search_spaces:\n",
    "            search_space_dict = {}\n",
    "            for optimizer in optimizers:\n",
    "                optimizer_path = root + '/' + seed_header + '/' + file_dict[search_space] + '/' + optimizer\n",
    "                if os.path.exists(optimizer_path):\n",
    "                    for hpo_folder in os.listdir(optimizer_path):\n",
    "                        hpo_seed = int(hpo_folder.split('_')[-1])\n",
    "                        values = []\n",
    "                        for seed in os.listdir(optimizer_path + '/' + hpo_folder):\n",
    "                            result_path = optimizer_path + '/' + hpo_folder + '/' + seed + '/errors.json'\n",
    "                            if os.path.isfile(result_path):\n",
    "                                result = json.load(open(result_path))\n",
    "                                valid_accs = result[1]['valid_acc']\n",
    "                                value = np.max(valid_accs)\n",
    "                                if not np.isnan(value):\n",
    "                                    values.append(value)\n",
    "                        if len(values) > 3:\n",
    "                            # had to add these if statements because file structure is in a different order\n",
    "                            if hpo_seed not in results_dict:\n",
    "                                results_dict[hpo_seed] = {}\n",
    "                            if search_space not in results_dict[hpo_seed]:\n",
    "                                results_dict[hpo_seed][search_space] = {}\n",
    "                            if optimizer not in results_dict[hpo_seed][search_space]:\n",
    "                                results_dict[hpo_seed][search_space][optimizer] = {}\n",
    "                            results_dict[hpo_seed][search_space][optimizer] = [np.mean(values), np.std(values)]\n",
    "                        else:\n",
    "                            print(len(values), 'not enough values', hpo_seed, search_space, optimizer)\n",
    "                            errors += 1\n",
    "                            if errors > 100:\n",
    "                                print('ending early due to excess errors')\n",
    "                                return results_dict\n",
    "\n",
    "    return results_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define constants that will be used throughout the notebook\n",
    "\n",
    "\"\"\"\n",
    "Set up colors. There are 11 colors defined in 'defaults', and 3 markers/formats for the plot lines.\n",
    "So there are 33 color/markers total.\n",
    "\"\"\"\n",
    "defaults = [(0.12156862745098039, 0.4666666666666667, 0.7058823529411765),\n",
    "            (1.0, 0.4980392156862745, 0.054901960784313725),\n",
    "            (0.17254901960784313, 0.6274509803921569, 0.17254901960784313),\n",
    "            (0.8392156862745098, 0.15294117647058825, 0.1568627450980392),\n",
    "            (0.5803921568627451, 0.403921568627451, 0.7411764705882353),\n",
    "            (0.5490196078431373, 0.33725490196078434, 0.29411764705882354),\n",
    "            (0.8901960784313725, 0.4666666666666667, 0.7607843137254902),\n",
    "            (0.4980392156862745, 0.4980392156862745, 0.4980392156862745),\n",
    "            (0.7372549019607844, 0.7411764705882353, 0.13333333333333333),\n",
    "            (0.09019607843137255, 0.7450980392156863, 0.8117647058823529),\n",
    "            (0.0, 0.0, 0.0)\n",
    "           ]\n",
    "\n",
    "fmts = ['-', '--', ':', '-.']\n",
    "markers = ['^', 'v', 'o']\n",
    "defaults = [np.array(d) for d in defaults]\n",
    "\n",
    "color_dict={\n",
    "    'rs':{'color':defaults[0], 'fmt':fmts[0]},\n",
    "    're':{'color':defaults[1], 'fmt':fmts[0]},\n",
    "    'ls':{'color':defaults[2], 'fmt':fmts[0]},\n",
    "    'bananas':{'color':defaults[3], 'fmt':fmts[0]},\n",
    "    'npenas':{'color':defaults[4], 'fmt':fmts[0]},\n",
    "}\n",
    "\n",
    "# how the optimizer names will be displayed in the plot legends:\n",
    "pred_label_dict={\n",
    "    'rs': 'Rand. Search', 're':'Reg. Evo.', 'ls':'Local Search', \n",
    "    'bananas':'BANANAS', 'npenas':'NPENAS'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 232,
   "metadata": {},
   "outputs": [],
   "source": [
    "# search space constants\n",
    "\n",
    "# how the search space name will be displayed in the plot titles:\n",
    "ss_dict_lined = {'nb101':'NB-101\\n CIFAR10', \n",
    "                 'nb201_c10':'NB-201\\n CIFAR10', \n",
    "                 'nb201_c100':'NB-201\\n CIFAR100', \n",
    "                 'nb201_im':'NB-201\\n ImageNet', \n",
    "                 'darts':'DARTS\\n CIFAR10',\n",
    "                 'nlp':'NB-NLP\\n TreeBank',\n",
    "                 'asr':'NB-ASR\\n TIMIT',\n",
    "                 'mr_3ddet':'NB-MR\\n KITTI',\n",
    "                 'mr_cls':'NB-MR\\n ImageNet',\n",
    "                 'mr_seg':'NB-MR\\n City',\n",
    "                 'mr_video':'NB-MR\\n HMDB51',\n",
    "                 'transmicro_obj':'TNB-Micro\\n Object', \n",
    "                 'transmicro_scene':'TNB-Micro\\n Scene', \n",
    "                 'transmicro_jigsaw':'TNB-Micro\\n Jigsaw', \n",
    "                 'transmicro_room':'TNB-Micro\\n Room',\n",
    "                 'transmicro_segment':'TNB-Micro\\n Semantic', \n",
    "                 'transmicro_normal':'TNB-Micro\\n Surface', \n",
    "                 'transmicro_auto':'TNB-Micro\\n Autoenc.', \n",
    "                 'transmacro_obj':'TNB-Macro\\n Object', \n",
    "                 'transmacro_scene':'TNB-Macro\\n Scene', \n",
    "                 'transmacro_jigsaw':'TNB-Macro\\n Jigsaw', \n",
    "                 'transmacro_room':'TNB-Macro\\n Room',\n",
    "                 'transmacro_segment':'TNB-Macro\\n Semantic', \n",
    "                 'transmacro_normal':'TNB-Macro\\n Surface', \n",
    "                 'transmacro_auto':'TNB-Macro\\n Autoenc.', \n",
    "          }\n",
    "\n",
    "ss_dict_oneline = {'nb101':'NB-101 CIFAR10', \n",
    "                 'nb201_c10':'NB-201 CIFAR10', \n",
    "                 'nb201_c100':'NB-201 CIFAR100', \n",
    "                 'nb201_im':'NB-201 ImageNet', \n",
    "                 'darts':'DARTS CIFAR10',\n",
    "                 'nlp':'NB-NLP TreeBank',\n",
    "                 'asr':'NB-ASR TIMIT',\n",
    "                 'mr_3ddet':'NB-MR KITTI',\n",
    "                 'mr_cls':'NB-MR ImageNet',\n",
    "                 'mr_seg':'NB-MR City',\n",
    "                 'mr_video':'NB-MR HMDB51',\n",
    "                 'transmicro_obj':'TNB-Micro Object', \n",
    "                 'transmicro_scene':'TNB-Micro Scene', \n",
    "                 'transmicro_jigsaw':'TNB-Micro Jigsaw', \n",
    "                 'transmicro_room':'TNB-Micro Room',\n",
    "                 'transmicro_segment':'TNB-Micro Semantic', \n",
    "                 'transmicro_normal':'TNB-Micro Surface', \n",
    "                 'transmicro_auto':'TNB-Micro Autoenc.', \n",
    "                 'transmacro_obj':'TNB-Macro Object', \n",
    "                 'transmacro_scene':'TNB-Macro Scene', \n",
    "                 'transmacro_jigsaw':'TNB-Macro Jigsaw', \n",
    "                 'transmacro_room':'TNB-Macro Room',\n",
    "                 'transmacro_segment':'TNB-Macro Semantic', \n",
    "                 'transmacro_normal':'TNB-Macro Surface', \n",
    "                 'transmacro_auto':'TNB-Macro Autoenc.', \n",
    "          }\n",
    "\n",
    "# abbreviations used for the matrix plots:\n",
    "ss_dict_mat = {'nb101':'NB-101', \n",
    "                 'nb201_c10':'NB-201', \n",
    "                 'nb201_c100':'NB-201', \n",
    "                 'nb201_im':'NB-201', \n",
    "                 'darts':'DARTS',\n",
    "                 'nlp':'NB-NLP',\n",
    "                 'asr':'NB-ASR',\n",
    "                 'mr_3ddet':'NB-MR',\n",
    "                 'mr_cls':'NB-MR',\n",
    "                 'mr_seg':'NB-MR',\n",
    "                 'mr_video':'NB-MR',\n",
    "                 'transmicro_obj':'TNB-Micro', \n",
    "                 'transmicro_scene':'TNB-Micro', \n",
    "                 'transmicro_jigsaw':'TNB-Micro', \n",
    "                 'transmicro_room':'TNB-Micro',\n",
    "                 'transmicro_segment':'TNB-Micro', \n",
    "                 'transmicro_normal':'TNB-Micro', \n",
    "                 'transmicro_auto':'TNB-Micro', \n",
    "                 'transmacro_obj':'TNB-Macro', \n",
    "                 'transmacro_scene':'TNB-Macro', \n",
    "                 'transmacro_jigsaw':'TNB-Macro', \n",
    "                 'transmacro_room':'TNB-Macro',\n",
    "                 'transmacro_segment':'TNB-Macro', \n",
    "                 'transmacro_normal':'TNB-Macro', \n",
    "                 'transmacro_auto':'TNB-Macro', \n",
    "          }\n",
    "\n",
    "# these are the file paths we used\n",
    "file_dict = {\n",
    "    'nb101':'nasbench101/cifar10', \n",
    "    'nb201_c10':'nasbench201/cifar10', \n",
    "    'nb201_c100':'nasbench201/cifar100', \n",
    "    'nb201_im':'nasbench201/ImageNet16-120', \n",
    "    'darts':'darts/cifar10', \n",
    "    'nlp':'nlp/LM-task', \n",
    "    'asr':'asr/TIMIT', \n",
    "    'transmicro_obj':'transbench101_micro/class_object',\n",
    "    'transmicro_scene':'transbench101_micro/class_scene',\n",
    "    'transmicro_jigsaw':'transbench101_micro/jigsaw',\n",
    "    'transmicro_room':'transbench101_micro/room_layout',\n",
    "    'transmicro_segment':'transbench101_micro/segmentsemantic',\n",
    "    'transmicro_normal':'transbench101_micro/normal',\n",
    "    'transmicro_auto':'transbench101_micro/autoencoder',\n",
    "    'transmacro_obj':'transbench101_macro/class_object',\n",
    "    'transmacro_scene':'transbench101_macro/class_scene',\n",
    "    'transmacro_jigsaw':'transbench101_macro/jigsaw',\n",
    "    'transmacro_room':'transbench101_macro/room_layout',\n",
    "    'transmacro_segment':'transbench101_macro/segmentsemantic',\n",
    "    'transmacro_normal':'transbench101_macro/normal',\n",
    "    'transmacro_auto':'transbench101_macro/autoencoder',\n",
    "    'mr_3ddet':'mr/3ddet',\n",
    "    'mr_cls':'mr/cls',\n",
    "    'mr_seg':'mr/seg',\n",
    "    'mr_video':'mr/video',\n",
    "            }"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Now load all of the data\n",
    " - Each algorithm is tagged as \"algorithm_date\"\n",
    " - The next cell will create a dictionary will all of the results from the specified search space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "search_spaces = ['nb101', 'nb201_c10', 'nb201_c100', 'nb201_im', 'darts', 'asr', 'nlp',\n",
    "                 'mr_3ddet', 'mr_cls', 'mr_seg', 'mr_video',\n",
    "                 'transmicro_obj', 'transmicro_scene', 'transmicro_jigsaw', \n",
    "                 'transmicro_room', 'transmicro_segment', 'transmicro_normal', \n",
    "                 'transmicro_auto', \n",
    "                 'transmacro_obj', 'transmacro_scene', 'transmacro_jigsaw', \n",
    "                 'transmacro_room', 'transmacro_segment', 'transmacro_normal', \n",
    "                 'transmacro_auto']\n",
    "\n",
    "optimizers=('rs', 're', 'ls', 'bananas', 'npenas')\n",
    "root = '~/plotting_data/bbo'\n",
    "results = get_hpo_results(optimizers, search_spaces, root=root)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Now plot everything"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 435,
   "metadata": {},
   "outputs": [],
   "source": [
    "result_folder = 'plots_nov10/'\n",
    "\n",
    "# specify the seed that represents the default config:\n",
    "default_config = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot default and hpo side by side\n",
    "def plot_default_hpo(results, ss_group, optimizers, offset=0.1, scale_type='0-1', one_line=False, label=False, save=None):\n",
    "\n",
    "    if not one_line:\n",
    "        plot_width = .7 * len(ss_group)\n",
    "    else:\n",
    "        plot_width = .42 * len(ss_group)        \n",
    "    fig, ax = plt.subplots(figsize=(plot_width,2))\n",
    "    width = 0\n",
    "    ss_order = []\n",
    "    for search_space in ss_group:\n",
    "        if one_line:\n",
    "            ss_order.append(ss_dict_oneline[search_space])\n",
    "        else:\n",
    "            ss_order.append(ss_dict_lined[search_space])\n",
    "        width += 1\n",
    "        means = []\n",
    "        for optimizer in optimizers:\n",
    "            mean = results[default_config][search_space][optimizer][0]\n",
    "            means.append(mean)\n",
    "\n",
    "            hpo_means = []\n",
    "            for hpo_seed in results.keys():\n",
    "                if optimizer in results[hpo_seed][search_space]:\n",
    "                    hpo_means.append(results[hpo_seed][search_space][optimizer][0])\n",
    "            mean = np.max(hpo_means)\n",
    "            means.append(mean)\n",
    "\n",
    "        #print(search_space, means[::2])\n",
    "        if scale_type == '0-1':\n",
    "            min_acc, max_acc = np.min(means), np.max(means)\n",
    "            means = [(m - min_acc) / (max_acc - min_acc) for m in means]\n",
    "\n",
    "        i = 0\n",
    "        for optimizer in optimizers:\n",
    "            color = color_dict[optimizer]['color']\n",
    "            \n",
    "            # to average nbmr\n",
    "            first, second = i, i+1\n",
    "            if optimizer == 'rs' and 'mr' in search_space:\n",
    "                second = i\n",
    "\n",
    "            if width == 1:\n",
    "                ax.scatter(width-offset, means[first], label=pred_label_dict[optimizer], color=color, marker='o')\n",
    "                ax.scatter(width+offset, means[second], label=pred_label_dict[optimizer]+'+HPO', color=color, marker='x')\n",
    "            else:\n",
    "                ax.scatter(width-offset, means[first], color=color, marker='o')    \n",
    "                ax.scatter(width+offset, means[second], color=color, marker='x')\n",
    "            i += 2\n",
    "\n",
    "    ax.set_xticks(range(1, len(ss_order)+1))\n",
    "    if label:\n",
    "        ax.set_xticklabels(ss_order, fontsize=12, rotation=90)\n",
    "    else:\n",
    "        ax.set_xticklabels(['' for _ in range(len(ss_order))], fontsize=12, rotation=90)\n",
    "\n",
    "    if one_line:\n",
    "        ax.legend(loc=(1.01,-.37))\n",
    "    else:\n",
    "        ax.legend(loc=(1.01,0))\n",
    "    #ax.set_xlabel('NAS Benchmark Task', fontsize=14)    \n",
    "    ax.set_ylabel('Scaled Accuracy', fontsize=12)   \n",
    "    #ax.set_title('Scaled Accuracy of NAS Algorithms', fontsize=14)\n",
    "    ax.set_title('NAS Algorithms', fontsize=14)\n",
    "    \n",
    "    if save:\n",
    "        plt.savefig(result_folder + save, bbox_inches = 'tight', pad_inches = 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 225,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 756x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxAAAACqCAYAAAA9QKlzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAB37ElEQVR4nO3deVzUdf4H8NdnZmAAQQ4PTgFFYBguD0RN09AyL8xsNc2j2q1WzQVzS7I2MzU1K0sts7bWFdG8j9BW19SfrbeYccgNeYDcIPc9n98fw3ecwQEGZZhR38/Hgwd+P9/rzcz4ne/7+7kY5xyEEEIIIYQQoguRoQMghBBCCCGEPDwogSCEEEIIIYTojBIIQgghhBBCiM4ogSCEEEIIIYTojBIIQgghhBBCiM4khg6AEEIIIYQY3pUrV3pKJJLvAfiBHjI/zhQAEhoaGl4bOHBgvrYNKIEghBBCCCGQSCTfOzg4+PTo0aNEJBLROP+PKYVCwQoKCuS5ubnfA5ikbRvKLgkhhBBCCAD49ejRo4ySh8ebSCTiPXr0KIWyJkr7Np0YDyGEEEIIMV4iSh4IoEwi0EqeQAkEIYQQQgghRGeUQBBCCCGEEKMgFosHymQyuaenp++oUaP6FhYWijviuBs2bOg2Z84c19a2aWxsxCuvvNLL09PT18vLS+7n5+eTnJxs2hHnv9+YjBUlEIQQQgghxChIpVJFcnJyYlpa2jUbG5uGTz/9tEdnnfv777+3y83NNUlOTr6WmpqaeOjQofRu3bo1Puhx6+vrOyI8o0IJBCGEEEIIabeoCzfsgj/+xb/3u0cGBn/8i3/UhRt2HXn8IUOGVGZnZ5sCwKlTpyz69esn8/Hxkffv318WGxsrBZRP8ceMGePx5JNPerq5ufnNnTvXRdh//fr13dzd3f38/f19zp07Z9nW+XJyckzs7e3rxWJlpYeHh0d9jx49GgFg//79Xfv16yeTy+U+48aN61NaWioCgLffftvRz8/Px9PT03fGjBluCoUCABAcHOz95z//uZefn5/PypUr7U+fPm3Rv39/mbe3t9zf39+npKREBAC5ubkm2mI3dpRAEEIIIYSQdom6cMNuxeFEt/zyWlMOIL+81nTF4US3jkoiGhoacOrUKavJkyffAYDAwMCay5cvJyclJSV++OGH2YsXL1bdbCcmJlocPHgwMykp6dpPP/1km56ebnLjxg2TNWvWOJ07dy758uXLyampqeZtnXP27NnFv/zyi41MJpO//vrrLmfPnjUHgJycHMmqVascf/3119TExMSkAQMGVK1YscIeAN555538hISEpLS0tGvV1dWinTt3WgvHq6urYwkJCUlLlizJnzlzpseXX355MyUlJfH06dMplpaWipZi74jXT99oHghCCCGEENIuG06kOdc2KDQeRNc2KEQbTqQ5zxriVny/x62trRXJZDJ5Xl6eiYeHR83kyZPLAKC4uFj84osv9r5+/boZY4zX19czYZ/hw4eXCU2N+vbtW5ORkSHNz8+XDBkypNzJyakBAKZMmVKcmppq1tq5PTw86tPT0xOio6OtTpw40XX8+PHekZGRGVVVVaKMjAyz4OBgGQDU19ezgQMHVgDAf/7zH6t169Y51NTUiO7cuSORy+XVAEoBYMaMGcUAEBcXZ9azZ8/6kSNHVgGAnZ2dorXY+/bta/RtnqgGghBCCCGEtEtBea3WzsUtletK6ANx8+bNeM451qxZ0xMAIiIinEeOHFmelpZ2LTo6Or2urk51D2tqaqoaelYsFmskF+1lbm7Op02bVvbtt99mhYeH5+zfv9+Gc47hw4eXJScnJyYnJydmZGRc2717942qqir297//3W3//v0ZqampibNmzSqsqalRxWVlZaVo7VwdHXtnogSCEEIIIYS0Sw8raV17ytvLyspKsWHDhpubNm2yr6+vR1lZmdjFxaUOAL799tvube0/YsSIyosXL1rl5uaKa2tr2YEDB2zb2ufMmTMW169fNwGUIzLFx8ebu7m51T311FOVMTExlgkJCVIAKCsrE8XFxUmrqqpEAODg4NBQWloqio6O1nqOgICAmvz8fJPTp09bAEBJSYnoYe9YTQkEIYQQQghpl7DRntlSiUjjCbtUIlKEjfbM7qhzDBs2rFomk1V/9913dhEREbnLli1z8fHxkTc0NLS5r5ubW31ERMTtIUOG+AQFBcm8vLxqhHXbt2+3XrhwoVPzfXJzcyUTJkzo6+np6SuTyXwlEgnefffdfCcnp4Zvv/32+vTp0/t4eXnJg4KCZPHx8Wbdu3dvnDlzZoGPj49vSEiIV2BgYKW2WMzMzPj27dszwsLCXL29veVPPfWUl5B8PKwY5zThICGEEELI4y42NvZ6YGBgoa7bR124YbfhRJpz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\n",
      "text/plain": [
       "<Figure size 756x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the full results:\n",
    "plot_default_hpo(results, search_spaces, optimizers, scale_type='0-1', one_line=True, label=True) #, save='optimizers_appendix.pdf')\n",
    "\n",
    "# plot a representative subset:\n",
    "ss_group = ['nb101', 'nb201_c10', 'nb201_c100', 'nb201_im', 'darts', 'asr', 'nlp', \\\n",
    "            'mr_3ddet', 'mr_video', 'mr_cls', 'mr_seg', \\\n",
    "            'transmicro_scene', 'transmicro_segment', 'transmacro_scene', 'transmacro_segment']\n",
    "plot_default_hpo(results, ss_group, optimizers, scale_type='0-1', label=False) #, save='optimizers.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 426,
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute the average ranks of the predictors, and the number of wins\n",
    "# we give weight 1 to each search space, including the ones with multiple datasets (nb201, trans, mr)\n",
    "# (correctly weighing each search_space,dataset pair makes the code a bit more complex)\n",
    "\n",
    "def compute_ranks(results, optimizers):\n",
    "    rank_results = []\n",
    "    full_ranks_no_hpo = None\n",
    "    full_ranks_hpo = None\n",
    "    for hpo in [False, True]:\n",
    "        ranks = np.zeros((len(search_spaces), len(optimizers)))\n",
    "        nb201_indices = []\n",
    "        trans_indices = []\n",
    "        mr_indices = []\n",
    "        for i, search_space in enumerate(results[default_config].keys()):\n",
    "            values = []\n",
    "            for optimizer in optimizers:\n",
    "                if not hpo:\n",
    "                    values.append(results[default_config][search_space][optimizer][0])\n",
    "                else:\n",
    "                    means = []\n",
    "                    for hpo_seed in results.keys():\n",
    "                        if optimizer in results[hpo_seed][search_space]:\n",
    "                            means.append(results[hpo_seed][search_space][optimizer][0])\n",
    "                    values.append(np.max(means))\n",
    "            ranks[i] = np.flip(np.array(values).argsort()).argsort()\n",
    "            if 'nb201' in search_space:\n",
    "                nb201_indices.append(i)\n",
    "            elif 'trans' in search_space:\n",
    "                trans_indices.append(i)\n",
    "            elif 'mr' in search_space:\n",
    "                mr_indices.append(i)\n",
    "\n",
    "        # compute num_wins\n",
    "        num_wins = [0 for i in range(len(optimizers))]\n",
    "        for i in range(len(ranks)):\n",
    "            if i in nb201_indices:\n",
    "                num_wins[np.argmin(ranks[i])] += 1/3\n",
    "            elif i in trans_indices:\n",
    "                num_wins[np.argmin(ranks[i])] += 1/14\n",
    "            elif i in mr_indices:\n",
    "                num_wins[np.argmin(ranks[i])] += 1/4\n",
    "            else:\n",
    "                num_wins[np.argmin(ranks[i])] += 1\n",
    "                \n",
    "        # scale by weight\n",
    "        for i in nb201_indices[1:]:\n",
    "            ranks[nb201_indices[0]] += ranks[i]\n",
    "        ranks[nb201_indices[0]] /= 3\n",
    "            \n",
    "        for i in trans_indices[1:]:\n",
    "            ranks[trans_indices[0]] += ranks[i]\n",
    "        ranks[trans_indices[0]] /= 14\n",
    "        \n",
    "        for i in mr_indices[1:]:\n",
    "            ranks[mr_indices[0]] += ranks[i]\n",
    "        ranks[mr_indices[0]] /= 4\n",
    "\n",
    "        indices_to_delete = [*nb201_indices[1:], *trans_indices[1:], *mr_indices[1:]]\n",
    "        indices_to_delete.sort(reverse=True)\n",
    "\n",
    "        for i in indices_to_delete:\n",
    "            ranks = np.delete(ranks, i, axis=0)\n",
    "                \n",
    "        if not hpo:\n",
    "            full_ranks_no_hpo = ranks\n",
    "        else:\n",
    "            full_ranks_hpo = ranks\n",
    "        avg_ranks = np.mean(ranks, axis=0) + 1\n",
    "        rank_results.append(avg_ranks)\n",
    "        rank_results.append(num_wins)\n",
    "\n",
    "    print(\"\\t Avg. rank, default\\t Num. #1's, default\\t Avg. rank, HPO\\t Num. #1's, HPO\")\n",
    "    for i, optimizer in enumerate(optimizers):\n",
    "        if i == 3:\n",
    "            print(optimizer, *[str(np.round(rank_results[j][i], 2))+'\\t\\t\\t' for j in range(len(rank_results))])\n",
    "        else:\n",
    "            print(optimizer, '\\t', *[str(np.round(rank_results[j][i], 2))+'\\t\\t\\t' for j in range(len(rank_results))])\n",
    "\n",
    "    for i, optimizer in enumerate(optimizers):\n",
    "        print(pred_label_dict[optimizer], '&', *[str(np.round(rank_results[j][i], 2))+' &' for j in range(len(rank_results))])\n",
    "    return full_ranks_no_hpo, full_ranks_hpo"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 427,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Avg. rank, default\t Num. #1's, default\t Avg. rank, HPO\t Num. #1's, HPO\n",
      "rs \t 3.47\t\t\t 0.75\t\t\t 3.97\t\t\t 0\t\t\t\n",
      "re \t 2.36\t\t\t 3.39\t\t\t 1.96\t\t\t 3.29\t\t\t\n",
      "ls \t 2.66\t\t\t 1.14\t\t\t 2.41\t\t\t 2.0\t\t\t\n",
      "bananas 3.02\t\t\t 1.36\t\t\t 3.17\t\t\t 1.36\t\t\t\n",
      "npenas \t 3.48\t\t\t 0.36\t\t\t 3.49\t\t\t 0.36\t\t\t\n",
      "Rand. Search & 3.47 & 0.75 & 3.97 & 0 &\n",
      "Reg. Evo. & 2.36 & 3.39 & 1.96 & 3.29 &\n",
      "Local Search & 2.66 & 1.14 & 2.41 & 2.0 &\n",
      "BANANAS & 3.02 & 1.36 & 3.17 & 1.36 &\n",
      "NPENAS & 3.48 & 0.36 & 3.49 & 0.36 &\n"
     ]
    }
   ],
   "source": [
    "full_ranks_no_hpo, full_ranks_hpo = compute_ranks(results, optimizers)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 446,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.29277002188455997 ss_sizes no_hpo rs\n",
      "-0.2646280620124816 ss_sizes hpo rs\n",
      "-0.2057377999494559 ss_sizes no_hpo re\n",
      "-0.2057377999494559 ss_sizes hpo re\n",
      "-0.15018785229652765 ss_sizes no_hpo ls\n",
      "-0.05006261743217588 ss_sizes hpo ls\n",
      "0.47633051162246687 ss_sizes no_hpo bananas\n",
      "0.2057377999494559 ss_sizes hpo bananas\n",
      "0.2646280620124816 ss_sizes no_hpo npenas\n",
      "0.3504383220252312 ss_sizes hpo npenas\n",
      "-0.09759000729485331 nbhd_sizes no_hpo rs\n",
      "-0.15877683720748895 nbhd_sizes hpo rs\n",
      "-0.5143444998736397 nbhd_sizes no_hpo re\n",
      "-0.3086066999241839 nbhd_sizes hpo re\n",
      "0.2503130871608794 nbhd_sizes no_hpo ls\n",
      "0.05006261743217588 nbhd_sizes hpo ls\n",
      "0.3704792868174742 nbhd_sizes no_hpo bananas\n",
      "0.3086066999241839 nbhd_sizes hpo bananas\n",
      "0.15877683720748895 nbhd_sizes no_hpo npenas\n",
      "0.05006261743217588 nbhd_sizes hpo npenas\n",
      "-.29 & -.21 & -.15 & .48 & .26 & \n",
      "-.26 & -.21 & -.05 & .21 & .35 & \n",
      "-.1 & -.51 & .25 & .37 & .16 & \n",
      "-.16 & -.31 & .05 & .31 & .05 & \n"
     ]
    }
   ],
   "source": [
    "# compute correlation between algo performance and {size, RWA}\n",
    "algo_rankings = {\n",
    "    'no_hpo':full_ranks_no_hpo,\n",
    "    'hpo':full_ranks_hpo\n",
    "}\n",
    "# 101, 201, darts, asr, nlp, trans, mr\n",
    "ss_rankings = {\n",
    "    'ss_sizes':[432625, 6466, 1e18, 8242, 1e53, 3676, 1e23],\n",
    "    'nbhd_sizes':[20.114, 24, 120, 21, 42, 15, 45.3],\n",
    "}\n",
    "\n",
    "for key1, ss_rank in ss_rankings.items():\n",
    "    for i, optimizer in enumerate(optimizers):\n",
    "        for key2, alg_rankings in algo_rankings.items():\n",
    "        \n",
    "            alg_rank = [ss[i] for ss in alg_rankings]\n",
    "            value = kendalltau(alg_rank, ss_rank)[0]\n",
    "            # print in readable format:\n",
    "            print(value, key1, key2, optimizer)\n",
    "\n",
    "for key1, ss_rank in ss_rankings.items():\n",
    "    for key2, alg_rankings in algo_rankings.items():\n",
    "        res = []\n",
    "        for i, optimizer in enumerate(optimizers):       \n",
    "            alg_rank = [ss[i] for ss in alg_rankings]\n",
    "            value = kendalltau(alg_rank, ss_rank)[0]\n",
    "            s = str(np.round(value, 2))\n",
    "            if s[0] == '-':\n",
    "                s = '-' + s[2:]\n",
    "            else:\n",
    "                s = s[1:]\n",
    "            res.append(s + ' & ')\n",
    "        \n",
    "        # print in latex format:\n",
    "        print(''.join(res))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 433,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "plot a matrix where entry [i,j] is the regret of a predictor \n",
    "tuned on search space i and evaluated on search space j.\n",
    "\n",
    "Some of the matrix code is different types of scaling so that we can see the trends better.\n",
    "\"\"\"\n",
    "def replace_if_nan(num, replacement=0):\n",
    "    if np.isnan(num) or np.isinf(num):\n",
    "        return replacement\n",
    "    return num\n",
    "\n",
    "def compute_matrix(results, ss_group, optimizers, optimizer):\n",
    "\n",
    "    # first, compute a list of all seeds that have full info\n",
    "    hpo_seeds = []\n",
    "    for hpo_seed in results.keys():\n",
    "        valid = True\n",
    "        for search_space in ss_group:\n",
    "            for opt in optimizers:\n",
    "                if not (search_space in results[hpo_seed] and \\\n",
    "                        opt in results[hpo_seed][search_space]):\n",
    "                    valid = False\n",
    "        if valid:\n",
    "            hpo_seeds.append(hpo_seed)\n",
    "        else:\n",
    "            pass\n",
    "    print('num valid', len(hpo_seeds))\n",
    "\n",
    "    # now compute the raw results and best seed for each search space\n",
    "    best_seeds = []\n",
    "    raw_seed_results = np.zeros((len(ss_group), len(hpo_seeds)))\n",
    "    scaled_seed_results = np.zeros((len(ss_group), len(hpo_seeds)))\n",
    "    normed_seed_results = np.zeros((len(ss_group), len(hpo_seeds)))\n",
    "    for i, search_space in enumerate(ss_group):\n",
    "        raw_seed_results[i] = [results[hpo_seed][search_space][optimizer][0] for hpo_seed in hpo_seeds]\n",
    "        best_seeds.append(np.argmax(raw_seed_results[i]))\n",
    "        # 0-1 scaling:\n",
    "        min_acc, max_acc = np.min(raw_seed_results[i]), np.max(raw_seed_results[i])\n",
    "        scaled_seed_results[i] = [(m - min_acc) / (max_acc - min_acc) for m in raw_seed_results[i]]\n",
    "        for j in range(len(scaled_seed_results[i])):\n",
    "            scaled_seed_results[i][j] = replace_if_nan(scaled_seed_results[i][j], 0)\n",
    "\n",
    "        # normalization:\n",
    "        if optimizer != 'bananas':\n",
    "            mean = np.mean(raw_seed_results[i])\n",
    "            std = np.std(raw_seed_results[i])\n",
    "            normed_seed_results[i] = [(m - mean) / (std) for m in raw_seed_results[i]]\n",
    "        else:\n",
    "            # todo: fix NaN errors when bananas is normalized\n",
    "            normed_seed_results[i] = copy.deepcopy(raw_seed_results[i])\n",
    "\n",
    "    # compute the matrices\n",
    "    div_matrix = np.zeros((len(ss_group), len(ss_group)))\n",
    "    kt_matrix = np.zeros((len(ss_group), len(ss_group)))\n",
    "    scaled_matrix = np.zeros((len(ss_group), len(ss_group)))\n",
    "    normed_matrix = np.zeros((len(ss_group), len(ss_group)))\n",
    "\n",
    "    for i, ss_1 in enumerate(ss_group):\n",
    "        for j, ss_2 in enumerate(ss_group):\n",
    "            div_matrix[i][j] = scaled_seed_results[i][best_seeds[j]] / scaled_seed_results[i][best_seeds[i]]\n",
    "            scaled_matrix[i][j] = scaled_seed_results[i][best_seeds[i]] - scaled_seed_results[i][best_seeds[j]]\n",
    "            normed_matrix[i][j] = normed_seed_results[i][best_seeds[i]] - normed_seed_results[i][best_seeds[j]]\n",
    "            kt_matrix[i][j] = replace_if_nan(kendalltau(scaled_seed_results[i], scaled_seed_results[j])[0], 0)\n",
    "\n",
    "    return div_matrix, scaled_matrix, normed_matrix, kt_matrix, normed_seed_results\n",
    "\n",
    "def scale_matrix(matrix, mean_div=2.5):\n",
    "    # further scaling of the results\n",
    "    # needs to happen in its own method so that an avg_matrix is input\n",
    "    scaled_matrix = np.zeros((len(matrix), len(matrix)))\n",
    "    maximum = np.max(matrix)\n",
    "    mean = np.mean(matrix)\n",
    "    for i in range(len(matrix)):\n",
    "        for j in range(len(matrix)):\n",
    "            if mean_div > 0:\n",
    "                scaled_matrix[i][j] = np.minimum(matrix[i][j], mean * mean_div)\n",
    "            else:\n",
    "                scaled_matrix[i][j] = np.maximum(matrix[i][j], mean / mean_div * -1)\n",
    "\n",
    "    # 0-1 scale\n",
    "    min_acc, max_acc = np.min(scaled_matrix), np.max(scaled_matrix)\n",
    "    for i in range(len(scaled_matrix)):\n",
    "        for j in range(len(scaled_matrix)):\n",
    "            scaled_matrix[i][j] = (scaled_matrix[i][j] - min_acc) / (max_acc - min_acc) \n",
    "\n",
    "    return scaled_matrix\n",
    "\n",
    "def plot_matrix(matrix, ss_group, save=None, cmap='viridis', hparam=False):\n",
    "    coords = matrix\n",
    "    cellsize = 5\n",
    "    fig, ax = plt.subplots(1,1,figsize=(cellsize*1.2, cellsize*coords.shape[0]/coords.shape[1]))\n",
    "    im = ax.pcolormesh(coords, edgecolor='k', linewidth=0.5, cmap=cmap) \n",
    "    if hparam:\n",
    "        plt.title('HParam. Corr. for Black-Box Algorithms')\n",
    "    else:\n",
    "        plt.title('Generalizability for Black-Box Algorithms')\n",
    "    plt.gca().invert_yaxis()\n",
    "    ax.set_xticks([])\n",
    "    ax.set_xticklabels('')\n",
    "    ax.set_xticks([c+0.5 for c in range(coords.shape[0]-0)], minor=True)\n",
    "    ax.set_xticklabels([ss_dict_mat[ss] for ss in ss_group], minor=True, rotation=90)\n",
    "    ax.set_yticks([])\n",
    "    ax.set_yticklabels('')    \n",
    "    ax.set_yticks([c+0.5 for c in range(coords.shape[1]-0)], minor=True)\n",
    "    ax.set_yticklabels([ss_dict_mat[ss] for ss in ss_group], minor=True)\n",
    "    fig.colorbar(im, ax=ax)\n",
    "    \n",
    "    if save:\n",
    "        plt.savefig(result_folder + save, bbox_inches = 'tight', pad_inches = 0.1)\n",
    "        \n",
    "    return matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 436,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num valid 100\n",
      "num valid 100\n",
      "num valid 100\n",
      "num valid 100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ubuntu/anaconda3/envs/mvenv/lib/python3.7/site-packages/ipykernel_launcher.py:37: RuntimeWarning: invalid value encountered in double_scalars\n",
      "/home/ubuntu/anaconda3/envs/mvenv/lib/python3.7/site-packages/ipykernel_launcher.py:57: RuntimeWarning: invalid value encountered in double_scalars\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "norm_matrices = []\n",
    "kt_matrices = []\n",
    "for i, optimizer in enumerate(('re', 'ls', 'npenas', 'bananas')):\n",
    "    _, _, norm, kt_mat, _ = compute_matrix(results, search_spaces, optimizers, optimizer=optimizer)\n",
    "    norm_matrices.append(norm)\n",
    "    kt_matrices.append(kt_mat)\n",
    "\n",
    "avg_norm_matrix = np.mean(np.array(norm_matrices), axis=0)\n",
    "avg_kt_matrix = np.mean(np.array(kt_matrices), axis=0)\n",
    "\n",
    "scaled_matrix = scale_matrix(avg_norm_matrix, mean_div=2.5)\n",
    "scaled_kt_matrix = scale_matrix(avg_kt_matrix, mean_div=-1000000)\n",
    "\n",
    "avg_scaled_matrix = plot_matrix(scaled_matrix, search_spaces, cmap='viridis') #, save='bbo_matrix_avg.pdf')\n",
    "_ = plot_matrix(scaled_kt_matrix, search_spaces, cmap='viridis_r', hparam=True) #, save='bbo_corr_matrix.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 350,
   "metadata": {},
   "outputs": [],
   "source": [
    "def shorten_matrix(matrix):\n",
    "    # this has hard-coded indices for groups of search_spaces\n",
    "    if len(matrix) != 25:\n",
    "        print('invalid matrix')\n",
    "        return\n",
    "\n",
    "    # compute a smaller matrix based on just ss_groups\n",
    "    ss_idx_groups = [[0], [1,2,3], [4], [5], [6], [7,8,9,10], [i for i in range(11,25)]]\n",
    "    ss_matrix = np.zeros((len(ss_idx_groups), len(ss_idx_groups)))\n",
    "    for i, ss_1 in enumerate(ss_idx_groups):\n",
    "        for j, ss_2 in enumerate(ss_idx_groups):\n",
    "            ss_matrix[i][j] = np.mean(matrix[ss_1, :][:, ss_2])\n",
    "\n",
    "    if False:\n",
    "        # debug by looking at the matrix\n",
    "        coords = ss_matrix\n",
    "        cellsize = 5\n",
    "        fig, ax = plt.subplots(1,1,figsize=(cellsize*1.2, cellsize*coords.shape[0]/coords.shape[1]))\n",
    "        im = ax.pcolormesh(coords, edgecolor='k', linewidth=0.5) \n",
    "        plt.title('Generalizability for Predictors')\n",
    "        plt.gca().invert_yaxis()\n",
    "        fig.colorbar(im, ax=ax)\n",
    "    return ss_matrix\n",
    "\n",
    "def summarize_matrix(matrix):\n",
    "    # compute the average transfer score\n",
    "    to_avgs = []\n",
    "    from_avgs = []\n",
    "    adjustment = len(matrix) / (len(matrix) - 1)\n",
    "    for i in range(len(matrix)):\n",
    "        to_avgs.append(np.mean(matrix[i,:]) * adjustment)\n",
    "        from_avgs.append(np.mean(matrix[:,i]) * adjustment)\n",
    "    mean_avgs = np.mean([to_avgs, from_avgs], axis=0)\n",
    "    to_avgs = np.round(to_avgs, 3)\n",
    "    from_avgs = np.round(from_avgs, 3)\n",
    "    mean_avgs = np.round(mean_avgs, 3)\n",
    "    print(*[str(t) + ' &' for t in to_avgs])\n",
    "    print(*[str(t) + ' &' for t in from_avgs])\n",
    "    print(mean_avgs)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 444,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "summary of matrix (just 0-1 scaling)\n",
      ".0 & .25 & .25 & .0 & .25 & .75 & .27 &\n",
      ".25 & .22 & .33 & .75 & .5 & .83 & .28 &\n",
      ".25 & .33 & .0 & .75 & .5 & .5 & .23 &\n",
      ".75 & .5 & .5 & .0 & .75 & .25 & .5 &\n",
      ".07 & .28 & .28 & .73 & .0 & .64 & .28 &\n",
      ".86 & .8 & .7 & .42 & .84 & .32 & .76 &\n",
      ".27 & .28 & .23 & .73 & .48 & .7 & .28 &\n",
      "\n",
      "0.461 & 0.528 & 0.428 & 0.542 & 0.381 & 0.784 & 0.495 &\n",
      "0.407 & 0.444 & 0.383 & 0.731 & 0.555 & 0.666 & 0.433 &\n",
      "[0.434 0.486 0.405 0.636 0.468 0.725 0.464]\n"
     ]
    }
   ],
   "source": [
    "shortened_matrix = shorten_matrix(avg_matrix)\n",
    "print('summary of matrix (just 0-1 scaling)')\n",
    "rounded = np.round(shortened_matrix, 2)\n",
    "\n",
    "for row in rounded:\n",
    "    print(*[str(i)[1:] + ' &' for i in row])\n",
    "print()\n",
    "\n",
    "summarize_matrix(shortened_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {},
   "outputs": [],
   "source": [
    "# this is used to compare the best predictors on nb101 and nb201 vs best on every other search space\n",
    "def compute_subsets(results, optimizers, ss_group, ss_indices_1, ss_indices_2):\n",
    "    rank_results = []\n",
    "    print(optimizers)\n",
    "    for hpo in [False, True]:\n",
    "        ranks = np.zeros((len(search_spaces), len(optimizers)))\n",
    "        nb201_indices = []\n",
    "        trans_indices = []\n",
    "        mr_indices = []\n",
    "        for i, search_space in enumerate(ss_group):\n",
    "            values = []\n",
    "            for optimizer in optimizers:\n",
    "                if not hpo:\n",
    "                    values.append(results[default_config][search_space][optimizer][0])\n",
    "                else:\n",
    "                    means = []\n",
    "                    for hpo_seed in results.keys():\n",
    "                        if optimizer in results[hpo_seed][search_space]:\n",
    "                            means.append(results[hpo_seed][search_space][optimizer][0])\n",
    "                    values.append(np.max(means))\n",
    "            ranks[i] = np.flip(np.array(values).argsort()).argsort()\n",
    "            if 'nb201' in search_space:\n",
    "                nb201_indices.append(i)\n",
    "            elif 'trans' in search_space:\n",
    "                trans_indices.append(i)\n",
    "            elif 'mr' in search_space:\n",
    "                mr_indices.append(i)\n",
    "                \n",
    "        # scale by weight\n",
    "        for i in nb201_indices[1:]:\n",
    "            ranks[nb201_indices[0]] += ranks[i]\n",
    "        ranks[nb201_indices[0]] /= 3\n",
    "            \n",
    "        for i in trans_indices[1:]:\n",
    "            ranks[trans_indices[0]] += ranks[i]\n",
    "        ranks[trans_indices[0]] /= 14\n",
    "        \n",
    "        for i in mr_indices[1:]:\n",
    "            ranks[mr_indices[0]] += ranks[i]\n",
    "        ranks[mr_indices[0]] /= 4\n",
    "\n",
    "        indices_to_delete = [*nb201_indices[1:], *trans_indices[1:], *mr_indices[1:]]\n",
    "        indices_to_delete.sort(reverse=True)\n",
    "\n",
    "        for i in indices_to_delete:\n",
    "            ranks = np.delete(ranks, i, axis=0)\n",
    "               \n",
    "        ranks_1, ranks_2 = [], []\n",
    "        for i in range(len(ranks)):\n",
    "            if i in ss_indices_1:\n",
    "                ranks_1.append(ranks[i])\n",
    "            elif i in ss_indices_2:\n",
    "                ranks_2.append(ranks[i])\n",
    "                \n",
    "        avg_ranks = np.mean(ranks, axis=0) + 1\n",
    "        avg_ranks_1 = np.mean(ranks_1, axis=0) + 1\n",
    "        avg_ranks_2 = np.mean(ranks_2, axis=0) + 1\n",
    "        \n",
    "        avg_ranks_1 = [np.round(a, 2) for a in avg_ranks_1]\n",
    "        avg_ranks_2 = [np.round(a, 2) for a in avg_ranks_2]\n",
    "        avg_ranks = [np.round(a, 2) for a in avg_ranks]\n",
    "\n",
    "        print('a:', *[str(a)+' &' for a in avg_ranks])\n",
    "        print('1:', *[str(a)+' &' for a in avg_ranks_1])\n",
    "        print('2:', *[str(a)+' &' for a in avg_ranks_2])\n",
    "        \n",
    "        rank_results.append(avg_ranks)\n",
    "\n",
    "    print(rank_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('rs', 're', 'ls', 'bananas', 'npenas')\n",
      "a: 3.47 & 2.36 & 2.66 & 3.02 & 3.48 &\n",
      "1: 4.5 & 3.0 & 1.5 & 3.5 & 2.5 &\n",
      "2: 3.06 & 2.11 & 3.13 & 2.83 & 3.87 &\n",
      "a: 3.97 & 1.96 & 2.41 & 3.17 & 3.49 &\n",
      "1: 5.0 & 1.5 & 1.5 & 4.0 & 3.0 &\n",
      "2: 3.56 & 2.14 & 2.77 & 2.84 & 3.69 &\n",
      "[[3.47, 2.36, 2.66, 3.02, 3.48], [3.97, 1.96, 2.41, 3.17, 3.49]]\n"
     ]
    }
   ],
   "source": [
    "full_ss = ['nb101', \n",
    "           'nb201_c10', 'nb201_c100', 'nb201_im',\n",
    "           'darts', \n",
    "           'asr', \n",
    "           'nlp',\n",
    "           'mr_cls', 'mr_3ddet', 'mr_seg', 'mr_video',\n",
    "           'transmicro_obj', 'transmicro_scene', 'transmicro_jigsaw', \n",
    "           'transmicro_room', 'transmicro_segment', 'transmicro_normal', \n",
    "           'transmicro_auto', 'transmacro_obj', 'transmacro_scene', 'transmacro_jigsaw', \n",
    "           'transmacro_room', 'transmacro_segment', 'transmacro_normal', \n",
    "           'transmacro_auto']\n",
    "\n",
    "ss_indices_1 = [0, 1]\n",
    "ss_indices_2 = [2, 3, 4, 5, 6]\n",
    "\n",
    "compute_subsets(results, optimizers, full_ss, ss_indices_1, ss_indices_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
