{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "289465db",
   "metadata": {},
   "outputs": [],
   "source": [
    "from random_bo_agent_config import *\n",
    "from coordinator import Coordinator\n",
    "from random_instance import RandomInstance\n",
    "from power_allocation_instance import PowerAllocationInstance\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7ff62b7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "pa_instance = PowerAllocationInstance()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1f66c66b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start constructing power allocation config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Start constructing power allocation config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Start constructing power allocation config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Start constructing power allocation config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Start constructing power allocation config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n"
     ]
    }
   ],
   "source": [
    "if True:\n",
    "    if True:\n",
    "        max_while = 50\n",
    "        num_while = 0\n",
    "        while num_while <= max_while:\n",
    "            pd_pa, pen_pa = pa_instance.generate_one_instance()\n",
    "            if pd_pa.opt_val < 0.5 * pa_instance.M:\n",
    "               break\n",
    "            num_while += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "38cd551f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.86125572]\n",
      "[3.95918367]\n"
     ]
    }
   ],
   "source": [
    "pd_pa.update()\n",
    "print(sum(pd_pa.agent_list[k].black_box_func_gp_list[0].Y[-1] for k in range(5)))\n",
    "print(pd_pa.affine_dual)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "5b531917",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([3.95918367])"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd_pa.affine_dual\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "22415c1a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start constructing random_agent config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Black box function 1 sampled!\n",
      "Black box function 2 sampled!\n",
      "Start constructing random_agent config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Black box function 1 sampled!\n",
      "Black box function 2 sampled!\n",
      "Start constructing random_agent config!\n",
      "x_grid constructed!\n",
      "Black box function 0 sampled!\n",
      "Black box function 1 sampled!\n",
      "Black box function 2 sampled!\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-3-fafaa0c87778>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mrandom_coordinator\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mrandom_inst\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_one_instance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/DMABO/dmabo/random_instance.py\u001b[0m in \u001b[0;36mrun_one_instance\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    115\u001b[0m         \u001b[0mnum_while\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    116\u001b[0m         \u001b[0;32mwhile\u001b[0m \u001b[0mnum_while\u001b[0m \u001b[0;34m<=\u001b[0m \u001b[0mmax_while\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 117\u001b[0;31m             \u001b[0mpd_rc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcei_rc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgenerate_one_instance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    118\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mpd_rc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mopt_val\u001b[0m \u001b[0;34m<\u001b[0m \u001b[0;36m0.5\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mM\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    119\u001b[0m                \u001b[0;32mbreak\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/DMABO/dmabo/random_instance.py\u001b[0m in \u001b[0;36mgenerate_one_instance\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m     88\u001b[0m         \u001b[0mwhole_obj\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mwhole_black_box_funcs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     89\u001b[0m         \u001b[0mwhole_constraints_list\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mwhole_black_box_funcs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 90\u001b[0;31m         constr_func_val = [whole_obj(x) +\n\u001b[0m\u001b[1;32m     91\u001b[0m                        M * (1 - np.all(\n\u001b[1;32m     92\u001b[0m             [whole_constraints_list[k](x) <= 0 for k in range(\n",
      "\u001b[0;32m~/DMABO/dmabo/random_instance.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     88\u001b[0m         \u001b[0mwhole_obj\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mwhole_black_box_funcs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     89\u001b[0m         \u001b[0mwhole_constraints_list\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mwhole_black_box_funcs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 90\u001b[0;31m         constr_func_val = [whole_obj(x) +\n\u001b[0m\u001b[1;32m     91\u001b[0m                        M * (1 - np.all(\n\u001b[1;32m     92\u001b[0m             [whole_constraints_list[k](x) <= 0 for k in range(\n",
      "\u001b[0;32m~/DMABO/dmabo/random_instance.py\u001b[0m in \u001b[0;36m<lambda>\u001b[0;34m(x)\u001b[0m\n\u001b[1;32m     62\u001b[0m         \u001b[0;31m#for k in range(agent_0.num_black_box_constrs + 1):\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     63\u001b[0m         whole_black_box_funcs.append(\n\u001b[0;32m---> 64\u001b[0;31m                 lambda x: sum(\n\u001b[0m\u001b[1;32m     65\u001b[0m                 \u001b[0mprimal_dual_agent_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mblack_box_funcs_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     66\u001b[0m                 for i in range(self.num_agents))\n",
      "\u001b[0;32m~/DMABO/dmabo/random_instance.py\u001b[0m in \u001b[0;36m<genexpr>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     63\u001b[0m         whole_black_box_funcs.append(\n\u001b[1;32m     64\u001b[0m                 lambda x: sum(\n\u001b[0;32m---> 65\u001b[0;31m                 \u001b[0mprimal_dual_agent_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mblack_box_funcs_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     66\u001b[0m                 for i in range(self.num_agents))\n\u001b[1;32m     67\u001b[0m             )\n",
      "\u001b[0;32m~/DMABO/dmabo/util.py\u001b[0m in \u001b[0;36msampled_f\u001b[0;34m(x)\u001b[0m\n\u001b[1;32m     73\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0msampled_f\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     74\u001b[0m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0matleast_2d\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 75\u001b[0;31m         \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mkernel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mknot_x\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0malpha\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     76\u001b[0m         \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     77\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/lib/python3.8/site-packages/GPy/kern/src/kernel_slice_operations.py\u001b[0m in \u001b[0;36mwrap\u001b[0;34m(self, X, X2, *a, **kw)\u001b[0m\n\u001b[1;32m    107\u001b[0m     \u001b[0;34m@\u001b[0m\u001b[0mwraps\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    108\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mwrap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mX2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkw\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 109\u001b[0;31m         \u001b[0;32mwith\u001b[0m \u001b[0m_Slice_wrap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mX2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    110\u001b[0m             \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mX2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkw\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    111\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mret\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/lib/python3.8/site-packages/GPy/kern/src/kernel_slice_operations.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, k, X, X2, diag, ret_shape)\u001b[0m\n\u001b[1;32m     62\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_all_dims_active\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_sliced_X\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     63\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_check_active_dims\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 64\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mX\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slice_X\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     65\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mX2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slice_X\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mX2\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m \u001b[0;32melse\u001b[0m \u001b[0mX2\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     66\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<decorator-gen-128>\u001b[0m in \u001b[0;36m_slice_X\u001b[0;34m(self, X)\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/lib/python3.8/site-packages/paramz/caching.py\u001b[0m in \u001b[0;36mg\u001b[0;34m(obj, *args, **kw)\u001b[0m\n\u001b[1;32m    281\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    282\u001b[0m                 \u001b[0mcacher\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcache\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mCacher\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlimit\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mignore_args\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforce_kwargs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcacher_enabled\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcache\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcaching_enabled\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 283\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mcacher\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkw\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    284\u001b[0m         \u001b[0mg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    285\u001b[0m         \u001b[0mg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__doc__\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__doc__\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/lib/python3.8/site-packages/paramz/caching.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kw)\u001b[0m\n\u001b[1;32m    164\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    165\u001b[0m         \u001b[0;31m# 2: prepare_cache_id and get the unique self.id string for this call\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 166\u001b[0;31m         \u001b[0minputs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcombine_inputs\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkw\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mignore_args\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    167\u001b[0m         \u001b[0mcache_id\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprepare_cache_id\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    168\u001b[0m         \u001b[0;31m# 2: if anything is not cachable, we will just return the operation, without caching\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/miniconda3/lib/python3.8/site-packages/paramz/caching.py\u001b[0m in \u001b[0;36mcombine_inputs\u001b[0;34m(self, args, kw, ignore_args)\u001b[0m\n\u001b[1;32m     90\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mcombine_inputs\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkw\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mignore_args\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     91\u001b[0m         \u001b[0;34m\"Combines the args and kw in a unique way, such that ordering of kwargs does not lead to recompute\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 92\u001b[0;31m         \u001b[0minputs\u001b[0m\u001b[0;34m=\u001b[0m \u001b[0margs\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mc\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mc\u001b[0m \u001b[0;32min\u001b[0m \u001b[0msorted\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkw\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitems\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkey\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mlambda\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     93\u001b[0m         \u001b[0;31m# REMOVE the ignored arguments from input and PREVENT it from being checked!!!\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     94\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0ma\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0ma\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minputs\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mignore_args\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "random_coordinator = random_inst.run_one_instance()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b3a3d1cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.88458359, 2.04798186])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "random_coordinator.blackbox_dual"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2c495296",
   "metadata": {},
   "outputs": [],
   "source": [
    "agent_list = random_coordinator.agent_list\n",
    "num_agent = len(agent_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9168ba79",
   "metadata": {},
   "outputs": [],
   "source": [
    "obj = sum(agent_list[k].black_box_func_gp_list[0].Y for k in range(num_agent))\n",
    "constr_1 = sum(agent_list[k].black_box_func_gp_list[1].Y for k in range(num_agent))\n",
    "constr_2 = sum(agent_list[k].black_box_func_gp_list[2].Y for k in range(num_agent))\n",
    "opt_val = random_coordinator.opt_val\n",
    "regret = obj - opt_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "72952a2c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-1.]\n",
      "[-0.83673469]\n",
      "[1.]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.cumsum(regret))\n",
    "plt.plot(np.cumsum(constr_1))\n",
    "plt.plot(np.cumsum(constr_2))\n",
    "\n",
    "print(agent_list[0].black_box_func_gp_list[0].X[-1])\n",
    "\n",
    "print(agent_list[1].black_box_func_gp_list[0].X[-1])\n",
    "print(agent_list[2].black_box_func_gp_list[0].X[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fc83fc00",
   "metadata": {},
   "outputs": [],
   "source": [
    "opt_sol = random_coordinator.opt_sol\n",
    "whole_funcs = random_coordinator.whole_black_box_funcs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "07bdcfc9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.08706783617343267 -0.012192343604054783 -0.022133587835624163\n"
     ]
    }
   ],
   "source": [
    "print(sum(agent_list[k].black_box_funcs_list[0](opt_sol[k]) for k in range(num_agent)),\n",
    "sum(agent_list[k].black_box_funcs_list[1](opt_sol[k]) for k in range(num_agent)),\n",
    "sum(agent_list[k].black_box_funcs_list[2](opt_sol[k]) for k in range(num_agent)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "3bc3e5cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-1.02559582262796"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "opt_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "7e09c139",
   "metadata": {},
   "outputs": [],
   "source": [
    "opt_sol=[[-0.79591837],\n",
    "[-0.10204082],\n",
    "[-0.59183673]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "70f1fc89",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.08706783617343267 -0.012192343604054783 -0.022133587835624163\n"
     ]
    }
   ],
   "source": [
    "print(whole_funcs[0](opt_sol),\n",
    "whole_funcs[1](opt_sol),\n",
    "whole_funcs[2](opt_sol))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "91009b69",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function random_instance.RandomInstance.generate_one_instance.<locals>.<lambda>(x)>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "whole_funcs[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "8ee38162",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function random_instance.RandomInstance.generate_one_instance.<locals>.<lambda>(x)>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "whole_funcs[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f702e393",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
