{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.utils.env_export import create_json\n",
    "from src.utils.khalili_env import get_env\n",
    "from src.policy.jas_voc_policy import JAS_voc_policy\n",
    "from src.utils.mouselab_jas import MouselabJas\n",
    "import numpy as np\n",
    "import random\n",
    "import seaborn as sns\n",
    "from matplotlib import pyplot as plt\n",
    "import json\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "cost_weight= 0.5798921379230035\n",
    "\n",
    "for size in range(2, 6):\n",
    "    env, config = get_env(size)\n",
    "    create_json(f\"./data/khalili_env_{size}.json\", config, list(range(1, 31)), cost_weight=cost_weight)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def select_n(x, n):\n",
    "    n = min(n, len(x))\n",
    "    sampled_indices = np.random.choice(a=len(x), size=n, replace=False)\n",
    "    return [x[i] for i in sampled_indices]\n",
    "\n",
    "def get_highlight(env: MouselabJas, policy: JAS_voc_policy, num_choices: int, tolerance=0.001, mode=\"random\"):\n",
    "\n",
    "    actions, vocs = policy.get_all_vocs(env)\n",
    "    max_voc = np.max(vocs)\n",
    "\n",
    "    # Remove term actions\n",
    "    assert actions[-1]==env.term_action\n",
    "    actions = actions[:-1]\n",
    "    vocs = vocs[:-1]\n",
    "    \n",
    "    # Split actions in optimal and suboptimal actions\n",
    "    optimal = []\n",
    "    suboptimal = []\n",
    "    for action, voc in zip(actions, vocs):\n",
    "        if np.abs(max_voc - voc) <= tolerance:\n",
    "            optimal.append(action)\n",
    "        else:\n",
    "            suboptimal.append(action)\n",
    "    \n",
    "    # Prefer actions with a low project in case of ties\n",
    "    lowest_project = env.num_projects\n",
    "    lowest_project_actions = []\n",
    "    for action in optimal:\n",
    "        project = env.action_to_readable(action)[0]\n",
    "        lowest_project = min(lowest_project, project)\n",
    "    for action in optimal:\n",
    "        project = env.action_to_readable(action)[0]\n",
    "        if project == lowest_project:\n",
    "            lowest_project_actions.append(action)\n",
    "\n",
    "    # Generate highlights\n",
    "    highlights = []\n",
    "    if max_voc == 0:\n",
    "        choice = env.term_action\n",
    "        #highlights.append(env.action_to_readable(env.term_action))\n",
    "        highlights.extend([env.action_to_readable(action) for action in select_n(suboptimal, num_choices)])\n",
    "    else:\n",
    "        choice = random.choice(lowest_project_actions)\n",
    "        choice_readable = env.action_to_readable(choice)\n",
    "        highlights.append(choice_readable)\n",
    "        num_remaining = num_choices - 1\n",
    "        # Alternate choice preference order\n",
    "        perfect_match_suboptimal = []\n",
    "        ok_match_suboptimal = []\n",
    "        bad_match_suboptimal = []\n",
    "\n",
    "        if mode == \"random\":\n",
    "            perfect_match_suboptimal = suboptimal\n",
    "        elif mode == \"criteria\":\n",
    "            for action in suboptimal:\n",
    "                action_readable = env.action_to_readable(action)\n",
    "                if (action_readable[0] == choice_readable[0]) and (action_readable[1] == choice_readable[1]):\n",
    "                    perfect_match_suboptimal.append(action)\n",
    "                elif (action_readable[1] == choice_readable[1]):\n",
    "                    ok_match_suboptimal.append(action)\n",
    "                else:\n",
    "                    bad_match_suboptimal.append(action)\n",
    "        elif mode == \"expert\":\n",
    "            for action in suboptimal:\n",
    "                action_readable = env.action_to_readable(action)\n",
    "                if (action_readable[0] == choice_readable[0]) and (action_readable[2] == choice_readable[2]):\n",
    "                    perfect_match_suboptimal.append(action)\n",
    "                elif (action_readable[2] == choice_readable[2]):\n",
    "                    ok_match_suboptimal.append(action)\n",
    "                else:\n",
    "                    bad_match_suboptimal.append(action)\n",
    "        elif mode == \"project\":\n",
    "            for action in suboptimal:\n",
    "                action_readable = env.action_to_readable(action)\n",
    "                if (action_readable[1] == choice_readable[1]) and (action_readable[2] == choice_readable[2]):\n",
    "                    perfect_match_suboptimal.append(action)\n",
    "                elif (action_readable[1] == choice_readable[1]) or (action_readable[2] == choice_readable[2]):\n",
    "                    ok_match_suboptimal.append(action)\n",
    "                else:\n",
    "                    bad_match_suboptimal.append(action)\n",
    "        elif mode == \"combined\":\n",
    "            for action in suboptimal:\n",
    "                action_readable = env.action_to_readable(action)\n",
    "                if (action_readable[1] == choice_readable[1]) and (action_readable[2] == choice_readable[2]):\n",
    "                    perfect_match_suboptimal.append(action)\n",
    "                elif (action_readable[1] == choice_readable[1]) and (action_readable[0] == choice_readable[0]):\n",
    "                    perfect_match_suboptimal.append(action)\n",
    "                elif (action_readable[0] == choice_readable[0]) and (action_readable[2] == choice_readable[2]):\n",
    "                    perfect_match_suboptimal.append(action)\n",
    "                elif (action_readable[1] == choice_readable[1]) or (action_readable[2] == choice_readable[2]) or (action_readable[0] == choice_readable[0]):\n",
    "                    ok_match_suboptimal.append(action)\n",
    "                else:\n",
    "                    bad_match_suboptimal.append(action)\n",
    "        else:\n",
    "            assert 0, \"unknown mode: \"+mode\n",
    "        \n",
    "        if num_remaining > 0:\n",
    "            highlights.extend([env.action_to_readable(a) for a in select_n(perfect_match_suboptimal, num_remaining)])\n",
    "            num_remaining = num_remaining - min(len(perfect_match_suboptimal), num_remaining)\n",
    "        if num_remaining > 0:\n",
    "            highlights.extend([env.action_to_readable(a) for a in select_n(ok_match_suboptimal, num_remaining)])\n",
    "            num_remaining = num_remaining - min(len(ok_match_suboptimal), num_remaining)\n",
    "        if num_remaining > 0:\n",
    "            highlights.extend([env.action_to_readable(a) for a in select_n(bad_match_suboptimal, num_remaining)])\n",
    "            num_remaining = num_remaining - min(len(bad_match_suboptimal), num_remaining)\n",
    "\n",
    "    return highlights, choice\n",
    "\n",
    "def get_highlights(n: int, num_projects: int, num_choices: int, mode=\"random\"):\n",
    "    env, config = get_env(num_projects)\n",
    "    policy = JAS_voc_policy(discrete_observations=True, cost_weight=cost_weight)\n",
    "\n",
    "    highlights = []\n",
    "    for i in range(n):\n",
    "        env.reset()\n",
    "        done = False\n",
    "        while not done:\n",
    "            highlight, choice = get_highlight(env, policy, num_choices, mode=mode)\n",
    "            #print(highlight, choice)\n",
    "            highlights.extend(highlight)\n",
    "            _, _, done, _ = env.step(choice)\n",
    "    return highlights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot(projects, criteria, experts):\n",
    "    fig, axes =plt.subplots(1,3, figsize=(15,4))\n",
    "    axes = axes.flatten()\n",
    "\n",
    "    g = sns.histplot(projects, discrete=True, shrink=0.9, stat=\"probability\", ax=axes[0])\n",
    "    g.set_title(\"Project distribution\")\n",
    "    g.set_xlabel(\"Project\")\n",
    "    g.set_ylabel(\"Probability\")\n",
    "\n",
    "    g = sns.histplot(criteria, discrete=True, shrink=0.9, stat=\"probability\", ax=axes[1])\n",
    "    g.set_title(\"Criteria distribution\")\n",
    "    g.set_xlabel(\"Criteria\")\n",
    "    g.set_ylabel(\"Probability\")\n",
    "\n",
    "    g = sns.histplot(experts, discrete=True, shrink=0.9, stat=\"probability\", ax=axes[2])\n",
    "    g.set_title(\"Expert distribution\")\n",
    "    g.set_xlabel(\"Expert\")\n",
    "    g.set_ylabel(\"Probability\")\n",
    "\n",
    "    plt.show()\n",
    "\n",
    "def get_distribution(x):\n",
    "    num_elements = len(x)\n",
    "    counter = [0 for _ in range(max(x)+1)]\n",
    "    for element in x:\n",
    "        counter[element] += 1\n",
    "    return [element/num_elements for element in counter]\n",
    "\n",
    "def format_distribution_data(highlights, num_projects, save_highlight=200):\n",
    "    projects = [x[0] for x in highlights]\n",
    "    criteria = [x[1] for x in highlights]\n",
    "    experts = [x[2] for x in highlights]\n",
    "\n",
    "    project_dist = get_distribution(projects)\n",
    "    criteria_dist = get_distribution(criteria)\n",
    "    expert_dist = get_distribution(experts)\n",
    "\n",
    "    print(\"Projects:\", project_dist)\n",
    "    print(\"Criteria:\", criteria_dist)\n",
    "    print(\"Experts:\", expert_dist)\n",
    "    plot(projects, criteria, experts)\n",
    "    \n",
    "    res = {\n",
    "        \"num_projects\": num_projects,\n",
    "        \"project_dist\": project_dist,\n",
    "        \"criteria_dist\": criteria_dist,\n",
    "        \"expert_dist\": expert_dist,\n",
    "        \"highlights\": select_n(highlights, save_highlight)\n",
    "    }\n",
    "\n",
    "    return res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Projects: [0.5757709251101322, 0.42422907488986783]\n",
      "Criteria: [0.09801762114537445, 0.09427312775330396, 0.11475770925110132, 0.10308370044052863, 0.48612334801762114, 0.10374449339207048]\n",
      "Experts: [0.1092511013215859, 0.2786343612334802, 0.1105726872246696, 0.11696035242290749, 0.12819383259911896, 0.2563876651982379]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABNEAAAGHCAYAAACeQ8QzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAABtrElEQVR4nO3de1gUdf//8deKcvAApihiIpAlqGQipKKpGYqplZ3uKPOUhzK0UuruFg+JZnFbpliJ6V3KbQekbu3snVF5Ks2SoLzzcFu3tmqQoSkeUWF+f/Rjv64LLKwLy+H5uK65Lvezn5l5z7DOe+e9n5kxGYZhCAAAAAAAAECp6rk6AAAAAAAAAKC6o4gGAAAAAAAA2EERDQAAAAAAALCDIhoAAAAAAABgB0U0AAAAAAAAwA6KaAAAAAAAAIAdFNEAAAAAAAAAOyiiAQAAAAAAAHZQRAMAAAAAAADsoIiGKpGamiqTyWSZ6tevrzZt2uiBBx7QoUOHnLquoKAgjR492qnLvFhKSopSU1Mvezkmk0mJiYmW18X7aP/+/RVazrPPPqv33nuvQvOUtK4bb7xRYWFhFVqOPWvXrrXaxotV9t8JQN3yww8/6IEHHlBwcLA8PT3VuHFjde3aVc8995yOHj1armVcelz69ddflZiYqOzs7EqJ2dHjfkVt2LBBJpNJGzZssLSNHj1aQUFBFVqOo/ujpHWZTCZNmjSpQsuxp7T8vH//fplMJqfkbgC49Lzm0uniY211tHPnTiUmJl527klMTJTJZLJqc+T7/ZYtW5SYmKhjx45VaL5L11Wc6/71r39VaDllOX36tBITE0v8m1ZVDkf1U9/VAaBuWbFihUJDQ3XmzBlt2rRJSUlJ2rhxo3bs2KFGjRo5ZR3vvvuuvL29nbKskqSkpMjX19fpBaAhQ4Zo69at8vf3r9B8zz77rO6++27dfvvtlb6uilq7dq0WL15cYiGtsv9OAOqOf/zjH4qLi1NISIj++te/qmPHjjp//ry2b9+uV155RVu3btW7775rdzmXHpd+/fVXzZ49W0FBQerSpYvT466qY3FJZs6cqccee6xC8zi6PxxZlyNKy8/+/v7aunWr2rVrV+kxAKg7is9rLtWxY0cXRFN+O3fu1OzZs3XjjTdW+McUexz5fr9lyxbNnj1bo0ePVtOmTSt1XRV1+vRpzZ49W9KfAw4u5socDteiiIYqFRYWpsjISElSv379VFhYqKefflrvvfee7r///hLnOX36tBo2bFjudYSHhzsl1qrWokULtWjRolLXcebMGXl6elbJuuypqX8nANXL1q1b9fDDD2vAgAF677335OHhYXlvwIABevzxx/XJJ5+UuYwzZ87Iy8uryo5L1eFYXBUFpeL87erilYeHh3r06OHSGADUPhef19QE58+ftxk55mxVkUerOmeXpjqcT8E1uJwTLlX8pfaXX36R9OclH40bN9aOHTsUExOjJk2aKDo6WpJ09OhRxcXF6corr5S7u7uuuuoqTZ8+XQUFBVbLLGkYcX5+vp544gkFBwfL3d1dV155pSZPnqxTp05Z9SsqKtJLL72kLl26yMvLS02bNlWPHj30wQcfWJb9448/auPGjZYh2/Z+wcnPz9f48ePVvHlzNW7cWDfffLP++9//2vQraUhwVlaWbrnlFrVs2VIeHh5q3bq1hgwZooMHD0r683KYU6dO6Z///KclnuJfSYqX9+mnn2rMmDFq0aKFGjZsqIKCgjKHH2/evFk9evSQl5eXrrzySs2cOVOFhYWW90u6LEiyvVxm9OjRWrx4sSXO4ql4nSX9ncxms4YPH27Z3g4dOuiFF15QUVGRzXrmz5+vBQsWKDg4WI0bN1ZUVJS+/vrrMv8WAGqfZ599ViaTScuWLbMqoBVzd3fXbbfdZnkdFBSkW265RWvWrFF4eLg8PT0tvzJffFzasGGDrr/+eknSAw88YDmGXTyydvv27brtttvUrFkzeXp6Kjw8XG+//bbV+it6LM7IyNDQoUPVpk0beXp66uqrr9ZDDz2kvLy8cu2P3bt36+abb1bDhg3l6+urCRMm6MSJEzb9SrrE8p133lH37t3l4+Ojhg0b6qqrrtKYMWPKtT/Kyt9lXTq6dOlStW/fXh4eHurYsaNWrVpl9X5JlwtJtjmzrPxc2uWcX375paKjo9WkSRM1bNhQPXv21Mcff1zietavX6+HH35Yvr6+at68ue688079+uuvJW4TAEjSqlWrZDKZ9PLLL1u1z5o1S25ubsrIyJD0f8eo5557Ts8884zatm0rT09PRUZG6vPPP7dZ7t69ezVs2DCr78vF37mLFX9ff/311/X444/ryiuvlIeHh1599VX95S9/kfTngIbi46W9y90//vhjdenSRR4eHgoODtb8+fNL7Hfp9/uioiLNnTtXISEhlnOrzp07a9GiRZL+PMb/9a9/lSQFBwfbXBJb3px9sbNnzyo+Pl6tWrWSl5eX+vbtq6ysLKs+N954o83IMsk6X+3fv99SJJs9e7YltuJ1lnY+tXz5cl133XXy9PRUs2bNdMcdd2jXrl0262ncuLF++uknDR48WI0bN1ZAQIAef/xxm3NbVD+MRINL/fTTT5JkVcU/d+6cbrvtNj300EOaOnWqLly4oLNnz6pfv376+eefNXv2bHXu3FmbN29WUlKSsrOzbb70Xuz06dPq27evDh48qGnTpqlz58768ccf9dRTT2nHjh367LPPLF/QR48erTfeeENjx47VnDlz5O7uru+++85ycHz33Xd19913y8fHRykpKZJU4klbMcMwdPvtt2vLli166qmndP311+urr77SoEGD7O6bU6dOacCAAQoODtbixYvl5+en3NxcrV+/3nJCtHXrVt10003q16+fZs6cKUk2w5rHjBmjIUOG6PXXX9epU6fUoEGDUteZm5ure++9V1OnTtWcOXP08ccfa+7cufrjjz9svgDYM3PmTJ06dUr/+te/tHXrVkt7aUOef//9d/Xs2VPnzp3T008/raCgIH300Ud64okn9PPPP1v2d7HFixcrNDRUycnJlvUNHjxY+/btk4+PT4ViBVAzFRYW6osvvlBERIQCAgLKPd93332nXbt2acaMGQoODi7xdgJdu3bVihUr9MADD2jGjBkaMmSIJKlNmzaSpPXr1+vmm29W9+7d9corr8jHx0erVq1SbGysTp8+bfPFvrzH4p9//llRUVEaN26cfHx8tH//fi1YsEA33HCDduzYUeYx/LffflPfvn3VoEEDpaSkyM/PT2+++Wa57j22detWxcbGKjY2VomJifL09NQvv/yiL774olz7Qyo5f5flgw8+0Pr16zVnzhw1atRIKSkpuu+++1S/fn3dfffddmO+WEXz88aNGzVgwAB17txZr732mjw8PJSSkqJbb71VaWlpio2Nteo/btw4DRkyRG+99ZYOHDigv/71rxo+fLhl/wCoewoLC22OcyaTSW5ubpKke++9Vxs3btTjjz+uHj16KDIyUl988YXmzp2radOmacCAAVbzvvzyywoMDFRycrKKior03HPPadCgQdq4caOioqIk/XkpZs+ePdW2bVu98MILatWqldatW6dHH31UeXl5mjVrltUyExISFBUVpVdeeUX16tVTZGSk/vjjD02bNk2LFy9W165dJZU9Ovnzzz/X0KFDFRUVpVWrVqmwsFDPPfecfvvtN7v76LnnnlNiYqJmzJihPn366Pz589q9e7fl/mfjxo3T0aNH9dJLL2nNmjWW84SLL4ktT86+2LRp09S1a1e9+uqrOn78uBITE3XjjTcqKytLV111ld2Yi/n7++uTTz7RzTffrLFjx2rcuHGSVObos6SkJE2bNk333XefkpKSdOTIESUmJioqKkrffvutrrnmGkvf8+fP67bbbtPYsWP1+OOPa9OmTXr66afl4+Ojp556qtxxwgUMoAqsWLHCkGR8/fXXxvnz540TJ04YH330kdGiRQujSZMmRm5urmEYhjFq1ChDkrF8+XKr+V955RVDkvH2229btc+bN8+QZHz66aeWtsDAQGPUqFGW10lJSUa9evWMb7/91mref/3rX4YkY+3atYZhGMamTZsMScb06dPL3JZOnToZffv2Ldd2//vf/zYkGYsWLbJqf+aZZwxJxqxZsyxtxfto3759hmEYxvbt2w1JxnvvvVfmOho1amS1vZcub+TIkaW+V7wuwzCMvn37GpKM999/36rv+PHjjXr16hm//PKLYRiGsX79ekOSsX79eqt++/btMyQZK1assLRNnDjRKO0wc+nfaerUqYYkY9u2bVb9Hn74YcNkMhl79uyxWs+1115rXLhwwdLvm2++MSQZaWlpJa4PQO2Tm5trSDLuvffecs8TGBhouLm5WY4pl7538XHp22+/tTmuFQsNDTXCw8ON8+fPW7Xfcssthr+/v1FYWGgYRsWPxRcrKioyzp8/b/zyyy8lHp8v9be//c0wmUxGdna2VfuAAQNsjtujRo0yAgMDLa/nz59vSDKOHTtW6vLL2h+l5e+S1mUYhiHJ8PLysuR/wzCMCxcuGKGhocbVV19taZs1a1aJeaSkfVdafi4pP/Xo0cNo2bKlceLECav1h4WFGW3atDGKioqs1hMXF2e1zOeee86QZOTk5NisD0DtVnxcKGlyc3Oz6nv27FkjPDzcCA4ONnbu3Gn4+fkZffv2tfoOW3yMat26tXHmzBlLe35+vtGsWTOjf//+lraBAwcabdq0MY4fP261nkmTJhmenp7G0aNHDcP4v+/rffr0sYn/nXfeKfG7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a6z6FxUV6Y033lCbNm0u63JfACi2Y8cOPfrooxo5cqQ2b96szp07KzY2Vn/88YdN3zVr1liNQjpx4oQ+/PBD9e7dW25ubmrYsKH69eunrKwsde7cucTcc+mo2ZJU5FjeqFEjdevWrdTYKqJp06a6++67NXHiRB09etTy4DZn55a0tDQZhmF5/csvv2jLli1WT+MMCgrSf//7X6tBAUeOHNGWLVusllWR2KKiouTl5aU33njDqv3gwYP64osvyjxfRc3CSDTUCCNHjtTixYs1atQo7d+/X9dee62+/PJLPfvssxo8eLD69+9f6ryTJ0/W6tWr1adPH02ZMkWdO3dWUVGRzGazPv30Uz3++OPq3r27evfurREjRmju3Ln67bffdMstt8jDw0NZWVlq2LChHnnkEUn/NzosPT1dV111lTw9PXXttdeWuO6YmBj16dNHTz75pE6dOqXIyEh99dVXev311+1u80cffaSUlBTdfvvtuuqqq2QYhtasWaNjx45ZPc3n2muv1YYNG/Thhx/K399fTZo0sRkBUV7NmzfXww8/LLPZrPbt22vt2rX6xz/+oYcfflht27aV9Odw6P79+yspKUlXXHGFAgMD9fnnn2vNmjU2yyveL/PmzdOgQYPk5uamzp07y93d3abvlClTtHLlSg0ZMkRz5sxRYGCgPv74Y6WkpOjhhx/mhAZAiaKiorRkyRLFxcUpIiJCDz/8sDp16qTz588rKytLy5YtU1hYWLnu3XKpdu3aycvLS2+++aY6dOigxo0bq3Xr1mrdurWWLl2qQYMGaeDAgRo9erSuvPJKHT16VLt27dJ3332nd955p8LrCw0NVbt27TR16lQZhqFmzZrpww8/VEZGRrnmnzx5spYvX64hQ4Zo7ty5lqdz7t692+68Tz31lA4ePKjo6Gi1adNGx44d06JFi9SgQQP17dvX7v5whK+vr2666SbNnDnT8nTO3bt3a9WqVZY+gwcPVrNmzSxPza5fv75SU1N14MABm+VVJD8nJSVpwIAB6tevn5544gm5u7srJSVF//nPf5SWlnbZozcA1H7/+c9/SnwKcbt27dSiRQudOnVK99xzj4KDg5WSkiJ3d3e9/fbb6tq1qx544AGbwQFubm4aMGCA4uPjVVRUpHnz5ik/P1+zZ8+29Fm0aJFuuOEG9e7dWw8//LCCgoJ04sQJ/fTT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K9XG/xO1bZtq2/ZIbFNNUN23x5W5pjJySEWXSZ5xLbap+qtt2yOxTVWtvHnGZUU0X19fubm5KTc316r98OHD8vPzK3GeVq1aldi/fv36at68eYnzeHh4yMPDw6qtadOmduPz9vaudn/Umoj9ePnYh87BfnSO0vajj4+PC6Kxr7rnGleqjf8nats21bbtkdimmqA6b09V55rKyiGl9SltmRJ5prpgm6q/2rY9EttUlcqTZ1z2YAF3d3dFREQoIyPDqj0jI0M9e/YscZ6oqCib/p9++qkiIyNLvEcNAKBuI9cAABxVWTmktD6lLRMAUH249Omc8fHxevXVV7V8+XLt2rVLU6ZMkdls1oQJEyT9OWx55MiRlv4TJkzQL7/8ovj4eO3atUvLly/Xa6+9pieeeMJVmwAAqObINQAAR1VGDnnsscf06aefat68edq9e7fmzZunzz77TJMnT67qzQMAVJBL74kWGxurI0eOaM6cOcrJyVFYWJjWrl2rwMBASVJOTo7MZrOlf3BwsNauXaspU6Zo8eLFat26tV588UXdddddTovJw8NDs2bNshkujYphP14+9qFzsB+doybvx+qYa1ypJv8tS1Pbtqm2bY/ENtUEtW17nKUyckjPnj21atUqzZgxQzNnzlS7du2Unp6u7t27V/n2VYba+Flim6q/2rY9EttUXZkMowqfEw0AAAAAAADUQC69nBMAAAAAAACoCSiiAQAAAAAAAHZQRAMAAAAAAADsoIgGAAAAAAAA2FHni2h//PGHRowYIR8fH/n4+GjEiBE6duxYmfOMHj1aJpPJaurRo0fVBFxNpKSkKDg4WJ6enoqIiNDmzZvL7L9x40ZFRETI09NTV111lV555ZUqirR6q8h+3LBhg83nzmQyaffu3VUYcfWzadMm3XrrrWrdurVMJpPee+89u/PwebRW0X3IZ7Hmquixu7pz5P9/dZaUlKTrr79eTZo0UcuWLXX77bdrz549rg7rsixZskSdO3eWt7e3vL29FRUVpX//+9+uDstpkpKSZDKZNHnyZFeH4rDExESb43mrVq1cHRZqsNqUa8gz1R95pvqrbXmmzhfRhg0bpuzsbH3yySf65JNPlJ2drREjRtid7+abb1ZOTo5lWrt2bRVEWz2kp6dr8uTJmj59urKystS7d28NGjTI6vHeF9u3b58GDx6s3r17Kysr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n3zyiW644QY1bdpUzZs31y233KKff/65CvcUAMAZis9rLp6uuOIKbdiwQe7u7tq8ebOl7wsvvCBfX1/l5ORIkm688UZNmjRJkyZNsuSDGTNmyDAMyzyO5J0HHnhA//znP/X+++9b8tjF8wBVhZFoQCXx8vLS+fPnJUk//fST3n77ba1evVpubm6SpNtvv12NGjXSxo0bdeHCBcXFxSk2NrbUZLBu3ToNHz5cL774onr37q2ff/5ZDz74oCRp1qxZKioq0qBBg3TixAm98cYbateunXbu3Ck3Nzf17NlTycnJeuqpp7Rnzx5JUuPGjSt/JwAALsvRo0f1ySef6JlnnlGjRo1s3r/4x5ZZs2YpKSlJCxculJubm/bt22d5r6w88MADD2j//v1atWqVWrdurXfffVc333yzduzYoWuuuUaSdPr0aSUlJenVV19V8+bN1bJlS5tYTp06pfj4eF177bU6deqUnnrqKd1xxx3Kzs5WvXr8bgsANd2NN96oyZMna8SIEfr++++1f/9+TZ8+XWlpafL397f0++c//6mxY8dq27Zt2r59ux588EEFBgZq/PjxkhzLO61atdLZs2eVn59vGSXXrFmzqt8JqPMoogGV4JtvvtFbb72l6OhoSX/+2vL666+rRYsWkqSMjAz98MMP2rdvnwICAiRJr7/+ujp16qRvv/1W119/vc0yn3nmGU2dOlWjRo2SJF111VV6+umn9eSTT2rWrFn67LPP9M0332jXrl1q3769pU8xHx8fmUymSrm0BwBQOX766ScZhqHQ0FC7fYcNG6YxY8ZYXl9cRHN3dy8xD/z8889KS0vTwYMH1bp1a0nSE088oU8++UQrVqzQs88+K+nPy0NTUlJ03XXXlbr+u+66y+r1a6+9ppYtW2rnzp0KCwsr3wYDAFzuo48+svnB/W9/+5tmzpypuXPn6rPPPtODDz6oH3/8USNGjNAdd9xh1TcgIEALFy6UyWRSSEiIduzYoYULF2r8+PGXlXe8vLxUUFDA+QxciiIa4CTFyebChQs6f/68hg4dqpdeekkpKSkKDAy0FNAkadeuXQoICLAU0CSpY8eOatq0qXbt2lViES0zM1PffvutnnnmGUtbYWGhzp49q9OnTys7O1tt2rSxFNAAADVf8eUv5bkXTGRkZIWX/91338kwDJvcUVBQoObNm1teu7u7q3PnzmUu6+eff9bMmTP19ddfKy8vT0VFRZIks9lMEQ0AapB+/frZ3Ne5eNSXu7u73njjDXXu3FmBgYFKTk62mb9Hjx5WeSsqKkovvPCCCgsLnZp3AFegiAY4SXGyadCggVq3bm318IBLL8ExDKPEE6LS2iWpqKhIs2fP1p133mnznqenJw8hAIBa6JprrpHJZNKuXbvsPpGspMs97SkqKpKbm5syMzMttxsodvEoBC8vL7uFvFtvvVUBAQH6xz/+odatW6uoqEhhYWE6d+5cheMCALhOo0aNdPXVV5f6/pYtWyT9ecuBo0ePVij/ODPvAK5AEQ1wEnvJ5mIdO3aU2WzWgQMHLKPRdu7cqePHj6tDhw4lztO1a1ft2bOn1HV07txZBw8e1H//+98SR6O5u7ursLCwnFsDAKgOmjVrpoEDB2rx4sV69NFHbU5Ujh07ZvMQmtKUlAfCw8NVWFiow4cPq3fv3g7HeeTIEe3atUtLly61LOfLL790eHkAgOrp559/1pQpU/SPf/xDb7/9tkaOHKnPP//c6t6XxQ+9ufj1NddcIzc3t8vKO5zPoDrgLq+AC/Tv31+dO3fW/fffr++++07ffPONRo4cqb59+5Z6Oc5TTz2llStXKjExUT/++KN27dql9PR0zZgxQ5LUt29f9enTR3fddZcyMjK0b98+/fvf/9Ynn3wiSQoKCtLJkyf1+eefKy8vT6dPn66y7QUAOC4lJUWFhYXq1q2bVq9erb1792rXrl168cUXFRUVVe7llJQH2rdvr/vvv18jR47UmjVrtG/fPn377beaN2+e1q5dW+5lX3HFFWrevLmWLVumn376SV988YXi4+Md2VwAgIsVFBQoNzfXasrLy1NhYaFGjBihmJgYPfDAA1qxYoX+85//6IUXXrCa/8CBA4qPj9eePXuUlpaml156SY899pgkXVbeCQoK0g8//KA9e/YoLy/P8hA3oCpRRANcwGQy6b333tMVV1yhPn36qH///rrqqquUnp5e6jwDBw7URx99pIyMDF1//fXq0aOHFixYoMDAQEuf1atX6/rrr9d9992njh076sknn7T8WtOzZ09NmDBBsbGxatGihZ577rlK304AwOULDg7Wd999p379+unxxx9XWFiYBgwYoM8//9zmnjVlKS0PrFixQiNHjtTjjz+ukJAQ3Xbbbdq2bZvVfTvtqVevnlatWqXMzEyFhYVpypQpev755yu8rQAA1/vkk0/k7+9vNd1www165plntH//fi1btkyS1KpVK7366quaMWOGsrOzLfOPHDlSZ86cUbdu3TRx4kQ98sgjevDBBy3vO5p3xo8fr5CQEEVGRqpFixb66quvKmX7gbKYjOI71gKoVpYuXaqnn35aBw8edHUoAAAAAGDXjTfeqC5dupT4wAGgNmAkGlANHThwQGvXrlWnTp1cHQoAAAAAABAPFgCqpa5du+rKK69Uamqqq0MBAAAAAADick4AAAAAAADALi7nBAAAAAAAAOygiAYAAAAAAADYQRENAAAAAAAAsIMiGgAAAAAAAGAHRTQAAAAAAADADopoAAAAAAAAgB0U0QAAAAAAAAA7KKIBAAAAAAAAdvw/vvr3h2bCCOwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1500x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 2 node env\n",
    "num_projects = 2\n",
    "highlights = []\n",
    "highlights.extend(get_highlights(n=50, num_projects=num_projects, num_choices=1, mode=\"random\"))\n",
    "highlights.extend(get_highlights(n=100, num_projects=num_projects, num_choices=3, mode=\"criteria\"))\n",
    "highlights.extend(get_highlights(n=100, num_projects=num_projects, num_choices=3, mode=\"expert\"))\n",
    "highlights.extend(get_highlights(n=100, num_projects=num_projects, num_choices=6, mode=\"combined\"))\n",
    "env_2 = format_distribution_data(highlights=highlights, num_projects=num_projects, save_highlight=500)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Projects: [0.302367941712204, 0.26678809957498484, 0.20995749848208864, 0.151183970856102, 0.06970248937462052]\n",
      "Criteria: [0.0936247723132969, 0.0938676381299332, 0.09823922282938677, 0.09641772920461444, 0.522890103217972, 0.0949605343047966]\n",
      "Experts: [0.10018214936247723, 0.2734669095324833, 0.10649666059502125, 0.0962962962962963, 0.12143290831815422, 0.3021250758955677]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABNoAAAGHCAYAAABmoz/EAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAABmP0lEQVR4nO3de1xU1f7/8feI3ETFC4qY3DIFFU2FVDA0MzE1szoeKctLaWXYRclTkpWXLI5lipWYVsqxi1JHu5lldPGWZolQndRO9dXGDDI0xSsq7N8f/ZjjOIAwzjAwvJ6Px348mjVrr/1ZYPvD+syevU2GYRgCAAAAAAAAcFHquToAAAAAAAAAwB1QaAMAAAAAAAAcgEIbAAAAAAAA4AAU2gAAAAAAAAAHoNAGAAAAAAAAOACFNgAAAAAAAMABKLQBAAAAAAAADkChDQAAAAAAAHAACm0AAAAAAACAA1BoQ42RkZEhk8lk2erXr682bdro9ttv1/79+x16rLCwMI0dO9ahY54rPT1dGRkZFz2OyWTSjBkzLK9Lf0Z79+6t0jhPPfWU3nnnnSrtU9axrrrqKkVFRVVpnAtZu3at1RzP5ezfE4C65dtvv9Xtt9+u8PBw+fj4qGHDhurevbuefvppHTp0qFJjnH9e+u233zRjxgzl5uY6JWZ7z/tVtX79eplMJq1fv97SNnbsWIWFhVVpHHt/HmUdy2Qy6d57763SOBdSXn7eu3evTCaTQ3I3AJy/rjl/O/dcWxPt3LlTM2bMuOjcM2PGDJlMJqs2e/6+37Jli2bMmKHDhw9Xab/zj1Wa6/79739XaZyKnDhxQjNmzCjzd1pdORw1T31XBwCcb9myZYqMjNTJkye1ceNGpaamasOGDfruu+/k5+fnkGO8/fbbaty4sUPGKkt6eroCAgIcXiQaMmSItm7dqqCgoCrt99RTT2n48OG64YYbnH6sqlq7dq0WLlxYZrHN2b8nAHXHSy+9pKSkJEVEROgf//iHOnbsqDNnzmj79u168cUXtXXrVr399tsXHOf889Jvv/2mmTNnKiwsTF27dnV43NV1Li7LY489pgceeKBK+9j787DnWPYoLz8HBQVp69atatu2rdNjAFB3lK5rztexY0cXRFN5O3fu1MyZM3XVVVdV+QOXC7Hn7/stW7Zo5syZGjt2rJo0aeLUY1XViRMnNHPmTEl/XZRwLlfmcLgWhTbUOFFRUYqJiZEk9evXT8XFxXriiSf0zjvv6NZbby1znxMnTqhBgwaVPka3bt0cEmt1a9GihVq0aOHUY5w8eVI+Pj7VcqwLqa2/JwA1y9atW3XPPfdowIABeuedd+Tt7W15b8CAAXrwwQf10UcfVTjGyZMn5evrW23npZpwLq6OolNp/nZ1gcvb21u9evVyaQwA3M+565ra4MyZMzZXoDladeTR6s7Z5akJ6ym4Bl8dRY1X+ofvL7/8Iumvr5c0bNhQ3333nRISEtSoUSP1799fknTo0CElJSXpkksukZeXly699FJNmzZNRUVFVmOWdclyYWGhpkyZovDwcHl5eemSSy7RpEmTdPz4cat+JSUlev7559W1a1f5+vqqSZMm6tWrl9577z3L2N9//702bNhguTz8Qp8EFRYW6s4771Tz5s3VsGFDXXvttfrvf/9r06+sy49zcnJ03XXXqWXLlvL29lbr1q01ZMgQ/frrr5L++urN8ePH9a9//csST+mnLaXjffzxx7rjjjvUokULNWjQQEVFRRVe6rxp0yb16tVLvr6+uuSSS/TYY4+puLjY8n5ZX0GSbL+aM3bsWC1cuNASZ+lWesyyfk9ms1m33XabZb4dOnTQs88+q5KSEpvjzJ07V/PmzVN4eLgaNmyo2NhYffnllxX+LgC4n6eeekomk0lLliyxKrKV8vLy0vXXX295HRYWpuuuu06rV69Wt27d5OPjY/m0+tzz0vr163XFFVdIkm6//XbLOezcK3S3b9+u66+/Xs2aNZOPj4+6deumN9980+r4VT0XZ2VladiwYWrTpo18fHx02WWX6e6771ZBQUGlfh67d+/WtddeqwYNGiggIEATJkzQ0aNHbfqV9XXOt956Sz179pS/v78aNGigSy+9VHfccUelfh4V5e+Kvqa6ePFitW/fXt7e3urYsaNWrlxp9X5ZX02SbHNmRfm5vK+Obt68Wf3791ejRo3UoEEDxcXF6YMPPijzOJ9//rnuueceBQQEqHnz5rrpppv022+/lTknAJCklStXymQy6YUXXrBqnz59ujw8PJSVlSXpf+eop59+Wk8++aRCQkLk4+OjmJgYffrppzbj/vjjjxo5cqTV38ulf3OXKv17/dVXX9WDDz6oSy65RN7e3nr55Zf197//XdJfFz2Uni8v9NX6Dz74QF27dpW3t7fCw8M1d+7cMvud//d9SUmJZs+erYiICMvaqkuXLlqwYIGkv87x//jHPyRJ4eHhNl+/rWzOPtepU6eUnJysVq1aydfXV3379lVOTo5Vn6uuusrmCjXJOl/t3bvXUkibOXOmJbbSY5a3nlq6dKkuv/xy+fj4qFmzZrrxxhu1a9cum+M0bNhQP/30kwYPHqyGDRsqODhYDz74oM3aFjUPV7Shxvvpp58kyerTgNOnT+v666/X3XffralTp+rs2bM6deqU+vXrp59//lkzZ85Uly5dtGnTJqWmpio3N9fmD+NznThxQn379tWvv/6qRx55RF26dNH333+vxx9/XN99950++eQTyx/xY8eO1WuvvaZx48Zp1qxZ8vLy0o4dOywn0LffflvDhw+Xv7+/0tPTJanMhV0pwzB0ww03aMuWLXr88cd1xRVX6IsvvtCgQYMu+LM5fvy4BgwYoPDwcC1cuFCBgYHKz8/X559/blk0bd26VVdffbX69eunxx57TJJsLqG+4447NGTIEL366qs6fvy4PD09yz1mfn6+br75Zk2dOlWzZs3SBx98oNmzZ+vPP/+0+SPhQh577DEdP35c//73v7V161ZLe3mXV//xxx+Ki4vT6dOn9cQTTygsLExr1qzRlClT9PPPP1t+3qUWLlyoyMhIpaWlWY43ePBg7dmzR/7+/lWKFUDtVFxcrM8++0zR0dEKDg6u9H47duzQrl279Oijjyo8PLzMWxd0795dy5Yt0+23365HH31UQ4YMkSS1adNGkvT555/r2muvVc+ePfXiiy/K399fK1euVGJiok6cOGHzx39lz8U///yzYmNjNX78ePn7+2vv3r2aN2+errzySn333XcVnsN///139e3bV56enkpPT1dgYKBef/31St0LbevWrUpMTFRiYqJmzJghHx8f/fLLL/rss88q9fOQys7fFXnvvff0+eefa9asWfLz81N6erpuueUW1a9fX8OHD79gzOeqan7esGGDBgwYoC5duuiVV16Rt7e30tPTNXToUK1YsUKJiYlW/cePH68hQ4bojTfe0L59+/SPf/xDt912m+XnA6DuKS4utjnPmUwmeXh4SJJuvvlmbdiwQQ8++KB69eqlmJgYffbZZ5o9e7YeeeQRDRgwwGrfF154QaGhoUpLS1NJSYmefvppDRo0SBs2bFBsbKykv772GRcXp5CQED377LNq1aqV1q1bp/vvv18FBQWaPn261ZgpKSmKjY3Viy++qHr16ikmJkZ//vmnHnnkES1cuFDdu3eXVPFVzp9++qmGDRum2NhYrVy5UsXFxXr66af1+++/X/Bn9PTTT2vGjBl69NFH1adPH505c0a7d++23I9t/PjxOnTokJ5//nmtXr3ask449+u3lcnZ53rkkUfUvXt3vfzyyzpy5IhmzJihq666Sjk5Obr00ksvGHOpoKAgffTRR7r22ms1btw4jR8/XpIqvIotNTVVjzzyiG655Ralpqbq4MGDmjFjhmJjY/X111+rXbt2lr5nzpzR9ddfr3HjxunBBx/Uxo0b9cQTT8jf31+PP/54peOECxhADbFs2TJDkvHll18aZ86cMY4ePWqsWbPGaNGihdGoUSMjPz/fMAzDGDNmjCHJWLp0qdX+L774oiHJePPNN63a58yZY0gyPv74Y0tbaGioMWbMGMvr1NRUo169esbXX39tte+///1vQ5Kxdu1awzAMY+PGjYYkY9q0aRXOpVOnTkbfvn0rNe8PP/zQkGQsWLDAqv3JJ580JBnTp0+3tJX+jPbs2WMYhmFs377dkGS88847FR7Dz8/Par7njzd69Ohy3ys9lmEYRt++fQ1JxrvvvmvV98477zTq1atn/PLLL4ZhGMbnn39uSDI+//xzq3579uwxJBnLli2ztE2cONEo71R0/u9p6tSphiRj27ZtVv3uuecew2QyGT/88IPVcTp37mycPXvW0u+rr74yJBkrVqwo83gA3E9+fr4hybj55psrvU9oaKjh4eFhOaec/96556Wvv/7a5rxWKjIy0ujWrZtx5swZq/brrrvOCAoKMoqLiw3DqPq5+FwlJSXGmTNnjF9++aXM8/P5Hn74YcNkMhm5ublW7QMGDLA5b48ZM8YIDQ21vJ47d64hyTh8+HC541f08ygvf5d1LMMwDEmGr6+vJf8bhmGcPXvWiIyMNC677DJL2/Tp08vMI2X97MrLz2Xlp169ehktW7Y0jh49anX8qKgoo02bNkZJSYnVcZKSkqzGfPrppw1JRl5ens3xALi30vNCWZuHh4dV31OnThndunUzwsPDjZ07dxqBgYFG3759rf6GLT1HtW7d2jh58qSlvbCw0GjWrJlxzTXXWNoGDhxotGnTxjhy5IjVce69917Dx8fHOHTo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eTmnrN9pZfOhn5+fevbsqdWrV1v1Lykp0WuvvaY2bdpc1FeLAaDUd999p/vvv1+jR4/Wpk2b1KVLFyUmJurPP/+06bt69Wqrq5mOHj2q999/X/Hx8fLw8FCDBg3Ur18/5eTkqEuXLmXmnvOvvi1LVc7lfn5+6tGjR7mxVUWTJk00fPhwTZw4UYcOHbI8bM7RuWXFihUyDMPy+pdfftGWLVusnjIaFham//73v1YXDhw8eFBbtmyxGqsqscXGxsrX11evvfaaVfuvv/6qzz77rML1KmoXrmiD2xg9erQWLlyoMWPGaO/evercubM2b96sp556SoMHD9Y111xT7r6TJk3SqlWr1KdPH02ePFldunRRSUmJzGazPv74Yz344IPq2bOn4uPjNWrUKM2ePVu///67rrvuOnl7eysnJ0cNGjTQfffdJ+l/V5llZmbq0ksvlY+Pjzp37lzmsRMSEtSnTx899NBDOn78uGJiYvTFF1/o1VdfveCc16xZo/T0dN1www269NJLZRiGVq9ercOHD1s9pahz585av3693n//fQUFBalRo0Y2V1JUVvPmzXXPPffIbDarffv2Wrt2rV566SXdc889CgkJkfTXpdfXXHONUlNT1bRpU4WGhurTTz/V6tWrbcYr/bnMmTNHgwYNkoeHh7p06SIvLy+bvpMnT9by5cs1ZMgQzZo1S6Ghofrggw+Unp6ue+65h0UPgDLFxsZq0aJFSkpKUnR0tO655x516tRJZ86cUU5OjpYsWaKoqKhK3UvmfG3btpWvr69ef/11dejQQQ0bNlTr1q3VunVrLV68WIMGDdLAgQM1duxYXXLJJTp06JB27dqlHTt26K233qry8SIjI9W2bVtNnTpVhmGoWbNmev/995WVlVWp/SdNmqSlS5dqyJAhmj17tuWpo7t3777gvo8//rh+/fVX9e/fX23atNHhw4e1YMECeXp6qm/fvhf8edgjICBAV199tR577DHLU0d3796tlStXWvoMHjxYzZo1szwNvH79+srIyNC+fftsxqtKfk5NTdWAAQPUr18/TZkyRV5eXkpPT9d//vMfrVix4qKvAgHg/v7zn/+U+XTltm3bqkWLFjp+/LhGjBih8PBwpaeny8vLS2+++aa6d++u22+/3eYCAg8PDw0YMEDJyckqKSnRnDlzVFhYqJkzZ1r6LFiwQFdeeaXi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dx+gOnFFG+BCvr6+OnPmjCTpp59+0ptvvqlVq1bJw8NDknTDDTfIz89PGzZs0NmzZ5WUlKTExMRyk8a6det022236bnnnlN8fLx+/vln3XXXXZKk6dOnq6SkRIMGDdLRo0f12muvqW3bttq5c6c8PDwUFxentLQ0Pf744/rhhx8kSQ0bNnT+DwEAYLdDhw7po48+0pNPPik/Pz+b98/9MGb69OlKTU3V/Pnz5eHhoT179ljeqygH3H777dq7d69Wrlyp1q1b6+2339a1116r7777Tu3atZMknThxQqmpqXr55ZfVvHlztWzZ0iaW48ePKzk5WZ07d9bx48f1+OOP68Ybb1Rubq7q1eOzXwCo7a666ipNmjRJo0aN0jfffKO9e/dq2rRpWrFihYKCgiz9/vWvf2ncuHHatm2btm/frrvuukuhoaG68847JdmXd1q1aqVTp06psLDQcrVds2bNqv+HAIhCG+AyX331ld544w31799f0l+f3Lz66qtq0aKFJCkrK0vffvut9uzZo+DgYEnSq6++qk6dOunrr7/WFVdcYTPmk08+qalTp2rMmDGSpEsvvVRPPPGEHnroIU2fPl2ffPKJvvrqK+3atUvt27e39Cnl7+8vk8nklK8SAQAc76effpJhGIqMjLxg35EjR+qOO+6wvD630Obl5VVmDvj555+1YsUK/frrr2rdurUkacqUKfroo4+0bNkyPfXUU5L++ipqenq6Lr/88nKP/7e//c3q9SuvvKKWLVtq586dioqKqtyEAQAut2bNGpsP5B9++GE99thjmj17tj755BPddddd+v777zVq1CjdeOONVn2Dg4M1f/58mUwmRURE6LvvvtP8+fN15513XlTe8fX1VVFREWsZuByFNqAalSals2fP6syZMxo2bJief/55paenKzQ01FJkk6Rdu3YpODjYUmSTpI4dO6pJkybatWtXmYW27Oxsff3113ryySctbcXFxTp16pROnDih3NxctWnTxlJkAwDUbqVftanMvWliYmKqPP6OHTtkGIZN3igqKlLz5s0tr728vNSlS5cKx/r555/12GOP6csvv1RBQYFKSkokSWazmUIbANQi/fr1s7nHdOnVY15eXnrttdfUpUsXhYaGKi0tzWb/Xr16WeWt2NhYPfvssyouLnZo3gFchUIbUI1Kk5Knp6dat25t9cCD87/yYxhGmQun8tolqaSkRDNnztRNN91k856Pjw8PTgAAN9OuXTuZTCbt2rXrgk9aK+urpRdSUlIiDw8PZWdnW25rUOrcqxl8fX0vWOwbOnSogoOD9dJLL6l169YqKSlRVFSUTp8+XeW4AACu4+fnp8suu6zc97ds2SLpr9sbHDp0qEr5x5F5B3AVCm1ANbpQUjpXx44dZTabtW/fPstVbTt37tSRI0fUoUOHMvfp3r27fvjhh3KP0aVLF/3666/673//W+ZVbV5eXiouLq7kbAAArtasWTMNHDhQCxcu1P3332+zmDl8+LDNQ3PKU1YO6Natm4qLi3XgwAHFx8fbHefBgwe1a9cuLV682DLO5s2b7R4PAFAz/fzzz5o8ebJeeuklvfnmmxo9erQ+/fRTq3txlj6o59zX7dq1k4eHx0XlHdYyqCm48yxQQ11zzTXq0qWLbr31Vu3YsUNfffWVRo8erb59+5b79Z/HH39cy5cv14wZM/T9999r165dyszM1KOPPipJ6tu3r/r06aO//e1vysrK0p49e/Thhx/qo48+kiSFhYXp2LFj+vTTT1VQUKATJ05U23wBAPZJT09XcXGxevTooVWrVunHH3/Url279Nxzzyk2NrbS45SVA9q3b69bb71Vo0eP1urVq7Vnzx59/fXXmjNnjtauXVvpsZs2barmzZtryZIl+umnn/TZZ58pOTnZnukCAFysqKhI+fn5VltBQYGKi4s1atQoJSQk6Pbbb9eyZcv0n//8R88++6zV/vv27VNycrJ++OEHrVixQs8//7weeOABSbqovBMWFqZvv/1WP/zwgwoKCiwPnQOqG4U2oIYymUx655131LRpU/Xp00fXXHONLr30UmVmZpa7z8CBA7VmzRplZWXpiiuuUK9evTRv3jyFhoZa+qxatUpXXHGFbrnlFnXs2FEPPfSQ5ZOfuLg4TZgwQYmJiWrRooWefvppp88TAHBxwsPDtWPHDvXr108PPvigoqKiNGDAAH366ac299CpSHk5YNmyZRo9erQefPBBRURE6Prrr9e2bdus7iF6IfXq1dPKlSuVnZ2tqKgoTZ48Wc8880yV5woAcL2PPvpIQUFBVtuVV16pJ598Unv37tWSJUskSa1atdLLL7+sRx99VLm5uZb9R48erZMnT6pHjx6aOHGi7rvvPt11112W9+3NO3feeaciIiIUExOjFi1a6IsvvnDK/IELMRmld9EFUOssXrxYTzzxhH799VdXhwIAAAAAFbrqqqvUtWvXMh+SALgLrmgDaql9+/Zp7dq16tSpk6tDAQAAAAAA4mEIQK3VvXt3XXLJJcrIyHB1KAAAAAAAQHx1FAAAAAAAAHAIvjoKAAAAAAAAOACFNgAAAAAAAMABKLQBAAAAAAAADkChDQAAAAAAAHAACm0AAAAAAACAA1BoAwAAAAAAAByAQhsAAAAAAADgABTaAAAAAAAAAAf4fx6zeUpYqeEgAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1500x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 5 node env\n",
    "num_projects = 5\n",
    "highlights = []\n",
    "highlights.extend(get_highlights(n=200, num_projects=num_projects, num_choices=9, mode=\"combined\"))\n",
    "env_5 = format_distribution_data(highlights=highlights, num_projects=num_projects, save_highlight=200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "distribution_data = {\n",
    "    \"env_2\": env_2,\n",
    "    \"env_5\": env_5\n",
    "}\n",
    "\n",
    "path = \"./data/tutor_distribution.json\"\n",
    "\n",
    "with open(path, \"w\") as f:\n",
    "    d = json.dumps(distribution_data)\n",
    "    f.write(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = \"./data/tutor_distribution.json\"\n",
    "\n",
    "with open(path, \"r\") as f:\n",
    "    d = f.read()\n",
    "    distribution_data = json.loads(d)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.5 ('jas')",
   "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.10.6"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "cdc273f54b2f1f6750df25f1e10f8ad37a1a4b9d58873afdb9059fc1ead861fe"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
