{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {},
      "outputs": [],
      "source": [
        "states = [\"DE\", \"IA\", \"IL\", \"MA\", \"MD\", \"MN\", \"MT\", \"NV\"]\n",
        "revised_integrals_values = \\\n",
        "[[87.61, 87.78, 88.17, 87.99, 87.79, 87.6, 87.6, 87.9], \n",
        "[85.72, 84.84, 86.04 , 85.85, 85.41, 85.61, 85.67, 86.82],\n",
        "[87.51, 86.87, 86.95 , 87.32, 87.24, 86.82, 87.09, 87.09],\n",
        "[82.69, 82.08, 82.48 , 81.8, 81.26, 81.48, 81.75, 82.06],\n",
        "[87.84, 87.62, 88.09 , 88.17, 87.51, 87.57, 87.78, 87.78],\n",
        "[86.8,  86.79, 87.25 , 86.7, 87.2, 83.76, 87.05, 86.9],\n",
        "[87.56, 87.63, 87.25 , 87.47, 87.54, 87.35, 87.48, 87.67],\n",
        "[92.57, 87.25, 87.73 , 92.79, 92.76, 92.14, 91.82, 91.62]]\n",
        "\n",
        "revised_integrals = {}\n",
        "for i in range(len(states)):\n",
        "    revised_integrals[states[i]] = {state: revised_integrals_values[i][j] for j, state in enumerate(states)}\n",
        "\n",
        "# Minimize Error rather than Maximize Accuracy\n",
        "for key in revised_integrals:\n",
        "\tfor task in revised_integrals[key]:\n",
        "\t\trevised_integrals[key][task] = 100.0 - revised_integrals[key][task]"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "dlChfA6SZi01"
      },
      "source": [
        "### Network Selection Algorithm"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "DhdVOK1lNqzC"
      },
      "outputs": [],
      "source": [
        "import math \n",
        "import numpy as np\n",
        "\n",
        "def gen_task_combinations(tasks, rtn, index, path, path_dict):\n",
        "  if index >= len(tasks):\n",
        "    return \n",
        "\n",
        "  for i in range(index, len(tasks)):\n",
        "    cur_task = tasks[i]\n",
        "    new_path = path\n",
        "    new_dict = {k:v for k,v in path_dict.items()}\n",
        "    \n",
        "    # Building from a tree with two or more tasks...\n",
        "    if new_path:\n",
        "      new_dict[cur_task] = 0.\n",
        "      for prev_task in path_dict:\n",
        "        new_dict[prev_task] += revised_integrals[prev_task][cur_task]\n",
        "        new_dict[cur_task] += revised_integrals[cur_task][prev_task]\n",
        "      new_path = '{}|{}'.format(new_path, cur_task)\n",
        "      rtn[new_path] = new_dict\n",
        "    else: # First element in a new-formed tree\n",
        "      new_dict[cur_task] = 0.\n",
        "      new_path = cur_task\n",
        "\n",
        "    gen_task_combinations(tasks, rtn, i+1, new_path, new_dict)\n",
        "\n",
        "    # Fix single-task accuracy since dfs is finished for this task.\n",
        "    if '|' not in new_path:\n",
        "      new_dict[cur_task] = revised_integrals[cur_task][cur_task]\n",
        "      rtn[new_path] = new_dict"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "id": "NuRJiEmxWKMZ"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL': {'DE': 12.024999999999999, 'IA': 14.119999999999997, 'IL': 12.809999999999995}, 'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|IA|IL|MA|MD': {'DE': 12.067499999999999, 'IA': 14.245000000000001, 'IL': 12.765, 'MA': 17.8725, 'MD': 12.069999999999997}, 'DE|IA|IL|MA|MD|MN': {'DE': 12.134, 'IA': 14.274000000000001, 'IL': 12.848000000000003, 'MA': 18.002, 'MD': 12.142, 'MN': 13.051999999999998}, 'DE|IA|IL|MA|MD|MN|MT': {'DE': 12.178333333333335, 'IA': 14.283333333333333, 'IL': 12.858333333333334, 'MA': 18.043333333333333, 'MD': 12.155, 'MN': 13.034999999999998, 'MT': 12.533333333333333}, 'DE|IA|IL|MA|MD|MN|MT|NV': {'DE': 12.167142857142858, 'IA': 14.125714285714286, 'IL': 12.865714285714287, 'MA': 18.02857142857143, 'MD': 12.164285714285713, 'MN': 13.044285714285712, 'MT': 12.504285714285714, 'NV': 8.991428571428571}, 'DE|IA|IL|MA|MD|MN|NV': {'DE': 12.128333333333332, 'IA': 14.091666666666669, 'IL': 12.858333333333334, 'MA': 17.991666666666664, 'MD': 12.155, 'MN': 13.059999999999997, 'NV': 9.126666666666665}, 'DE|IA|IL|MA|MD|MT': {'DE': 12.134, 'IA': 14.262, 'IL': 12.794, 'MA': 17.948, 'MD': 12.099999999999998, 'MT': 12.51}, 'DE|IA|IL|MA|MD|MT|NV': {'DE': 12.128333333333332, 'IA': 14.081666666666669, 'IL': 12.813333333333333, 'MA': 17.946666666666665, 'MD': 12.119999999999997, 'MT': 12.479999999999999, 'NV': 9.18}, 'DE|IA|IL|MA|MD|NV': {'DE': 12.073999999999998, 'IA': 14.032000000000002, 'IL': 12.794, 'MA': 17.886, 'MD': 12.099999999999998, 'NV': 9.379999999999999}, 'DE|IA|IL|MA|MN': {'DE': 12.115000000000002, 'IA': 14.195, 'IL': 12.870000000000001, 'MA': 17.8175, 'MN': 13.114999999999998}, 'DE|IA|IL|MA|MN|MT': {'DE': 12.172000000000002, 'IA': 14.222, 'IL': 12.878, 'MA': 17.904, 'MN': 13.081999999999999, 'MT': 12.548000000000002}, 'DE|IA|IL|MA|MN|MT|NV': {'DE': 12.160000000000002, 'IA': 14.048333333333334, 'IL': 12.883333333333333, 'MA': 17.91, 'MN': 13.084999999999999, 'MT': 12.511666666666668, 'NV': 9.283333333333333}, 'DE|IA|IL|MA|MN|NV': {'DE': 12.112, 'IA': 13.992, 'IL': 12.878, 'MA': 17.842, 'MN': 13.111999999999998, 'NV': 9.504}, 'DE|IA|IL|MA|MT': {'DE': 12.115000000000002, 'IA': 14.18, 'IL': 12.802499999999998, 'MA': 17.75, 'MT': 12.5225}, 'DE|IA|IL|MA|MT|NV': {'DE': 12.112, 'IA': 13.98, 'IL': 12.823999999999998, 'MA': 17.788, 'MT': 12.484, 'NV': 9.568000000000001}, 'DE|IA|IL|MA|NV': {'DE': 12.04, 'IA': 13.892500000000002, 'IL': 12.802499999999998, 'MA': 17.6725, 'NV': 9.915}, 'DE|IA|IL|MD': {'DE': 12.086666666666664, 'IA': 14.276666666666666, 'IL': 12.793333333333331, 'MD': 12.149999999999997}, 'DE|IA|IL|MD|MN': {'DE': 12.165, 'IA': 14.305, 'IL': 12.89, 'MD': 12.219999999999999, 'MN': 12.989999999999998}, 'DE|IA|IL|MD|MN|MT': {'DE': 12.212, 'IA': 14.309999999999999, 'IL': 12.894, 'MD': 12.219999999999999, 'MN': 12.982, 'MT': 12.534}, 'DE|IA|IL|MD|MN|MT|NV': {'DE': 12.193333333333333, 'IA': 14.121666666666668, 'IL': 12.896666666666667, 'MD': 12.219999999999999, 'MN': 13.001666666666665, 'MT': 12.5, 'NV': 9.288333333333334}, 'DE|IA|IL|MD|MN|NV': {'DE': 12.151999999999997, 'IA': 14.080000000000002, 'IL': 12.894, 'MD': 12.219999999999999, 'MN': 13.011999999999997, 'NV': 9.51}, 'DE|IA|IL|MD|MT': {'DE': 12.165, 'IA': 14.29, 'IL': 12.822499999999998, 'MD': 12.167499999999997, 'MT': 12.504999999999999}, 'DE|IA|IL|MD|MT|NV': {'DE': 12.151999999999997, 'IA': 14.068000000000001, 'IL': 12.839999999999998, 'MD': 12.177999999999997, 'MT': 12.469999999999999, 'NV': 9.574000000000002}, 'DE|IA|IL|MD|NV': {'DE': 12.089999999999996, 'IA': 14.002500000000001, 'IL': 12.822499999999998, 'MD': 12.167499999999997, 'NV': 9.9225}, 'DE|IA|IL|MN': {'DE': 12.15, 'IA': 14.209999999999999, 'IL': 12.933333333333332, 'MN': 13.053333333333333}, 'DE|IA|IL|MN|MT': {'DE': 12.212500000000002, 'IA': 14.239999999999998, 'IL': 12.927499999999998, 'MN': 13.0275, 'MT': 12.552500000000002}, 'DE|IA|IL|MN|MT|NV': {'DE': 12.190000000000001, 'IA': 14.028, 'IL': 12.923999999999998, 'MN': 13.041999999999998, 'MT': 12.508000000000001, 'NV': 9.698000000000002}, 'DE|IA|IL|MN|NV': {'DE': 12.1375, 'IA': 13.9525, 'IL': 12.927499999999998, 'MN': 13.064999999999998, 'NV': 10.0775}, 'DE|IA|IL|MT': {'DE': 12.15, 'IA': 14.189999999999998, 'IL': 12.843333333333328, 'MT': 12.520000000000001}, 'DE|IA|IL|MT|NV': {'DE': 12.1375, 'IA': 13.9375, 'IL': 12.859999999999996, 'MT': 12.4725, 'NV': 10.157500000000002}, 'DE|IA|IL|NV': {'DE': 12.049999999999997, 'IA': 13.806666666666667, 'IL': 12.843333333333328, 'NV': 10.816666666666668}, 'DE|IA|MA': {'DE': 12.115000000000002, 'IA': 14.215000000000003, 'MA': 17.615000000000002}, 'DE|IA|MA|MD': {'DE': 12.146666666666667, 'IA': 14.340000000000003, 'MA': 17.99, 'MD': 12.12333333333333}, 'DE|IA|MA|MD|MN': {'DE': 12.21, 'IA': 14.352500000000003, 'MA': 18.1225, 'MD': 12.2, 'MN': 13.127499999999998}, 'DE|IA|MA|MD|MN|MT': {'DE': 12.248000000000001, 'IA': 14.348000000000003, 'MA': 18.148, 'MD': 12.203999999999999, 'MN': 13.091999999999999, 'MT': 12.49}, 'DE|IA|MA|MD|MN|MT|NV': {'DE': 12.223333333333334, 'IA': 14.153333333333336, 'MA': 18.113333333333333, 'MD': 12.206666666666665, 'MN': 13.093333333333332, 'MT': 12.463333333333333, 'NV': 8.445}, 'DE|IA|MA|MD|MN|NV': {'DE': 12.187999999999999, 'IA': 14.118000000000004, 'MA': 18.086, 'MD': 12.203999999999999, 'MN': 13.121999999999996, 'NV': 8.498}, 'DE|IA|MA|MD|MT': {'DE': 12.21, 'IA': 14.337500000000002, 'MA': 18.055, 'MD': 12.147499999999997, 'MT': 12.45}, 'DE|IA|MA|MD|MT|NV': {'DE': 12.187999999999999, 'IA': 14.106000000000003, 'MA': 18.032, 'MD': 12.161999999999997, 'MT': 12.425999999999998, 'NV': 8.562000000000001}, 'DE|IA|MA|MD|NV': {'DE': 12.134999999999998, 'IA': 14.050000000000004, 'MA': 17.9775, 'MD': 12.147499999999997, 'NV': 8.657499999999999}, 'DE|IA|MA|MN': {'DE': 12.210000000000003, 'IA': 14.273333333333335, 'MA': 17.916666666666668, 'MN': 13.236666666666665}, 'DE|IA|MA|MN|MT': {'DE': 12.257500000000004, 'IA': 14.287500000000001, 'MA': 18.0, 'MN': 13.165, 'MT': 12.497500000000002}, 'DE|IA|MA|MN|MT|NV': {'DE': 12.226000000000003, 'IA': 14.066000000000003, 'MA': 17.988, 'MN': 13.151999999999997, 'MT': 12.464000000000002, 'NV': 8.686000000000002}, 'DE|IA|MA|MN|NV': {'DE': 12.182500000000001, 'IA': 14.000000000000004, 'MA': 17.9225, 'MN': 13.202499999999997, 'NV': 8.8125}, 'DE|IA|MA|MT': {'DE': 12.210000000000003, 'IA': 14.253333333333336, 'MA': 17.826666666666668, 'MT': 12.446666666666667}, 'DE|IA|MA|MT|NV': {'DE': 12.182500000000001, 'IA': 13.985000000000003, 'MA': 17.855, 'MT': 12.4175, 'NV': 8.892500000000002}, 'DE|IA|MA|NV': {'DE': 12.11, 'IA': 13.870000000000005, 'MA': 17.723333333333333, 'NV': 9.13}, 'DE|IA|MD': {'DE': 12.214999999999996, 'IA': 14.435000000000002, 'MD': 12.269999999999996}, 'DE|IA|MD|MN': {'DE': 12.276666666666666, 'IA': 14.420000000000002, 'MD': 12.323333333333332, 'MN': 13.069999999999999}, 'DE|IA|MD|MN|MT': {'DE': 12.307500000000001, 'IA': 14.3975, 'MD': 12.2975, 'MN': 13.04, 'MT': 12.48}, 'DE|IA|MD|MN|MT|NV': {'DE': 12.266, 'IA': 14.154000000000002, 'MD': 12.282, 'MN': 13.051999999999998, 'MT': 12.45, 'NV': 8.692000000000002}, 'DE|IA|MD|MN|NV': {'DE': 12.232499999999998, 'IA': 14.110000000000003, 'MD': 12.2975, 'MN': 13.077499999999997, 'NV': 8.82}, 'DE|IA|MD|MT': {'DE': 12.276666666666666, 'IA': 14.4, 'MD': 12.25333333333333, 'MT': 12.423333333333332}, 'DE|IA|MD|MT|NV': {'DE': 12.232499999999998, 'IA': 14.095000000000002, 'MD': 12.244999999999997, 'MT': 12.399999999999999, 'NV': 8.900000000000002}, 'DE|IA|MD|NV': {'DE': 12.176666666666662, 'IA': 14.016666666666671, 'MD': 12.25333333333333, 'NV': 9.14}, 'DE|IA|MN': {'DE': 12.310000000000002, 'IA': 14.335, 'MN': 13.204999999999998}, 'DE|IA|MN|MT': {'DE': 12.340000000000003, 'IA': 14.333333333333334, 'MN': 13.12, 'MT': 12.48666666666667}, 'DE|IA|MN|MT|NV': {'DE': 12.280000000000001, 'IA': 14.045000000000002, 'MN': 13.114999999999998, 'MT': 12.447500000000002, 'NV': 9.055000000000003}, 'DE|IA|MN|NV': {'DE': 12.24, 'IA': 13.950000000000003, 'MN': 13.169999999999996, 'NV': 9.34666666666667}, 'DE|IA|MT': {'DE': 12.310000000000002, 'IA': 14.305, 'MT': 12.405000000000001}, 'DE|IA|MT|NV': {'DE': 12.24, 'IA': 13.930000000000001, 'MT': 12.38, 'NV': 9.453333333333338}, 'DE|IA|NV': {'DE': 12.159999999999997, 'IA': 13.730000000000004, 'NV': 10.090000000000003}, 'DE|IL': {'DE': 11.829999999999998, 'IL': 12.489999999999995}, 'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415}, 'DE|IL|MA|MD': {'DE': 12.016666666666666, 'IL': 12.643333333333336, 'MA': 17.856666666666666, 'MD': 11.966666666666663}, 'DE|IL|MA|MD|MN': {'DE': 12.1125, 'IL': 12.777500000000003, 'MA': 18.022499999999997, 'MD': 12.0825, 'MN': 13.0125}, 'DE|IL|MA|MD|MN|MT': {'DE': 12.170000000000002, 'IL': 12.804000000000002, 'MA': 18.067999999999998, 'MD': 12.11, 'MN': 13.0, 'MT': 12.565999999999999}, 'DE|IL|MA|MD|MN|MT|NV': {'DE': 12.158333333333333, 'IL': 12.821666666666667, 'MA': 18.046666666666663, 'MD': 12.128333333333332, 'MN': 13.016666666666666, 'MT': 12.526666666666666, 'NV': 8.365}, 'DE|IL|MA|MD|MN|NV': {'DE': 12.11, 'IL': 12.804000000000002, 'MA': 18.005999999999997, 'MD': 12.11, 'MN': 13.029999999999998, 'NV': 8.401999999999997}, 'DE|IL|MA|MD|MT': {'DE': 12.1125, 'IL': 12.71, 'MA': 17.955, 'MD': 12.029999999999998, 'MT': 12.544999999999998}, 'DE|IL|MA|MD|MT|NV': {'DE': 12.11, 'IL': 12.75, 'MA': 17.951999999999998, 'MD': 12.067999999999998, 'MT': 12.501999999999999, 'NV': 8.466}, 'DE|IL|MA|MD|NV': {'DE': 12.037499999999998, 'IL': 12.71, 'MA': 17.877499999999998, 'MD': 12.029999999999998, 'NV': 8.537499999999998}, 'DE|IL|MA|MN': {'DE': 12.080000000000004, 'IL': 12.783333333333337, 'MA': 17.78333333333333, 'MN': 13.083333333333334}, 'DE|IL|MA|MN|MT': {'DE': 12.160000000000004, 'IL': 12.815000000000001, 'MA': 17.9, 'MN': 13.05, 'MT': 12.592500000000001}, 'DE|IL|MA|MN|MT|NV': {'DE': 12.148000000000001, 'IL': 12.834, 'MA': 17.907999999999998, 'MN': 13.059999999999999, 'MT': 12.540000000000001, 'NV': 8.59}, 'DE|IL|MA|MN|NV': {'DE': 12.085, 'IL': 12.815000000000001, 'MA': 17.822499999999998, 'MN': 13.087499999999999, 'NV': 8.692499999999999}, 'DE|IL|MA|MT': {'DE': 12.080000000000004, 'IL': 12.693333333333333, 'MA': 17.69333333333333, 'MT': 12.573333333333332}, 'DE|IL|MA|MT|NV': {'DE': 12.085, 'IL': 12.747499999999999, 'MA': 17.755, 'MT': 12.5125, 'NV': 8.7725}, 'DE|IL|MA|NV': {'DE': 11.979999999999999, 'IL': 12.693333333333333, 'MA': 17.59, 'NV': 8.969999999999999}, 'DE|IL|MD': {'DE': 12.019999999999996, 'IL': 12.625, 'MD': 12.034999999999997}, 'DE|IL|MD|MN': {'DE': 12.146666666666667, 'IL': 12.810000000000002, 'MD': 12.166666666666666, 'MN': 12.916666666666666}, 'DE|IL|MD|MN|MT': {'DE': 12.21, 'IL': 12.835, 'MD': 12.18, 'MN': 12.925, 'MT': 12.575}, 'DE|IL|MD|MN|MT|NV': {'DE': 12.187999999999999, 'IL': 12.85, 'MD': 12.187999999999999, 'MN': 12.959999999999999, 'MT': 12.526, 'NV': 8.596}, 'DE|IL|MD|MN|NV': {'DE': 12.134999999999998, 'IL': 12.835, 'MD': 12.18, 'MN': 12.962499999999999, 'NV': 8.7}, 'DE|IL|MD|MT': {'DE': 12.146666666666667, 'IL': 12.719999999999999, 'MD': 12.096666666666664, 'MT': 12.549999999999997}, 'DE|IL|MD|MT|NV': {'DE': 12.134999999999998, 'IL': 12.767499999999998, 'MD': 12.127499999999998, 'MT': 12.494999999999997, 'NV': 8.780000000000001}, 'DE|IL|MD|NV': {'DE': 12.046666666666662, 'IL': 12.719999999999999, 'MD': 12.096666666666664, 'NV': 8.979999999999999}, 'DE|IL|MN': {'DE': 12.115000000000002, 'IL': 12.835, 'MN': 12.975000000000001}, 'DE|IL|MN|MT': {'DE': 12.210000000000003, 'IL': 12.86, 'MN': 12.966666666666669, 'MT': 12.613333333333335}, 'DE|IL|MN|MT|NV': {'DE': 12.182500000000001, 'IL': 12.872499999999999, 'MN': 13.0, 'MT': 12.5425, 'NV': 8.935000000000002}, 'DE|IL|MN|NV': {'DE': 12.11, 'IL': 12.86, 'MN': 13.016666666666666, 'NV': 9.186666666666667}, 'DE|IL|MT': {'DE': 12.115000000000002, 'IL': 12.699999999999996, 'MT': 12.594999999999999}, 'DE|IL|MT|NV': {'DE': 12.11, 'IL': 12.769999999999996, 'MT': 12.506666666666666, 'NV': 9.293333333333337}, 'DE|IL|NV': {'DE': 11.964999999999996, 'IL': 12.699999999999996, 'NV': 9.850000000000001}, 'DE|MA': {'DE': 12.010000000000005, 'MA': 17.310000000000002}, 'DE|MA|MD': {'DE': 12.11, 'MA': 18.025, 'MD': 11.994999999999997}, 'DE|MA|MD|MN': {'DE': 12.206666666666669, 'MA': 18.189999999999998, 'MD': 12.14, 'MN': 13.1}, 'DE|MA|MD|MN|MT': {'DE': 12.255000000000003, 'MA': 18.205, 'MD': 12.16, 'MN': 13.0625, 'MT': 12.52}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}, 'DE|MA|MD|MN|NV': {'DE': 12.18, 'MA': 18.127499999999998, 'MD': 12.16, 'MN': 13.099999999999998, 'NV': 7.434999999999999}, 'DE|MA|MD|MT': {'DE': 12.206666666666669, 'MA': 18.099999999999998, 'MD': 12.069999999999999, 'MT': 12.476666666666665}, 'DE|MA|MD|MT|NV': {'DE': 12.18, 'MA': 18.06, 'MD': 12.107499999999998, 'MT': 12.439999999999998, 'NV': 7.515000000000001}, 'DE|MA|MD|NV': {'DE': 12.106666666666664, 'MA': 17.996666666666666, 'MD': 12.069999999999999, 'NV': 7.293333333333332}, 'DE|MA|MN': {'DE': 12.205000000000005, 'MA': 17.915, 'MN': 13.25}, 'DE|MA|MN|MT': {'DE': 12.270000000000005, 'MA': 18.026666666666667, 'MN': 13.15, 'MT': 12.540000000000001}, 'DE|MA|MN|MT|NV': {'DE': 12.227500000000003, 'MA': 18.005, 'MN': 13.1375, 'MT': 12.4875, 'NV': 7.670000000000002}, 'DE|MA|MN|NV': {'DE': 12.170000000000002, 'MA': 17.923333333333332, 'MN': 13.199999999999998, 'NV': 7.5}, 'DE|MA|MT': {'DE': 12.205000000000005, 'MA': 17.78, 'MT': 12.485}, 'DE|MA|MT|NV': {'DE': 12.170000000000002, 'MA': 17.833333333333332, 'MT': 12.433333333333332, 'NV': 7.606666666666669}, 'DE|MA|NV': {'DE': 12.055, 'MA': 17.625, 'NV': 7.32}, 'DE|MD': {'DE': 12.209999999999994, 'MD': 12.159999999999997}, 'DE|MD|MN': {'DE': 12.305, 'MD': 12.295000000000002, 'MN': 13.0}, 'DE|MD|MN|MT': {'DE': 12.336666666666668, 'MD': 12.270000000000001, 'MN': 12.983333333333334, 'MT': 12.516666666666666}, 'DE|MD|MN|MT|NV': {'DE': 12.2775, 'MD': 12.2575, 'MN': 13.0125, 'MT': 12.469999999999999, 'NV': 7.677500000000002}, 'DE|MD|MN|NV': {'DE': 12.236666666666665, 'MD': 12.270000000000001, 'MN': 13.033333333333331, 'NV': 7.510000000000001}, 'DE|MD|MT': {'DE': 12.305, 'MD': 12.189999999999998, 'MT': 12.449999999999996}, 'DE|MD|MT|NV': {'DE': 12.236666666666665, 'MD': 12.199999999999998, 'MT': 12.409999999999997, 'NV': 7.61666666666667}, 'DE|MD|NV': {'DE': 12.154999999999994, 'MD': 12.189999999999998, 'NV': 7.335000000000001}, 'DE|MN': {'DE': 12.400000000000006, 'MN': 13.200000000000003}, 'DE|MN|MT': {'DE': 12.400000000000006, 'MN': 13.075000000000003, 'MT': 12.545000000000002}, 'DE|MN|MT|NV': {'DE': 12.300000000000002, 'MN': 13.083333333333334, 'MT': 12.473333333333334, 'NV': 7.823333333333338}, 'DE|MN|NV': {'DE': 12.25, 'MN': 13.149999999999999, 'NV': 7.645000000000003}, 'DE|MT': {'DE': 12.400000000000006, 'MT': 12.439999999999998}, 'DE|MT|NV': {'DE': 12.25, 'MT': 12.384999999999998, 'NV': 7.805000000000007}, 'DE|NV': {'DE': 12.099999999999994, 'NV': 7.430000000000007}, 'DE': {'DE': 12.39}, 'IA|IL': {'IA': 13.959999999999994, 'IL': 13.129999999999995}, 'IA|IL|MA': {'IA': 14.055, 'IL': 12.905000000000001, 'MA': 17.72}, 'IA|IL|MA|MD': {'IA': 14.233333333333334, 'IL': 12.85666666666667, 'MA': 18.06, 'MD': 12.039999999999997}, 'IA|IL|MA|MD|MN': {'IA': 14.2725, 'IL': 12.937500000000004, 'MA': 18.174999999999997, 'MD': 12.1375, 'MN': 13.014999999999997}, 'IA|IL|MA|MD|MN|MT': {'IA': 14.284, 'IL': 12.932000000000002, 'MA': 18.189999999999998, 'MD': 12.154, 'MN': 13.001999999999999, 'MT': 12.552000000000001}, 'IA|IL|MA|MD|MN|MT|NV': {'IA': 14.100000000000001, 'IL': 12.928333333333335, 'MA': 18.14833333333333, 'MD': 12.165, 'MN': 13.01833333333333, 'MT': 12.515, 'NV': 9.251666666666665}, 'IA|IL|MA|MD|MN|NV': {'IA': 14.054000000000002, 'IL': 12.932000000000002, 'MA': 18.127999999999997, 'MD': 12.154, 'MN': 13.031999999999996, 'NV': 9.465999999999998}, 'IA|IL|MA|MD|MT': {'IA': 14.2575, 'IL': 12.870000000000001, 'MA': 18.107499999999998, 'MD': 12.084999999999997, 'MT': 12.5275}, 'IA|IL|MA|MD|MT|NV': {'IA': 14.042000000000002, 'IL': 12.878, 'MA': 18.073999999999998, 'MD': 12.111999999999998, 'MT': 12.488, 'NV': 9.529999999999998}, 'IA|IL|MA|MD|NV': {'IA': 13.970000000000002, 'IL': 12.870000000000001, 'MA': 18.029999999999998, 'MD': 12.084999999999997, 'NV': 9.867499999999996}, 'IA|IL|MA|MN': {'IA': 14.166666666666666, 'IL': 12.99666666666667, 'MA': 17.986666666666665, 'MN': 13.086666666666664}, 'IA|IL|MA|MN|MT': {'IA': 14.2075, 'IL': 12.975000000000001, 'MA': 18.0525, 'MN': 13.052499999999998, 'MT': 12.575000000000003}, 'IA|IL|MA|MN|MT|NV': {'IA': 14.002, 'IL': 12.962, 'MA': 18.029999999999998, 'MN': 13.061999999999998, 'MT': 12.526000000000002, 'NV': 9.654}, 'IA|IL|MA|MN|NV': {'IA': 13.920000000000002, 'IL': 12.975000000000001, 'MA': 17.974999999999998, 'MN': 13.089999999999996, 'NV': 10.022499999999997}, 'IA|IL|MA|MT': {'IA': 14.146666666666667, 'IL': 12.906666666666666, 'MA': 17.896666666666665, 'MT': 12.550000000000002}, 'IA|IL|MA|MT|NV': {'IA': 13.905000000000001, 'IL': 12.907499999999999, 'MA': 17.9075, 'MT': 12.495000000000001, 'NV': 10.1025}, 'IA|IL|MA|NV': {'IA': 13.763333333333335, 'IL': 12.906666666666666, 'MA': 17.793333333333333, 'NV': 10.74333333333333}, 'IA|IL|MD': {'IA': 14.274999999999999, 'IL': 12.945, 'MD': 12.144999999999996}, 'IA|IL|MD|MN': {'IA': 14.313333333333333, 'IL': 13.023333333333335, 'MD': 12.24, 'MN': 12.919999999999996}, 'IA|IL|MD|MN|MT': {'IA': 14.317499999999999, 'IL': 12.995000000000001, 'MD': 12.235, 'MN': 12.927499999999998, 'MT': 12.557500000000001}, 'IA|IL|MD|MN|MT|NV': {'IA': 14.09, 'IL': 12.978, 'MD': 12.232, 'MN': 12.961999999999998, 'MT': 12.512, 'NV': 9.66}, 'IA|IL|MD|MN|NV': {'IA': 14.030000000000001, 'IL': 12.995000000000001, 'MD': 12.235, 'MN': 12.964999999999996, 'NV': 10.029999999999998}, 'IA|IL|MD|MT': {'IA': 14.293333333333331, 'IL': 12.933333333333332, 'MD': 12.169999999999996, 'MT': 12.526666666666666}, 'IA|IL|MD|MT|NV': {'IA': 14.015, 'IL': 12.927499999999998, 'MD': 12.182499999999997, 'MT': 12.4775, 'NV': 10.11}, 'IA|IL|MD|NV': {'IA': 13.910000000000002, 'IL': 12.933333333333332, 'MD': 12.169999999999996, 'NV': 10.75333333333333}, 'IA|IL|MN': {'IA': 14.174999999999997, 'IL': 13.155000000000001, 'MN': 12.979999999999997}, 'IA|IL|MN|MT': {'IA': 14.226666666666665, 'IL': 13.073333333333332, 'MN': 12.969999999999999, 'MT': 12.590000000000003}, 'IA|IL|MN|MT|NV': {'IA': 13.965, 'IL': 13.032499999999999, 'MN': 13.002499999999998, 'MT': 12.525000000000002, 'NV': 10.265}, 'IA|IL|MN|NV': {'IA': 13.843333333333334, 'IL': 13.073333333333332, 'MN': 13.019999999999996, 'NV': 10.959999999999999}, 'IA|IL|MT': {'IA': 14.144999999999996, 'IL': 13.019999999999996, 'MT': 12.560000000000002}, 'IA|IL|MT|NV': {'IA': 13.823333333333332, 'IL': 12.983333333333329, 'MT': 12.483333333333334, 'NV': 11.066666666666668}, 'IA|IL|NV': {'IA': 13.57, 'IL': 13.019999999999996, 'NV': 12.509999999999998}, 'IA|MA': {'IA': 14.150000000000006, 'MA': 17.92}, 'IA|MA|MD': {'IA': 14.370000000000005, 'MA': 18.33, 'MD': 12.104999999999997}, 'IA|MA|MD|MN': {'IA': 14.37666666666667, 'MA': 18.39333333333333, 'MD': 12.213333333333333, 'MN': 13.10333333333333}, 'IA|MA|MD|MN|MT': {'IA': 14.365000000000002, 'MA': 18.357499999999998, 'MD': 12.215, 'MN': 13.064999999999998, 'MT': 12.502500000000001}, 'IA|MA|MD|MN|MT|NV': {'IA': 14.128000000000004, 'MA': 18.273999999999997, 'MD': 12.216, 'MN': 13.071999999999997, 'MT': 12.468, 'NV': 8.648}, 'IA|MA|MD|MN|NV': {'IA': 14.077500000000004, 'MA': 18.279999999999998, 'MD': 12.215, 'MN': 13.102499999999996, 'NV': 8.764999999999997}, 'IA|MA|MD|MT': {'IA': 14.35666666666667, 'MA': 18.30333333333333, 'MD': 12.14333333333333, 'MT': 12.453333333333333}, 'IA|MA|MD|MT|NV': {'IA': 14.062500000000004, 'MA': 18.2125, 'MD': 12.162499999999998, 'MT': 12.4225, 'NV': 8.844999999999999}, 'IA|MA|MD|NV': {'IA': 13.973333333333338, 'MA': 18.2, 'MD': 12.14333333333333, 'NV': 9.066666666666663}, 'IA|MA|MN': {'IA': 14.270000000000003, 'MA': 18.22, 'MN': 13.254999999999995}, 'IA|MA|MN|MT': {'IA': 14.290000000000001, 'MA': 18.23, 'MN': 13.15333333333333, 'MT': 12.516666666666671}, 'IA|MA|MN|MT|NV': {'IA': 14.012500000000003, 'MA': 18.1575, 'MN': 13.139999999999997, 'MT': 12.470000000000002, 'NV': 9.0}, 'IA|MA|MN|NV': {'IA': 13.906666666666672, 'MA': 18.126666666666665, 'MN': 13.203333333333328, 'NV': 9.273333333333332}, 'IA|MA|MT': {'IA': 14.240000000000002, 'MA': 18.085, 'MT': 12.450000000000003}, 'IA|MA|MT|NV': {'IA': 13.88666666666667, 'MA': 18.036666666666665, 'MT': 12.410000000000002, 'NV': 9.38}, 'IA|MA|NV': {'IA': 13.665000000000006, 'MA': 17.93, 'NV': 9.979999999999997}, 'IA|MD': {'IA': 14.590000000000003, 'MD': 12.379999999999995}, 'IA|MD|MN': {'IA': 14.490000000000002, 'MD': 12.405000000000001, 'MN': 13.004999999999995}, 'IA|MD|MN|MT': {'IA': 14.436666666666667, 'MD': 12.343333333333334, 'MN': 12.986666666666665, 'MT': 12.493333333333334}, 'IA|MD|MN|MT|NV': {'IA': 14.122500000000002, 'MD': 12.3125, 'MN': 13.014999999999997, 'MT': 12.4525, 'NV': 9.0075}, 'IA|MD|MN|NV': {'IA': 14.053333333333336, 'MD': 12.343333333333334, 'MN': 13.036666666666662, 'NV': 9.283333333333331}, 'IA|MD|MT': {'IA': 14.46, 'MD': 12.299999999999997, 'MT': 12.415}, 'IA|MD|MT|NV': {'IA': 14.033333333333337, 'MD': 12.273333333333332, 'MT': 12.386666666666665, 'NV': 9.39}, 'IA|MD|NV': {'IA': 13.885000000000005, 'MD': 12.299999999999997, 'NV': 9.994999999999997}, 'IA|MN': {'IA': 14.39, 'MN': 13.209999999999994}, 'IA|MN|MT': {'IA': 14.36, 'MN': 13.079999999999998, 'MT': 12.510000000000005}, 'IA|MN|MT|NV': {'IA': 13.966666666666669, 'MN': 13.086666666666664, 'MT': 12.450000000000003, 'NV': 9.59666666666667}, 'IA|MN|NV': {'IA': 13.785000000000004, 'MN': 13.154999999999994, 'NV': 10.305}, 'IA|MT': {'IA': 14.329999999999998, 'MT': 12.370000000000005}, 'IA|MT|NV': {'IA': 13.755000000000003, 'MT': 12.350000000000001, 'NV': 10.465000000000003}, 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}, 'IA': {'IA': 15.159999999999997}, 'IL|MA': {'IL': 12.680000000000007, 'MA': 17.519999999999996}, 'IL|MA|MD': {'IL': 12.720000000000006, 'MA': 18.129999999999995, 'MD': 11.869999999999997}, 'IL|MA|MD|MN': {'IL': 12.87333333333334, 'MA': 18.259999999999994, 'MD': 12.056666666666667, 'MN': 12.949999999999998}, 'IL|MA|MD|MN|MT': {'IL': 12.882500000000004, 'MA': 18.257499999999997, 'MD': 12.0975, 'MN': 12.95, 'MT': 12.5975}, 'IL|MA|MD|MN|MT|NV': {'IL': 12.888000000000002, 'MA': 18.193999999999996, 'MD': 12.122, 'MN': 12.979999999999999, 'MT': 12.544, 'NV': 8.551999999999998}, 'IL|MA|MD|MN|NV': {'IL': 12.882500000000004, 'MA': 18.179999999999996, 'MD': 12.0975, 'MN': 12.987499999999997, 'NV': 8.644999999999996}, 'IL|MA|MD|MT': {'IL': 12.783333333333337, 'MA': 18.169999999999998, 'MD': 11.986666666666665, 'MT': 12.579999999999998}, 'IL|MA|MD|MT|NV': {'IL': 12.815000000000001, 'MA': 18.112499999999997, 'MD': 12.044999999999998, 'MT': 12.517499999999998, 'NV': 8.724999999999998}, 'IL|MA|MD|NV': {'IL': 12.783333333333337, 'MA': 18.066666666666663, 'MD': 11.986666666666665, 'NV': 8.906666666666661}, 'IL|MA|MN': {'IL': 12.930000000000007, 'MA': 18.019999999999996, 'MN': 13.024999999999999}, 'IL|MA|MN|MT': {'IL': 12.923333333333337, 'MA': 18.096666666666664, 'MN': 13.0, 'MT': 12.643333333333336}, 'IL|MA|MN|MT|NV': {'IL': 12.920000000000002, 'MA': 18.057499999999997, 'MN': 13.024999999999999, 'MT': 12.565000000000001, 'NV': 8.879999999999999}, 'IL|MA|MN|NV': {'IL': 12.923333333333337, 'MA': 17.99333333333333, 'MN': 13.049999999999997, 'NV': 9.11333333333333}, 'IL|MA|MT': {'IL': 12.795000000000002, 'MA': 17.884999999999998, 'MT': 12.64}, 'IL|MA|MT|NV': {'IL': 12.833333333333334, 'MA': 17.903333333333332, 'MT': 12.536666666666667, 'NV': 9.219999999999999}, 'IL|MA|NV': {'IL': 12.795000000000002, 'MA': 17.729999999999997, 'NV': 9.739999999999995}, 'IL|MD': {'IL': 12.760000000000005, 'MD': 11.909999999999997}, 'IL|MD|MN': {'IL': 12.970000000000006, 'MD': 12.170000000000002, 'MN': 12.774999999999999}, 'IL|MD|MN|MT': {'IL': 12.950000000000003, 'MD': 12.186666666666667, 'MN': 12.833333333333334, 'MT': 12.62}, 'IL|MD|MN|MT|NV': {'IL': 12.940000000000001, 'MD': 12.195, 'MN': 12.899999999999999, 'MT': 12.5475, 'NV': 8.8875}, 'IL|MD|MN|NV': {'IL': 12.950000000000003, 'MD': 12.186666666666667, 'MN': 12.883333333333331, 'NV': 9.12333333333333}, 'IL|MD|MT': {'IL': 12.835, 'MD': 12.064999999999998, 'MT': 12.604999999999997}, 'IL|MD|MT|NV': {'IL': 12.86, 'MD': 12.116666666666665, 'MT': 12.51333333333333, 'NV': 9.229999999999999}, 'IL|MD|NV': {'IL': 12.835, 'MD': 12.064999999999998, 'NV': 9.754999999999995}, 'IL|MN': {'IL': 13.180000000000007, 'MN': 12.75}, 'IL|MN|MT': {'IL': 13.045000000000002, 'MN': 12.850000000000001, 'MT': 12.700000000000003}, 'IL|MN|MT|NV': {'IL': 13.0, 'MN': 12.933333333333332, 'MT': 12.576666666666668, 'NV': 9.436666666666667}, 'IL|MN|NV': {'IL': 13.045000000000002, 'MN': 12.924999999999997, 'NV': 10.064999999999998}, 'IL|MT': {'IL': 12.909999999999997, 'MT': 12.75}, 'IL|MT|NV': {'IL': 12.909999999999997, 'MT': 12.54, 'NV': 10.225000000000001}, 'IL|NV': {'IL': 12.909999999999997, 'NV': 12.269999999999996}, 'IL': {'IL': 13.049999999999997}, 'MA|MD': {'MA': 18.739999999999995, 'MD': 11.829999999999998}, 'MA|MD|MN': {'MA': 18.629999999999995, 'MD': 12.130000000000003, 'MN': 13.049999999999997}, 'MA|MD|MN|MT': {'MA': 18.50333333333333, 'MD': 12.160000000000002, 'MN': 13.016666666666666, 'MT': 12.546666666666667}, 'MA|MD|MN|MT|NV': {'MA': 18.362499999999997, 'MD': 12.175, 'MN': 13.037499999999998, 'MT': 12.4925, 'NV': 7.622499999999999}, 'MA|MD|MN|NV': {'MA': 18.399999999999995, 'MD': 12.160000000000002, 'MN': 13.066666666666663, 'NV': 7.436666666666663}, 'MA|MD|MT': {'MA': 18.494999999999997, 'MD': 12.024999999999999, 'MT': 12.494999999999997}, 'MA|MD|MT|NV': {'MA': 18.31, 'MD': 12.089999999999998, 'MT': 12.439999999999998, 'NV': 7.543333333333332}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}, 'MA|MN': {'MA': 18.519999999999996, 'MN': 13.299999999999997}, 'MA|MN|MT': {'MA': 18.384999999999998, 'MN': 13.125, 'MT': 12.590000000000003}, 'MA|MN|MT|NV': {'MA': 18.236666666666665, 'MN': 13.116666666666665, 'MT': 12.503333333333336, 'NV': 7.75}, 'MA|MN|NV': {'MA': 18.229999999999997, 'MN': 13.199999999999996, 'NV': 7.534999999999997}, 'MA|MT': {'MA': 18.25, 'MT': 12.530000000000001}, 'MA|MT|NV': {'MA': 18.095, 'MT': 12.43, 'NV': 7.695}, 'MA|NV': {'MA': 17.939999999999998, 'NV': 7.209999999999994}, 'MA': {'MA': 18.200000000000003}, 'MD|MN': {'MD': 12.430000000000007, 'MN': 12.799999999999997}, 'MD|MN|MT': {'MD': 12.325000000000003, 'MN': 12.875, 'MT': 12.555}, 'MD|MN|MT|NV': {'MD': 12.290000000000001, 'MN': 12.949999999999998, 'MT': 12.479999999999999, 'NV': 7.760000000000001}, 'MD|MN|NV': {'MD': 12.325000000000003, 'MN': 12.949999999999996, 'NV': 7.549999999999997}, 'MD|MT': {'MD': 12.219999999999999, 'MT': 12.459999999999994}, 'MD|MT|NV': {'MD': 12.219999999999999, 'MT': 12.394999999999996, 'NV': 7.710000000000001}, 'MD|NV': {'MD': 12.219999999999999, 'NV': 7.239999999999995}, 'MD': {'MD': 12.489999999999995}, 'MN|MT': {'MN': 12.950000000000003, 'MT': 12.650000000000006}, 'MN|MT|NV': {'MN': 13.024999999999999, 'MT': 12.490000000000002, 'NV': 8.020000000000003}, 'MN|NV': {'MN': 13.099999999999994, 'NV': 7.859999999999999}, 'MN': {'MN': 16.239999999999995}, 'MT|NV': {'MT': 12.329999999999998, 'NV': 8.180000000000007}, 'MT': {'MT': 12.519999999999996}, 'NV': {'NV': 8.379999999999995}}\n"
          ]
        }
      ],
      "source": [
        "rtn = {}\n",
        "tasks = list(revised_integrals.keys())\n",
        "num_tasks = len(tasks)\n",
        "task_combinations = gen_task_combinations(tasks=tasks, rtn=rtn, index=0, path='', path_dict={})\n",
        "\n",
        "# Normalize by the number of times the accuracy of any given element has been summed. \n",
        "# i.e. (a,b,c) => [acc(a|b) + acc(a|c)]/2 + [acc(b|a) + acc(b|c)]/2 + [acc(c|a) + acc(c|b)]/2\n",
        "for group in rtn:\n",
        "  if '|' in group:\n",
        "    for task in rtn[group]:\n",
        "      rtn[group][task] /= (len(group.split('|')) - 1)\n",
        "\n",
        "print(rtn)\n",
        "assert(len(rtn.keys()) == 2**len(revised_integrals.keys()) - 1)\n",
        "rtn_tup = [(key,val) for key,val in rtn.items()]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "WvTgeaR3KWMd"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL': {'DE': 12.024999999999999, 'IA': 14.119999999999997, 'IL': 12.809999999999995}, 'DE|IA|IL|MA|MD|MN|MT|NV': {'DE': 12.167142857142858, 'IA': 14.125714285714286, 'IL': 12.865714285714287, 'MA': 18.02857142857143, 'MD': 12.164285714285713, 'MN': 13.044285714285712, 'MT': 12.504285714285714, 'NV': 8.991428571428571}}\n",
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL': {'DE': 12.024999999999999, 'IA': 14.119999999999997, 'IL': 12.809999999999995}, 'DE|IA|MA|MD|MN|MT|NV': {'DE': 12.223333333333334, 'IA': 14.153333333333336, 'MA': 18.113333333333333, 'MD': 12.206666666666665, 'MN': 13.093333333333332, 'MT': 12.463333333333333, 'NV': 8.445}}\n",
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL': {'DE': 12.024999999999999, 'IA': 14.119999999999997, 'IL': 12.809999999999995}, 'DE|IL|MA|MD|MN|MT|NV': {'DE': 12.158333333333333, 'IL': 12.821666666666667, 'MA': 18.046666666666663, 'MD': 12.128333333333332, 'MN': 13.016666666666666, 'MT': 12.526666666666666, 'NV': 8.365}}\n",
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL': {'DE': 12.024999999999999, 'IA': 14.119999999999997, 'IL': 12.809999999999995}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}}\n",
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}}\n",
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IA|IL|MA|MD|MN|MT|NV': {'DE': 12.167142857142858, 'IA': 14.125714285714286, 'IL': 12.865714285714287, 'MA': 18.02857142857143, 'MD': 12.164285714285713, 'MN': 13.044285714285712, 'MT': 12.504285714285714, 'NV': 8.991428571428571}, 'DE|MA|NV': {'DE': 12.055, 'MA': 17.625, 'NV': 7.32}}\n",
            "{'DE|IA': {'DE': 12.219999999999999, 'IA': 14.280000000000001}, 'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}}\n",
            "{'DE|IA|IL': {'DE': 12.024999999999999, 'IA': 14.119999999999997, 'IL': 12.809999999999995}, 'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}}\n",
            "{'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|IA|IL|MA|MD|MN|MT': {'DE': 12.178333333333335, 'IA': 14.283333333333333, 'IL': 12.858333333333334, 'MA': 18.043333333333333, 'MD': 12.155, 'MN': 13.034999999999998, 'MT': 12.533333333333333}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}}\n",
            "{'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|IA|IL|MA|MD|MN|MT|NV': {'DE': 12.167142857142858, 'IA': 14.125714285714286, 'IL': 12.865714285714287, 'MA': 18.02857142857143, 'MD': 12.164285714285713, 'MN': 13.044285714285712, 'MT': 12.504285714285714, 'NV': 8.991428571428571}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}}\n",
            "{'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|IA|IL|MA|MN|MT|NV': {'DE': 12.160000000000002, 'IA': 14.048333333333334, 'IL': 12.883333333333333, 'MA': 17.91, 'MN': 13.084999999999999, 'MT': 12.511666666666668, 'NV': 9.283333333333333}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}}\n",
            "{'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|IA|IL|MD|MN|MT|NV': {'DE': 12.193333333333333, 'IA': 14.121666666666668, 'IL': 12.896666666666667, 'MD': 12.219999999999999, 'MN': 13.001666666666665, 'MT': 12.5, 'NV': 9.288333333333334}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}}\n",
            "{'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|IA|IL|MN|MT|NV': {'DE': 12.190000000000001, 'IA': 14.028, 'IL': 12.923999999999998, 'MN': 13.041999999999998, 'MT': 12.508000000000001, 'NV': 9.698000000000002}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}}\n",
            "{'DE|IA|IL|MA': {'DE': 12.020000000000001, 'IA': 14.13, 'IL': 12.766666666666666, 'MA': 17.583333333333332}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}, 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}}\n",
            "{'DE|IA|IL|MA|MD|MN|MT': {'DE': 12.178333333333335, 'IA': 14.283333333333333, 'IL': 12.858333333333334, 'MA': 18.043333333333333, 'MD': 12.155, 'MN': 13.034999999999998, 'MT': 12.533333333333333}, 'DE|MA|NV': {'DE': 12.055, 'MA': 17.625, 'NV': 7.32}, 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}}\n",
            "{'DE|IA|IL|MA|MD|MN|MT|NV': {'DE': 12.167142857142858, 'IA': 14.125714285714286, 'IL': 12.865714285714287, 'MA': 18.02857142857143, 'MD': 12.164285714285713, 'MN': 13.044285714285712, 'MT': 12.504285714285714, 'NV': 8.991428571428571}, 'DE|MA|NV': {'DE': 12.055, 'MA': 17.625, 'NV': 7.32}, 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}}\n",
            "{'DE|IA|IL|MN|MT|NV': {'DE': 12.190000000000001, 'IA': 14.028, 'IL': 12.923999999999998, 'MN': 13.041999999999998, 'MT': 12.508000000000001, 'NV': 9.698000000000002}, 'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415}, 'MA|MD|NV': {'MA': 18.339999999999996, 'MD': 12.024999999999999, 'NV': 7.224999999999994}}\n",
            "{'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}, 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}}\n",
            "{'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415}, 'DE|MA|MD|MN|MT|NV': {'DE': 12.224, 'MA': 18.151999999999997, 'MD': 12.172, 'MN': 13.069999999999999, 'MT': 12.482, 'NV': 7.5840000000000005}, 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}}\n",
            "[12.551000000000002]\n"
          ]
        }
      ],
      "source": [
        "def select_groups(index, cur_group, best_group, best_val, splits):\n",
        "  # Check if this group covers all tasks.\n",
        "  task_set = set()\n",
        "  for group in cur_group:\n",
        "    for task in group.split('|'): task_set.add(task)\n",
        "  if len(task_set) == num_tasks:\n",
        "    best_tasks = {task:1e6 for task in task_set}\n",
        "    \n",
        "    # Compute the per-task best scores for each task and average them together.\n",
        "    for group in cur_group:\n",
        "      for task in cur_group[group]:\n",
        "        # Minimize error.\n",
        "        best_tasks[task] = min(best_tasks[task], cur_group[group][task])\n",
        "    group_avg = np.mean(list(best_tasks.values()))\n",
        "    \n",
        "    # Compare with the best grouping seen thus far.\n",
        "    if group_avg < best_val[0]:\n",
        "      print(cur_group)\n",
        "      best_val[0] = group_avg\n",
        "      best_group.clear()\n",
        "      for entry in cur_group:\n",
        "        best_group[entry] = cur_group[entry]\n",
        "  \n",
        "  # Base case.\n",
        "  if len(cur_group.keys()) == splits:\n",
        "    return\n",
        "\n",
        "  # Back to combinatorics \n",
        "  for i in range(index, len(rtn_tup)):\n",
        "    selected_group, selected_dict = rtn_tup[i]\n",
        "\n",
        "    new_group = {k:v for k,v in cur_group.items()}\n",
        "    new_group[selected_group] = selected_dict\n",
        "\n",
        "    if len(new_group.keys()) <= splits:\n",
        "      select_groups(i + 1, new_group, best_group, best_val, splits)\n",
        "\n",
        "selected_group = {}\n",
        "selected_val = [100000000]\n",
        "select_groups(index=0, cur_group={}, best_group=selected_group, best_val=selected_val, splits=3)\n",
        "print(selected_group)\n",
        "print(selected_val)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "{'DE|IL|MA': {'DE': 11.920000000000002, 'IL': 12.585, 'MA': 17.415},\n",
              " 'DE|MA|MD|MN|MT|NV': {'DE': 12.224,\n",
              "  'MA': 18.151999999999997,\n",
              "  'MD': 12.172,\n",
              "  'MN': 13.069999999999999,\n",
              "  'MT': 12.482,\n",
              "  'NV': 7.5840000000000005},\n",
              " 'IA|NV': {'IA': 13.180000000000007, 'NV': 12.75}}"
            ]
          },
          "execution_count": 8,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "selected_group"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [],
      "last_runtime": {
        "build_target": "//learning/deepmind/public/tools/ml_python:ml_notebook",
        "kind": "private"
      },
      "name": "HOA Network Selection Neurips Submission.ipynb",
      "provenance": [
        {
          "file_id": "1Tgl6WD5WM35CmitLzwfNItHKPnMOP0oF",
          "timestamp": 1622695496870
        },
        {
          "file_id": "1S4fmk97iAXQ_WrpWxIgPLbF1R8bx_MQU",
          "timestamp": 1618947957836
        }
      ]
    },
    "kernelspec": {
      "display_name": "Python 3",
      "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.6.13"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
