{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "de815565-e7de-4328-8edc-59845da230fe",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import client\n",
    "import server\n",
    "import utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8448f73c-c53c-4461-b6e8-bf1d07c00b6c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<module 'utils' from '/Users/gael/Desktop/het-opl/src/utils.py'>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import importlib\n",
    "importlib.reload(client)\n",
    "importlib.reload(server)\n",
    "importlib.reload(utils)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "abcad7be-146d-4523-ae2d-265dfbdbeaba",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from tqdm.notebook import tqdm\n",
    "\n",
    "import random\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "sns.set_theme()\n",
    "\n",
    "from vowpalwabbit.sklearn import VW\n",
    "from sklearn.model_selection import train_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "21e33242-c491-48db-816f-6e923a2fb5ac",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cfc99d51-6846-4821-b009-8d0c123bc8b9",
   "metadata": {},
   "source": [
    "### Generate data from heterogeneous clients"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a04c64fa-133b-4d07-9af1-f73aaeb9dc76",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def generate_separated_vectors(n, k, L=1.0, num_vectors=4, max_iter=1000):\n",
    "    vectors = np.zeros((num_vectors, n))\n",
    "    for i in range(num_vectors):\n",
    "        for _ in range(max_iter):\n",
    "            vector = np.random.rand(n) * 2 * L - L\n",
    "            if i == 0 or np.all(np.linalg.norm(vectors[:i] - vector, axis=1) >= k):\n",
    "                vectors[i] = vector\n",
    "                break\n",
    "        else:\n",
    "            raise RuntimeError(f\"Failed to generate a vector separated by {k} after {max_iter} iterations.\")\n",
    "    return vectors\n",
    "\n",
    "def generate_observational_data(num_clients, num_actions, num_features, train_sizes, test_sizes=None):\n",
    "    if test_sizes is None:\n",
    "        test_sizes = [10_000] * num_clients\n",
    "        \n",
    "    # Generate action parameters\n",
    "    found_action_params = False\n",
    "    while not found_action_params:\n",
    "        action_params = generate_separated_vectors(num_features, np.sqrt(num_features), 1, 4)\n",
    "        found_action_params = True\n",
    "        for i in range(num_actions):\n",
    "            other_vectors = np.delete(action_params, [i], axis=0)\n",
    "            if not all(np.linalg.norm(action_params[i] - v) > np.sqrt(num_features) for v in other_vectors):\n",
    "                found_action_params = False\n",
    "    print(\"Found action params.\")\n",
    "    \n",
    "#     # Generate context parameters\n",
    "#     found_context_params = False\n",
    "#     while not found_context_params:\n",
    "#         context_params = generate_separated_vectors(num_features, np.sqrt(num_features), 1, 4)\n",
    "#         found_context_params = True\n",
    "#         for i in range(num_actions):\n",
    "#             other_vectors = np.delete(context_params, [i], axis=0)\n",
    "#             if not all(np.linalg.norm(context_params[i] - v) > np.sqrt(num_features) for v in other_vectors):\n",
    "#                 found_context_params = False\n",
    "#     print(\"Found context params.\")\n",
    "    \n",
    "#     print(action_params-context_params)\n",
    "    \n",
    "    # Compute client weights\n",
    "    weights = []\n",
    "    for i in range(num_actions):\n",
    "        other_vectors = np.delete(action_params, [i], axis=0)\n",
    "        weights.append(sum([1/np.linalg.norm(action_params[i] - v) for v in other_vectors]))\n",
    "    weights = [w / sum(weights) for w in weights]\n",
    "\n",
    "    # Generate data\n",
    "    data = {}\n",
    "    aux = {}\n",
    "    for client_id in range(num_clients):\n",
    "        # Get num local samples, including test samples\n",
    "        num_samples = train_sizes[client_id] + test_sizes[client_id]\n",
    "\n",
    "        # Generate local data\n",
    "        # contexts = np.random.multivariate_normal(mean=context_params[client_id], cov=np.eye(num_features), size=num_samples)\n",
    "        contexts = np.random.normal(loc=0, scale=1, size=(num_samples, num_features)) \n",
    "        rewards_vectors = np.zeros((num_samples, num_actions))\n",
    "        for i in range(num_samples):\n",
    "            for a in range(num_actions):\n",
    "                cx_i = contexts[i]\n",
    "                ap_a = action_params[a]\n",
    "                if client_id == 0:\n",
    "                    rewards_vectors[i, a] += 5*np.sin(np.dot(cx_i, ap_a))\n",
    "                else:\n",
    "                    rewards_vectors[i, a] += np.dot(cx_i, ap_a)\n",
    "                    if cx_i[0] > 0:\n",
    "                        rewards_vectors[i, a] += -np.max([np.dot(cx_i, action_params[aprime]) for aprime in range(num_actions)]) \n",
    "        # actions = np.random.choice(num_actions, p=p, size=num_samples)\n",
    "        actions = np.random.choice(num_actions, size=num_samples)\n",
    "        epsilons = np.random.normal(loc=0, scale=1, size=(num_samples, num_actions))\n",
    "        noisy_rewards_vectors = rewards_vectors + epsilons\n",
    "        noisy_rewards = noisy_rewards_vectors[np.arange(num_samples), actions]\n",
    "        \n",
    "        # Get local train-test split\n",
    "        (X_train, X_test,\n",
    "         A_train, A_test,\n",
    "         Y_train, Y_test,\n",
    "         true_costs_train, true_costs_test) = train_test_split(contexts, actions, noisy_rewards, -rewards_vectors,\n",
    "                                                               train_size=train_sizes[client_id],\n",
    "                                                               shuffle=False)\n",
    "\n",
    "        # Compute local AIPW scores\n",
    "        crossfit_map, mu, e = utils.cross_fit_nuisance_params(X_train, A_train, Y_train, num_actions)\n",
    "        AIPW_vectors = utils.compute_AIPW_scores(X_train, A_train, Y_train, num_actions, crossfit_map, mu, e)\n",
    "\n",
    "        # Convert local data to VW format\n",
    "        vw_data = utils.to_vw_format(X_train, A_train, -AIPW_vectors)\n",
    "\n",
    "        # Store local data\n",
    "        data[client_id] = vw_data\n",
    "        aux[client_id] = {\"X_train\": X_train, \"X_test\": X_test,\n",
    "                          \"A_train\": A_train, \"A_test\": A_test,\n",
    "                          \"Y_train\": Y_train, \"Y_test\": Y_test,\n",
    "                          \"true_costs_train\": true_costs_train, \"true_costs_test\": true_costs_test,\n",
    "                          \"weight\": weights[client_id]}\n",
    "    \n",
    "    return data, aux"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9a10076a-3421-491c-af90-98567a6236a9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "NUM_CLIENTS = 4\n",
    "NUM_ACTIONS = 4\n",
    "NUM_FEATURES = 10\n",
    "TRAIN_SIZES = np.array([1, 1, 1, 1]) * 250_000\n",
    "TEST_SIZES = np.array([1, 1, 1, 1]) * 10_000\n",
    "\n",
    "# Generate data\n",
    "data, aux = generate_observational_data(num_clients=NUM_CLIENTS,\n",
    "                                        num_actions=NUM_ACTIONS,\n",
    "                                        num_features=NUM_FEATURES,\n",
    "                                        train_sizes=TRAIN_SIZES,\n",
    "                                        test_sizes=TEST_SIZES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fa59c78d-1728-4151-a187-d50e6a956141",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "# myvar = {\"data\": data, \"aux\": aux}\n",
    "myvar = {\"local_regrets\": [local_regrets, local_regrets_std],\n",
    "         \"random_regrets\": [random_regrets, random_regrets_std],\n",
    "         \"global_regrets\": [global_regrets, global_regrets_std],\n",
    "         \"fed_local_regrets\": [fed_local_regrets, fed_local_regrets_std],\n",
    "         \"global_regrets_w\": [global_regrets_w, global_regrets_std_w],\n",
    "         \"fed_local_regrets_w\": [fed_local_regrets_w, fed_local_regrets_std_w],\n",
    "         \"opt_local_models\": opt_local_models,\n",
    "         \"opt_global_model\": opt_global_model,\n",
    "         \"opt_global_model_w\": opt_global_model_w\n",
    "        }\n",
    "  \n",
    "# Open a file and use dump()\n",
    "with open('regrets_real.pkl', 'wb') as file:\n",
    "      \n",
    "    # A new file will be created\n",
    "    pickle.dump(myvar, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "ad343b05-11d0-4981-a536-4468f6c2aab1",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "with open('regrets_real.pkl', 'rb') as file:\n",
    "      \n",
    "    # Call load method to deserialze\n",
    "    myvar = pickle.load(file)\n",
    "  \n",
    "    # data = myvar[\"data\"]\n",
    "    # aux = myvar[\"aux\"]\n",
    "    \n",
    "    local_regrets, local_regrets_std = myvar[\"local_regrets\"]\n",
    "    global_regrets, global_regrets_std = myvar[\"global_regrets\"]\n",
    "    fed_local_regrets, fed_local_regrets_std = myvar[\"fed_local_regrets\"]\n",
    "    global_regrets_w, global_regrets_std_w = myvar[\"global_regrets_w\"]\n",
    "    fed_local_regrets_w, fed_local_regrets_std_w = myvar[\"fed_local_regrets_w\"]\n",
    "    opt_local_models = myvar[\"opt_local_models\"]\n",
    "    opt_global_model = myvar[\"opt_global_model\"]\n",
    "    opt_global_model_w = myvar[\"opt_global_model_w\"]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "480eb501-70c5-4b1e-a230-7c263d05a812",
   "metadata": {},
   "source": [
    "### Train optimal local model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "330a9ebc-85b1-4cce-9cbd-6bbe5bd8e317",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Local Client 0: opt_reward=3.7227702743798887, reward=2.142277613211763, regret=1.5804926611681278\n",
      "Local Client 1: opt_reward=1.1194969650168611, reward=1.1183032915827245, regret=0.0011936734341359268\n",
      "Local Client 2: opt_reward=1.107564367317708, reward=1.1062942434462042, regret=0.0012701238715038016\n",
      "Local Client 3: opt_reward=1.1121557194196257, reward=1.1113904756888322, regret=0.000765243730793231\n"
     ]
    }
   ],
   "source": [
    "opt_local_models = {}\n",
    "for client_id in range(NUM_CLIENTS):\n",
    "    opt_local_model = VW(csoaa=NUM_ACTIONS,\n",
    "                         convert_to_vw=False,\n",
    "                         convert_labels=False,\n",
    "                         passes=1)\n",
    "    opt_local_model.fit(data[client_id])\n",
    "    opt_local_models[client_id] = opt_local_model\n",
    "\n",
    "    # Evaluate on test data\n",
    "    X_test_vw = utils.to_vw_format(aux[client_id][\"X_test\"])\n",
    "    regret, opt_reward, reward = utils.compute_regret(X_test_vw, aux[client_id][\"true_costs_test\"], opt_local_model)\n",
    "    print(f\"Local Client {client_id}: opt_reward={opt_reward}, reward={reward}, regret={regret}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bd178226-d706-4896-a925-9cc09b553cc0",
   "metadata": {},
   "source": [
    "### Train local model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3c403709-7da2-41c1-9121-394e98d78bd0",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def train_local_policy(train_data, sample_size):\n",
    "    assert len(train_data) >= sample_size\n",
    "    \n",
    "    # Train on local data\n",
    "    model = VW(csoaa=NUM_ACTIONS,\n",
    "               convert_to_vw=False,\n",
    "               convert_labels=False,\n",
    "               passes=1)\n",
    "    model.fit(random.sample(train_data, sample_size))\n",
    "    return model\n",
    "\n",
    "def eval_local_policy(X_test, true_costs, model, opt_model=None):\n",
    "    # Evaluate on test data\n",
    "    X_test_vw = utils.to_vw_format(X_test)\n",
    "    regret, opt_reward, reward = utils.compute_regret(X_test_vw, true_costs, model, opt_model)\n",
    "    return regret, opt_reward, reward\n",
    "\n",
    "def eval_random_policy(X_test, true_costs, opt_model=None):\n",
    "    # Create random policy and evaluate on test data\n",
    "    class Model():\n",
    "        def predict(self, X):\n",
    "            return np.random.choice(NUM_ACTIONS, size=len(X))\n",
    "        \n",
    "    X_test_vw = utils.to_vw_format(X_test)\n",
    "    regret, opt_reward, reward = utils.compute_regret(X_test_vw, true_costs, Model(), opt_model)\n",
    "    return regret, opt_reward, reward"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "dea28ad7-06c5-463a-bad1-45bf7246b293",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "ss_range = [10, 25, 50, 75, 100, 250, 500, 750, 1000, 2500, 5000, 7500, 10000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f1c53ab4-5ebd-4d1b-8c69-0962ec904c0c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def run_local_training_experiments(data, aux, client_id, opt_local_model, num_iters=3):\n",
    "    local_regrets_mean = []\n",
    "    local_regrets_std = []\n",
    "    random_regrets_mean = []\n",
    "    random_regrets_std = []\n",
    "    \n",
    "    for sample_size in tqdm(ss_range):\n",
    "        local_regret = 0\n",
    "        random_regret = 0\n",
    "        local_regret_iters = []\n",
    "        random_regret_iters = []\n",
    "        for i in range(num_iters):\n",
    "            local_model = train_local_policy(data[client_id], sample_size)\n",
    "            lr, _, _ = eval_local_policy(aux[client_id][\"X_test\"], aux[client_id][\"true_costs_test\"], local_model, opt_local_models[client_id])\n",
    "            rr, _, _ = eval_random_policy(aux[client_id][\"X_test\"], aux[client_id][\"true_costs_test\"], opt_local_models[client_id])\n",
    "            local_regret_iters.append(lr)\n",
    "            random_regret_iters.append(rr)\n",
    "        local_regrets_mean.append(np.mean(local_regret_iters))\n",
    "        local_regrets_std.append(np.std(local_regret_iters))\n",
    "        random_regrets_mean.append(np.mean(random_regret_iters))\n",
    "        random_regrets_std.append(np.std(random_regret_iters))\n",
    "        \n",
    "    return (np.array(local_regrets_mean),\n",
    "            np.array(local_regrets_std),\n",
    "            np.array(random_regrets_mean),\n",
    "            np.array(random_regrets_std))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "c8b39455-5aaa-42d2-ae95-4e13e9e7d2e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d71e94e48be7458ea78cd8a1b30683d1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/13 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "local_regrets = {}\n",
    "local_regrets_std = {}\n",
    "random_regrets = {}\n",
    "random_regrets_std = {}\n",
    "for client_id in range(NUM_CLIENTS):\n",
    "    local_regret, local_regret_std, random_regret, random_regret_std = run_local_training_experiments(data, aux, client_id, opt_local_models[client_id], num_iters=5)\n",
    "    local_regrets[client_id] = local_regret\n",
    "    local_regrets_std[client_id] = local_regret_std\n",
    "    random_regrets[client_id] = random_regret\n",
    "    random_regrets_std[client_id] = random_regret_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "b97a57d0-08ee-4dd9-8c4e-2309ba1b92c0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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gtNPPwM//ektOOWUIbFz/vznV/GXv7yKkydPYsKEMpx55kS8885beP31v6Ki4iguvfRiXHvtf2LVqr/AarVi+fKVkCQJTz75KD766B8Ih8MYM+Y0/OQnN2Hs2HHYsmUTbrrpPwEAl156cbu3vbqKMy5JEELA6HlbOxERpYwQAsGQnpUf6foX/5//vBIPPXQfLr74Erz00qu47robsXLly3jyyUcBAJqm4ec/vxFffrkX9923BM8++xJkWcHPf/5TaJqGP/95Jf74x+W44Yab8Oqrq7B48cM4ePAAHn98aZeuy+/345VXVmD//q9wwQWzY8cWLLgeum7g8cefxeOPP4OCgkJcd92PcPx4FQDgjTf+jGeeeQJXXz0fK1asRHn5WVi+/LkWr//ee2vw6KNP4fe/fwB5eXlYuPAmHD58EEuWPIpnn30J48dPwA03zMfu3TsxYUIZ7r33QQDAc8+9FHdLK9U445KkHrgnJRFRSgghsPiVLdh7pC4rX//U0gLc+YPylC7RFkLglVdewpw5l+H/+/8uAwCccsoQeDy1eOKJP+Caa36MHTs+x549u7Fy5esYMmQYAOCOOxZh5cqX4fHUYfDgU/DLX96D6dNnAABKSgbivPO+gb///b2krmXJksVYuvTB2HWFQiGMGnUqfvvb+2Ov/fe//w21tbW45557oarmR/ydd/4KW7duxltvvYn586/Hq6++jEsvvQLf+c5/AACuvtoMH7t27Yz7epdccimGDx8BANi06RNs2/YZ/vrX99GvXx9omoHrr78R27Z9ir/85U9YtOge5OebjQgLC4tgs9mTHeqEMbgkibmFiKgdPaytS21tDaqrT+KMM86MO15WVg5N03DgwH7s3bsHeXn5sdACAH369MWCBbcAAKZPn4Ht2z/HCy88g0OHDuLAga/w5Zf70K9f/6SuZf7863HuuTMRDofxj3+sxauvvoKLL74EM2c2FuXu2rULPp8X3/72eXHPDYVCOHBgP+rqalFZWYHTT5/Q7P1MbBFcSktPif16927zscsuu7jF6waDwaTeR1cxuCSJMy5ERK2TJAl3/aAcoXB26gCdDjXlexVF/85vPokT3WRQVVWoqtruLM9//ddLeOGFZzF79kWYOPEsfO97l+Pjjz9IuqC2qKg4FiaGD78OkiRhyZL7kZ9fELs1I4SBIUOG4v77H2nxfIfD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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "client_id = 0\n",
    "x = ss_range\n",
    "plt.plot(x, local_regrets[client_id], label='Local Regret')\n",
    "plt.fill_between(x, local_regrets[client_id] - local_regrets_std[client_id], local_regrets[client_id] + local_regrets_std[client_id], alpha=0.2)\n",
    "\n",
    "# plt.plot(x, random_regrets, label='Random Regret')\n",
    "# plt.fill_between(x, random_regrets - random_regrets_std, random_regrets + random_regrets_std, alpha=0.2)\n",
    "\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e707cc92-d187-42eb-a011-c6db96812415",
   "metadata": {},
   "source": [
    "### Train optimal global model (pooled)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "74efe0c1-cddb-4d5d-8c68-a92d4a5da267",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Aggregate: opt_reward=1.7654968315335184, reward=1.2552702595709626, regret=0.5102265719625689\n"
     ]
    }
   ],
   "source": [
    "# Aggregate all data\n",
    "X_train = []\n",
    "A_train = []\n",
    "Y_train = []\n",
    "true_costs_train = []\n",
    "true_costs_test = []\n",
    "X_test = []\n",
    "\n",
    "idx_to_weight_mapping = {}\n",
    "for client_id in range(NUM_CLIENTS):\n",
    "    lo = len(X_train)\n",
    "    X_train.extend(aux[client_id][\"X_train\"])\n",
    "    hi = len(X_train)\n",
    "    A_train.extend(aux[client_id][\"A_train\"])\n",
    "    Y_train.extend(aux[client_id][\"Y_train\"])\n",
    "    true_costs_train.extend(aux[client_id][\"true_costs_train\"])\n",
    "    true_costs_test.extend(aux[client_id][\"true_costs_test\"])\n",
    "    X_test.extend(aux[client_id][\"X_test\"])\n",
    "    idx_to_weight_mapping.update({i:1 for i in range(lo, len(X_train))})\n",
    "    \n",
    "X_train = np.array(X_train)\n",
    "A_train = np.array(A_train)\n",
    "Y_train = np.array(Y_train)\n",
    "true_costs_train = np.array(true_costs_train)\n",
    "true_costs_test = np.array(true_costs_test)\n",
    "X_test = np.array(X_test)\n",
    "\n",
    "# Compute AIPW scores\n",
    "crossfit_map, mu, e = utils.cross_fit_nuisance_params(X_train, A_train, Y_train, NUM_ACTIONS)\n",
    "noisy_costs_train = -utils.compute_AIPW_scores(X_train, A_train, Y_train, NUM_ACTIONS, crossfit_map, mu, e)\n",
    "data_train = utils.to_vw_format(X_train, A_train, noisy_costs_train, idx_to_weight_mapping)\n",
    "\n",
    "# Train model\n",
    "opt_global_model = VW(csoaa=NUM_ACTIONS,\n",
    "                      convert_to_vw=False,\n",
    "                      convert_labels=False,\n",
    "                      passes=1)\n",
    "opt_global_model.fit(data_train)\n",
    "\n",
    "# Evaluate on test data\n",
    "X_test_vw = utils.to_vw_format(X_test)\n",
    "regret, opt_reward, reward = utils.compute_regret(X_test_vw, true_costs_test, opt_global_model, opt_model=None, idx_to_weight_mapping=idx_to_weight_mapping)\n",
    "print(f\"Aggregate: opt_reward={opt_reward}, reward={reward}, regret={regret}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8fc5729e-42c9-421d-bec1-d40e1abd0f5f",
   "metadata": {},
   "source": [
    "### Train federated model (weighted)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "c3a4ce66-fd79-49df-b37f-0ec7002258c2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "NUM_ROUNDS = 1\n",
    "\n",
    "def run_federated_training_experiments(data, aux, sample_size_fns, num_iters=3):\n",
    "\n",
    "    local_regrets_mean = {k:[] for k in range(NUM_CLIENTS)}\n",
    "    local_regrets_std = {k:[] for k in range(NUM_CLIENTS)}\n",
    "    global_regrets_mean = []\n",
    "    global_regrets_std = []\n",
    "    for sample_size in tqdm(ss_range):\n",
    "        local_regrets_iters = {k:[] for k in range(NUM_CLIENTS)}\n",
    "        global_regret_iters = []\n",
    "        for i in tqdm(range(num_iters)):\n",
    "\n",
    "            # Subsample data\n",
    "            data_mod = {}\n",
    "            aux_mod = {}\n",
    "            client_weights = []\n",
    "            for client_id in range(NUM_CLIENTS):\n",
    "                client_sample_size = sample_size_fns[client_id](sample_size)\n",
    "                client_weights.append(client_sample_size)\n",
    "\n",
    "                data_mod[client_id] = random.sample(data[client_id], client_sample_size)\n",
    "                aux_mod[client_id] = {\"X_test\": aux[client_id][\"X_test\"],\n",
    "                                      \"true_costs_test\": aux[client_id][\"true_costs_test\"]}\n",
    "            client_weights = np.array(client_weights) / np.sum(client_weights)\n",
    "            \n",
    "            # Run federated learning\n",
    "            global_vw = server.run_federated_learning(data_mod, aux_mod,\n",
    "                                                      opt_global_model, opt_local_models,\n",
    "                                                      num_features=NUM_FEATURES,\n",
    "                                                      num_classes=NUM_ACTIONS,\n",
    "                                                      num_rounds=NUM_ROUNDS,\n",
    "                                                      num_clients=NUM_CLIENTS,\n",
    "                                                      client_weights=client_weights)\n",
    "\n",
    "            gr = global_vw.metrics_distributed[\"global_regret\"][-1][1]\n",
    "            global_regret_iters.append(gr)\n",
    "            \n",
    "            for client_id in range(NUM_CLIENTS):\n",
    "                lr = global_vw.metrics_distributed[\"local_regrets\"][-1][1][client_id]\n",
    "                local_regrets_iters[client_id].append(lr)\n",
    "\n",
    "        global_regrets_mean.append(np.mean(global_regret_iters))\n",
    "        global_regrets_std.append(np.std(global_regret_iters))\n",
    "        \n",
    "        for client_id in range(NUM_CLIENTS):\n",
    "            local_regrets_mean[client_id].append(np.mean(local_regrets_iters[client_id]))\n",
    "            local_regrets_std[client_id].append(np.std(local_regrets_iters[client_id]))\n",
    "            \n",
    "    global_regrets_mean = np.array(global_regrets_mean)\n",
    "    global_regrets_std = np.array(global_regrets_std)\n",
    "    for client_id in range(NUM_CLIENTS):\n",
    "        local_regrets_mean[client_id] = np.array(local_regrets_mean[client_id])\n",
    "        local_regrets_std[client_id] = np.array(local_regrets_std[client_id])\n",
    "        \n",
    "    return (global_regrets_mean, global_regrets_std,\n",
    "            local_regrets_mean, local_regrets_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "6ba1ed4a-a083-4a7b-8754-7a09ff92aa9a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b81e949e0bce488dbb3ecda46283655d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/13 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "284c5056c75241c8b6189d7a064bdada",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:51:34,529 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:51:41,938\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:51:43,506 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6581804647.0}\n",
      "INFO flwr 2023-05-15 11:51:43,507 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:51:43,508 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:51:45,098 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:51:45,099 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:51:45,099 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:51:45,100 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24683)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24683)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24683)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:51:46,467 | server.py:229 | fit_round 1 received 4 results and 0 failures\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24684)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24684)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24679)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24679)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24680)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24680)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING flwr 2023-05-15 11:51:46,491 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:51:46,493 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24680)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24679)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24683)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24684)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:51:47,749 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:51:47,750 | server.py:144 | FL finished in 2.649815650000164\n",
      "INFO flwr 2023-05-15 11:51:47,752 | app.py:202 | app_fit: losses_distributed [(1, 1.925205437699884)]\n",
      "INFO flwr 2023-05-15 11:51:47,753 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.255270259570951)], 'reward': [(1, -0.6699351781289329)], 'global_regret': [(1, 1.9252054376998844)], 'local_regrets': [(1, {0: 2.092898769048928, 1: 2.0302051336765206, 2: 2.031658813334728, 3: 2.003243620385081})]}\n",
      "INFO flwr 2023-05-15 11:51:47,755 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:51:47,756 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:51:47,762 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:51:55,611\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:51:57,102 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6654824858.0}\n",
      "INFO flwr 2023-05-15 11:51:57,104 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:51:57,105 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:51:58,173 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:51:58,174 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:51:58,174 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:51:58,175 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24703)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24703)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24703)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:51:59,420 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:51:59,442 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:51:59,444 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24706)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24706)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24700)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24700)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24707)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24707)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24703)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24706)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24700)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24707)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:00,638 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:52:00,639 | server.py:144 | FL finished in 2.4635794130008435\n",
      "INFO flwr 2023-05-15 11:52:00,640 | app.py:202 | app_fit: losses_distributed [(1, 1.779706476061506)]\n",
      "INFO flwr 2023-05-15 11:52:00,641 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.255270259570951)], 'reward': [(1, -0.5244362164905526)], 'global_regret': [(1, 1.779706476061506)], 'local_regrets': [(1, {0: 1.9929457972680016, 1: 1.8605582038510475, 2: 1.86066095275402, 3: 1.8618455360186745})]}\n",
      "INFO flwr 2023-05-15 11:52:00,642 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:52:00,643 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:52:00,650 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:52:07,055\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:52:08,613 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6680261018.0}\n",
      "INFO flwr 2023-05-15 11:52:08,615 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:52:08,617 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:09,717 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:09,718 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:52:09,719 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:52:09,719 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24724)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24724)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24724)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:10,919 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:52:10,941 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:52:10,944 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24729)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24729)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24727)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24727)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24726)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24726)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24724)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24729)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24727)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24726)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:12,134 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:52:12,135 | server.py:144 | FL finished in 2.416036862998226\n",
      "INFO flwr 2023-05-15 11:52:12,137 | app.py:202 | app_fit: losses_distributed [(1, 1.905427230047477)]\n",
      "INFO flwr 2023-05-15 11:52:12,138 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.255270259570951)], 'reward': [(1, -0.6501569704765281)], 'global_regret': [(1, 1.905427230047477)], 'local_regrets': [(1, {0: 2.01151001280262, 1: 1.9857670735451618, 2: 2.077754946902886, 3: 2.0038614725849633})]}\n",
      "INFO flwr 2023-05-15 11:52:12,139 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:52:12,140 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:52:12,146 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:52:19,232\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:52:20,745 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6652826829.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:52:20,746 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:52:20,746 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:21,765 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:21,766 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:52:21,767 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:52:21,768 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24748)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24748)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24748)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:23,053 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:52:23,076 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:52:23,078 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24746)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24746)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24747)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24747)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24749)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24749)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24748)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24746)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24747)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24749)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:24,245 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:52:24,245 | server.py:144 | FL finished in 2.477462081998965\n",
      "INFO flwr 2023-05-15 11:52:24,247 | app.py:202 | app_fit: losses_distributed [(1, 1.670886379666112)]\n",
      "INFO flwr 2023-05-15 11:52:24,248 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.255270259570951)], 'reward': [(1, -0.4156161200951616)], 'global_regret': [(1, 1.670886379666112)], 'local_regrets': [(1, {0: 1.7649451238521066, 1: 1.8631117374447803, 2: 1.7509845209859511, 3: 1.7616887220273323})]}\n",
      "INFO flwr 2023-05-15 11:52:24,249 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:52:24,250 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:52:24,256 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:52:30,966\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:52:32,395 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6655517901.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 11:52:32,396 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:52:32,396 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:33,445 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:33,446 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:52:33,446 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:52:33,447 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24773)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24773)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24773)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:34,658 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:52:34,676 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:52:34,678 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24768)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24768)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24774)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24774)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24771)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24771)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24773)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24768)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24774)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24771)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:35,850 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:52:35,851 | server.py:144 | FL finished in 2.40441044399995\n",
      "INFO flwr 2023-05-15 11:52:35,853 | app.py:202 | app_fit: losses_distributed [(1, 1.6469888399524104)]\n",
      "INFO flwr 2023-05-15 11:52:35,854 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.255270259570951)], 'reward': [(1, -0.3917185803814595)], 'global_regret': [(1, 1.6469888399524104)], 'local_regrets': [(1, {0: 1.7413326814349344, 1: 1.7449862449454714, 2: 1.7625332347033373, 3: 1.7962877843716167})]}\n",
      "INFO flwr 2023-05-15 11:52:35,855 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:52:35,856 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4f82d3dc1edd44079fc6bb6f8ed9e217",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:52:35,929 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:52:42,571\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:52:44,111 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6658883584.0}\n",
      "INFO flwr 2023-05-15 11:52:44,112 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:52:44,113 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:45,193 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:45,194 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:52:45,194 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:52:45,195 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24796)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24796)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24796)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:46,403 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:52:46,423 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:52:46,425 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24795)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24795)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24794)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24794)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24793)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24793)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24796)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24795)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24794)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24793)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:47,569 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:52:47,570 | server.py:144 | FL finished in 2.3752760650004348\n",
      "INFO flwr 2023-05-15 11:52:47,572 | app.py:202 | app_fit: losses_distributed [(1, 0.8524075806209719)]\n",
      "INFO flwr 2023-05-15 11:52:47,573 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.277957568382062)], 'reward': [(1, 0.4276845037383568)], 'global_regret': [(1, 0.8502730646437048)], 'local_regrets': [(1, {0: 0.864371561363017, 1: 0.8424827876713618, 2: 1.332915007158972, 3: 0.8270455519362524})]}\n",
      "INFO flwr 2023-05-15 11:52:47,574 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:52:47,575 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:52:47,583 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:52:54,404\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:52:55,865 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6652789965.0}\n",
      "INFO flwr 2023-05-15 11:52:55,866 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:52:55,867 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:56,953 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:52:56,954 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:52:56,954 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:52:56,955 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24818)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24818)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24818)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:58,174 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:52:58,194 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:52:58,196 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24815)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24815)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24816)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24816)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24814)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24814)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24818)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24815)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24816)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24814)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:52:59,402 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:52:59,403 | server.py:144 | FL finished in 2.448362492999877\n",
      "INFO flwr 2023-05-15 11:52:59,405 | app.py:202 | app_fit: losses_distributed [(1, 0.9352634986208112)]\n",
      "INFO flwr 2023-05-15 11:52:59,406 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.279183353177099)], 'reward': [(1, 0.3472575766140241)], 'global_regret': [(1, 0.9319257765630766)], 'local_regrets': [(1, {0: 0.9548886087219863, 1: 1.0007439521866464, 2: 0.9687271067091222, 3: 1.2738789125111996})]}\n",
      "INFO flwr 2023-05-15 11:52:59,408 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:52:59,409 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:52:59,416 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:53:05,160\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:53:06,815 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6656723354.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:53:06,816 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:53:06,817 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:07,931 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:07,932 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:53:07,933 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:53:07,933 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24839)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24839)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24839)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:09,122 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:53:09,141 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:53:09,143 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24835)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24835)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24840)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24840)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24838)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24838)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24839)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24835)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24840)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24838)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:10,311 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:53:10,312 | server.py:144 | FL finished in 2.37907062100021\n",
      "INFO flwr 2023-05-15 11:53:10,314 | app.py:202 | app_fit: losses_distributed [(1, 0.9858596773074584)]\n",
      "INFO flwr 2023-05-15 11:53:10,315 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.279942320010338)], 'reward': [(1, 0.29551669791996793)], 'global_regret': [(1, 0.9844256220903702)], 'local_regrets': [(1, {0: 0.9935203551215606, 1: 1.4747016224608385, 2: 0.9838602596591647, 3: 0.9485410576339774})]}\n",
      "INFO flwr 2023-05-15 11:53:10,315 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:53:10,316 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:53:10,323 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:53:16,952\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:53:18,393 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6655683789.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 11:53:18,395 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:53:18,395 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:19,470 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:19,471 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:53:19,472 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:53:19,473 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24860)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24860)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24860)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:20,709 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:53:20,729 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:53:20,731 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24862)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24862)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24859)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24859)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24861)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24861)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24860)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24862)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24859)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24861)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:21,974 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:53:21,975 | server.py:144 | FL finished in 2.5028237759997864\n",
      "INFO flwr 2023-05-15 11:53:21,977 | app.py:202 | app_fit: losses_distributed [(1, 1.017949459152409)]\n",
      "INFO flwr 2023-05-15 11:53:21,978 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.277957568382062)], 'reward': [(1, 0.27455536674504366)], 'global_regret': [(1, 1.0034022016370208)], 'local_regrets': [(1, {0: 1.1043898891231794, 1: 1.2177767448950048, 2: 1.1139164050680157, 3: 1.0928993831691474})]}\n",
      "INFO flwr 2023-05-15 11:53:21,978 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:53:21,979 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:53:21,986 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:53:27,665\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:53:29,225 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6653873767.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 11:53:29,226 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:53:29,226 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:30,330 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:30,331 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:53:30,331 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:53:30,332 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24878)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24878)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24878)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:31,591 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:53:31,613 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:53:31,615 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24883)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24883)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24884)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24884)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24880)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24880)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24878)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24883)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24884)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24880)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:32,883 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:53:32,884 | server.py:144 | FL finished in 2.55207376099861\n",
      "INFO flwr 2023-05-15 11:53:32,886 | app.py:202 | app_fit: losses_distributed [(1, 0.843862946076831)]\n",
      "INFO flwr 2023-05-15 11:53:32,887 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1839977967143054)], 'reward': [(1, 0.3133721258020298)], 'global_regret': [(1, 0.8706256709122762)], 'local_regrets': [(1, {0: 1.1426591735650917, 1: 0.9083774592971571, 2: 0.8748492995022894, 3: 0.9067504375885004})]}\n",
      "INFO flwr 2023-05-15 11:53:32,888 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:53:32,889 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef5cf01fbad44f9fac8c2aa1b2bd374c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:53:32,981 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:53:38,583\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:53:39,991 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6666650829.0}\n",
      "INFO flwr 2023-05-15 11:53:39,993 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:53:39,994 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:41,065 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:41,066 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:53:41,067 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:53:41,068 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24908)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24908)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24908)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:42,542 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:53:42,566 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:53:42,568 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24906)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24906)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24905)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24905)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24907)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24907)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24908)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24906)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24905)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24907)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:43,975 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:53:43,976 | server.py:144 | FL finished in 2.9087474970001495\n",
      "INFO flwr 2023-05-15 11:53:43,978 | app.py:202 | app_fit: losses_distributed [(1, 0.45957403236786404)]\n",
      "INFO flwr 2023-05-15 11:53:43,980 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2893012227876177)], 'reward': [(1, 0.8409463806722819)], 'global_regret': [(1, 0.44835484211533627)], 'local_regrets': [(1, {0: 0.5036076782564165, 1: 0.49810123053845734, 2: 0.4963708882560745, 3: 0.7974009180662222})]}\n",
      "INFO flwr 2023-05-15 11:53:43,981 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:53:43,982 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:53:43,989 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:53:50,087\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:53:51,499 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6632212480.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 11:53:51,501 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:53:51,502 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:52,585 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:53:52,586 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:53:52,587 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:53:52,588 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24924)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24924)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24924)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:53,809 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:53:53,831 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:53:53,833 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24925)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24925)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24930)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24930)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24926)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24926)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24924)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24926)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24925)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24930)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:53:55,262 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:53:55,262 | server.py:144 | FL finished in 2.674632047999694\n",
      "INFO flwr 2023-05-15 11:53:55,264 | app.py:202 | app_fit: losses_distributed [(1, 0.6348926682054845)]\n",
      "INFO flwr 2023-05-15 11:53:55,265 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1483615652859824)], 'reward': [(1, 0.5358788223491235)], 'global_regret': [(1, 0.6124827429368593)], 'local_regrets': [(1, {0: 1.183904945780914, 1: 0.6201706972368701, 2: 0.5884455227271054, 3: 0.6042340927227604})]}\n",
      "INFO flwr 2023-05-15 11:53:55,267 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:53:55,268 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:53:55,275 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:54:01,796\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:54:03,331 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6611771392.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:54:03,332 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:54:03,333 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:54:04,551 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:54:04,552 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:54:04,553 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:54:04,554 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24950)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24950)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24950)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:54:06,111 | server.py:229 | fit_round 1 received 4 results and 0 failures\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24951)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24951)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24953)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24953)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24947)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24947)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING flwr 2023-05-15 11:54:06,135 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:54:06,137 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24950)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24951)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24953)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24947)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:54:07,904 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:54:07,905 | server.py:144 | FL finished in 3.3517191409991938\n",
      "INFO flwr 2023-05-15 11:54:07,908 | app.py:202 | app_fit: losses_distributed [(1, 0.863839342279238)]\n",
      "INFO flwr 2023-05-15 11:54:07,909 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.292278350230031)], 'reward': [(1, 0.4237480103989591)], 'global_regret': [(1, 0.8685303398310729)], 'local_regrets': [(1, {0: 0.8441316985834711, 1: 0.8608731314959567, 2: 0.8410570973609376, 3: 1.3664800273223028})]}\n",
      "INFO flwr 2023-05-15 11:54:07,911 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:54:07,912 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:54:07,921 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:54:13,884\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:54:17,118 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6602894541.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 11:54:17,120 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:54:17,122 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:54:18,937 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:54:18,939 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:54:18,940 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:54:18,941 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24969)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24969)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24969)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24972)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24972)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24973)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24973)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24975)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24975)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:54:21,199 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:54:21,231 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:54:21,234 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24969)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24972)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24973)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24975)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:54:24,362 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:54:24,364 | server.py:144 | FL finished in 5.42297008100104\n",
      "INFO flwr 2023-05-15 11:54:24,367 | app.py:202 | app_fit: losses_distributed [(1, 0.839299631095077)]\n",
      "INFO flwr 2023-05-15 11:54:24,369 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2893012227876177)], 'reward': [(1, 0.4779459439312981)], 'global_regret': [(1, 0.8113552788563203)], 'local_regrets': [(1, {0: 0.9502339249285436, 1: 0.9381559376541183, 2: 0.9317096980260516, 3: 0.9942835494173032})]}\n",
      "INFO flwr 2023-05-15 11:54:24,372 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:54:24,374 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:54:24,391 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:54:33,155\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:54:38,545 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6602828186.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:54:38,550 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:54:38,562 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=24997)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:54:46,705 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:54:46,708 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:54:46,723 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:54:46,741 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=24997)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24997)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24995)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24995)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24999)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24999)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24994)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=24994)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:55:11,776 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:55:12,013 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:55:12,045 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24997)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24999)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24994)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=24995)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:55:50,884 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:55:50,888 | server.py:144 | FL finished in 64.14873457000067\n",
      "INFO flwr 2023-05-15 11:55:50,921 | app.py:202 | app_fit: losses_distributed [(1, 0.5597706472546734)]\n",
      "INFO flwr 2023-05-15 11:55:50,936 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.292278350230031)], 'reward': [(1, 0.7526523206788385)], 'global_regret': [(1, 0.5396260295511928)], 'local_regrets': [(1, {0: 0.6394054645801688, 1: 0.7570974461643354, 2: 0.6402313983585292, 3: 0.6595328655613738})]}\n",
      "INFO flwr 2023-05-15 11:55:50,951 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:55:50,954 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3ec66969a7e24904ad69815829f29123",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:55:52,309 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:56:21,602\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:56:44,804 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6660118528.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 11:56:44,819 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:56:44,838 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25038)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:57:03,568 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:57:03,584 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:57:03,597 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:57:03,600 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25038)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25038)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25034)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25034)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25037)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25037)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25032)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25032)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:57:18,479 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:57:18,611 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:57:18,616 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25038)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25034)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25032)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25037)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:57:28,165 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:57:28,167 | server.py:144 | FL finished in 24.568136728001264\n",
      "INFO flwr 2023-05-15 11:57:28,182 | app.py:202 | app_fit: losses_distributed [(1, 0.314724632639608)]\n",
      "INFO flwr 2023-05-15 11:57:28,184 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1439680573016686)], 'reward': [(1, 0.8149309634200401)], 'global_regret': [(1, 0.32903709388163016)], 'local_regrets': [(1, {0: 0.7191072264738232, 1: 0.32328154051370694, 2: 0.3412983332056717, 3: 0.33239601601094526})]}\n",
      "INFO flwr 2023-05-15 11:57:28,187 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:57:28,192 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:57:28,236 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:57:40,709\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:57:45,414 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6650253722.0}\n",
      "INFO flwr 2023-05-15 11:57:45,420 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:57:45,424 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25068)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:57:49,164 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:57:49,166 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:57:49,169 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:57:49,172 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25068)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25068)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25063)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25063)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25065)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25065)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25066)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25066)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:57:53,477 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:57:53,535 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:57:53,539 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25068)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25063)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25065)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25066)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:57:58,776 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:57:58,779 | server.py:144 | FL finished in 9.606980757000201\n",
      "INFO flwr 2023-05-15 11:57:58,784 | app.py:202 | app_fit: losses_distributed [(1, 0.16312779298316699)]\n",
      "INFO flwr 2023-05-15 11:57:58,787 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.290699755522549)], 'reward': [(1, 1.1327801484383002)], 'global_regret': [(1, 0.15791960708424987)], 'local_regrets': [(1, {0: 0.18229507631534222, 1: 0.5532313131522023, 2: 0.19043518656969016, 3: 0.18373418154114743})]}\n",
      "INFO flwr 2023-05-15 11:57:58,791 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:57:58,795 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:57:58,825 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:58:08,569\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:58:12,655 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6648052941.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 11:58:12,658 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:58:12,661 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25091)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:58:15,421 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:58:15,423 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:58:15,425 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:58:15,427 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25091)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25091)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25087)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25087)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25092)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25092)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25088)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25088)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:58:18,725 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:58:18,771 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:58:18,775 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25091)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25087)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25092)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25088)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:58:22,544 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:58:22,546 | server.py:144 | FL finished in 7.118865161999565\n",
      "INFO flwr 2023-05-15 11:58:22,550 | app.py:202 | app_fit: losses_distributed [(1, 0.23095414097715847)]\n",
      "INFO flwr 2023-05-15 11:58:22,554 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.290699755522549)], 'reward': [(1, 1.0609321795821123)], 'global_regret': [(1, 0.22976757594043778)], 'local_regrets': [(1, {0: 0.23466993362826374, 1: 0.6603644865580109, 2: 0.24111061796563357, 3: 0.24485611140244004})]}\n",
      "INFO flwr 2023-05-15 11:58:22,556 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:58:22,559 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:58:22,577 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:58:31,412\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:58:35,126 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6666625024.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 11:58:35,128 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:58:35,130 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25114)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:58:37,737 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:58:37,739 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:58:37,741 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:58:37,743 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25114)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25114)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25113)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25113)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25110)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25110)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25115)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25115)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:58:40,877 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:58:40,916 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:58:40,919 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25114)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25110)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25113)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25115)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:58:44,148 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:58:44,150 | server.py:144 | FL finished in 6.4075012339999375\n",
      "INFO flwr 2023-05-15 11:58:44,154 | app.py:202 | app_fit: losses_distributed [(1, 0.13416789786561398)]\n",
      "INFO flwr 2023-05-15 11:58:44,156 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1439680573016686)], 'reward': [(1, 0.987243403115617)], 'global_regret': [(1, 0.1567246541860516)], 'local_regrets': [(1, {0: 0.5068750421880234, 1: 0.1628781804913418, 2: 0.1566251440614304, 3: 0.16747781036737608})]}\n",
      "INFO flwr 2023-05-15 11:58:44,158 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:58:44,160 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:58:44,173 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:58:52,596\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:58:56,179 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6657814528.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:58:56,181 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:58:56,183 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25135)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:58:58,437 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:58:58,439 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:58:58,440 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:58:58,442 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25135)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25135)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25139)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25139)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25141)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25141)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25138)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25138)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:01,088 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:59:01,126 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:59:01,130 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25135)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25139)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25141)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25138)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:04,232 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:59:04,233 | server.py:144 | FL finished in 5.791357853999216\n",
      "INFO flwr 2023-05-15 11:59:04,237 | app.py:202 | app_fit: losses_distributed [(1, 0.3583607687073662)]\n",
      "INFO flwr 2023-05-15 11:59:04,239 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2926139947915107)], 'reward': [(1, 0.9269827253674823)], 'global_regret': [(1, 0.36563126942402924)], 'local_regrets': [(1, {0: 0.3300255173928512, 1: 0.8932641575352988, 2: 0.3294206009213038, 3: 0.3379173846257234})]}\n",
      "INFO flwr 2023-05-15 11:59:04,241 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:59:04,243 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b7136d2e0a044094a0ad9348be66c30e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:59:04,396 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:59:13,420\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:59:16,986 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6644038452.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:59:16,988 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:59:16,990 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25163)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:59:19,159 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:59:19,161 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:59:19,162 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:59:19,164 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25163)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25163)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25168)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25168)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25166)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25166)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25167)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25167)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:21,786 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:59:21,832 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:59:21,835 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25163)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25168)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25166)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25167)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:24,873 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:59:24,875 | server.py:144 | FL finished in 5.711339397999836\n",
      "INFO flwr 2023-05-15 11:59:24,878 | app.py:202 | app_fit: losses_distributed [(1, 0.4351856322099051)]\n",
      "INFO flwr 2023-05-15 11:59:24,880 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2933849383736176)], 'reward': [(1, 0.8763189833261473)], 'global_regret': [(1, 0.41706595504746957)], 'local_regrets': [(1, {0: 0.4990556498113301, 1: 0.49940344334228737, 2: 0.49858828326142085, 3: 0.7008797380702952})]}\n",
      "INFO flwr 2023-05-15 11:59:24,882 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:59:24,883 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:59:24,900 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:59:33,065\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:59:36,453 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6643091047.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 11:59:36,455 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:59:36,456 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25189)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:59:38,466 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:59:38,467 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:59:38,469 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:59:38,470 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25189)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25189)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:40,816 | server.py:229 | fit_round 1 received 4 results and 0 failures\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25194)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25194)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25195)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25195)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25196)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25196)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING flwr 2023-05-15 11:59:40,851 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:59:40,853 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25189)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25194)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25195)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25196)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:43,762 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 11:59:43,763 | server.py:144 | FL finished in 5.293176703000427\n",
      "INFO flwr 2023-05-15 11:59:43,767 | app.py:202 | app_fit: losses_distributed [(1, 0.2616386041029983)]\n",
      "INFO flwr 2023-05-15 11:59:43,769 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2954442568292797)], 'reward': [(1, 1.0313981778153516)], 'global_regret': [(1, 0.26404607901392924)], 'local_regrets': [(1, {0: 0.2526392571758707, 1: 0.2529967388677406, 2: 0.25336745764514884, 3: 0.7447355483689468})]}\n",
      "INFO flwr 2023-05-15 11:59:43,771 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 11:59:43,773 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 11:59:43,791 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 11:59:51,112\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 11:59:54,686 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6657818215.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 11:59:54,688 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 11:59:54,689 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25212)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 11:59:56,928 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 11:59:56,930 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 11:59:56,932 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 11:59:56,934 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25212)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25212)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25213)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25213)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25218)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25218)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25217)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25217)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 11:59:59,308 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 11:59:59,341 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 11:59:59,344 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25212)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25213)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25218)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25217)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:00:02,274 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:00:02,275 | server.py:144 | FL finished in 5.341992994000975\n",
      "INFO flwr 2023-05-15 12:00:02,278 | app.py:202 | app_fit: losses_distributed [(1, 0.38655492782097944)]\n",
      "INFO flwr 2023-05-15 12:00:02,281 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2967193211091206)], 'reward': [(1, 0.9337401934213903)], 'global_regret': [(1, 0.36297912768773105)], 'local_regrets': [(1, {0: 0.4698105605227249, 1: 0.6203010197562264, 2: 0.4501232238242549, 3: 0.46316949282642716})]}\n",
      "INFO flwr 2023-05-15 12:00:02,283 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:00:02,285 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:00:02,301 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:00:10,890\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:00:14,467 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6646312960.0}\n",
      "INFO flwr 2023-05-15 12:00:14,469 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:00:14,470 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25246)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:00:16,608 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:00:16,610 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:00:16,611 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:00:16,613 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25246)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25246)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25248)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25248)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25247)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25247)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25251)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25251)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:00:19,103 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:00:19,138 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:00:19,141 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25246)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25248)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25247)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25251)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:00:22,154 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:00:22,156 | server.py:144 | FL finished in 5.543380381999668\n",
      "INFO flwr 2023-05-15 12:00:22,159 | app.py:202 | app_fit: losses_distributed [(1, 0.36817154248286)]\n",
      "INFO flwr 2023-05-15 12:00:22,161 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2954442568292797)], 'reward': [(1, 0.9423695123055074)], 'global_regret': [(1, 0.35307474452377335)], 'local_regrets': [(1, {0: 0.42168745580579564, 1: 0.6707865330516457, 2: 0.4229646135617306, 3: 0.41443215315798315})]}\n",
      "INFO flwr 2023-05-15 12:00:22,163 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:00:22,165 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:00:22,179 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:00:29,180\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:00:32,854 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6650806682.0}\n",
      "INFO flwr 2023-05-15 12:00:32,857 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:00:32,859 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25275)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:00:35,450 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:00:35,452 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:00:35,453 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:00:35,455 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25275)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25275)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25269)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25269)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25274)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25274)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25272)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25272)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:00:38,436 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:00:38,474 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:00:38,478 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25275)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25269)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25274)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25272)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:00:42,091 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:00:42,093 | server.py:144 | FL finished in 6.638293505999172\n",
      "INFO flwr 2023-05-15 12:00:42,098 | app.py:202 | app_fit: losses_distributed [(1, 0.32705623859254446)]\n",
      "INFO flwr 2023-05-15 12:00:42,100 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1355325219717862)], 'reward': [(1, 0.8468600302291739)], 'global_regret': [(1, 0.2886724917426146)], 'local_regrets': [(1, {0: 0.9235136252717959, 1: 0.28517651341417094, 2: 0.27602522790907164, 3: 0.28069417342085284})]}\n",
      "INFO flwr 2023-05-15 12:00:42,102 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:00:42,106 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "33d0e3e90efd495fa491a2342d78b7d5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:00:42,292 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:00:52,125\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:00:56,085 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6642840372.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:00:56,088 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:00:56,094 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25295)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:00:59,223 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:00:59,225 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:00:59,227 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:00:59,229 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25295)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25295)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25296)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25296)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25299)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25299)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25300)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25300)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:01:02,847 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:01:02,894 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:01:02,898 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25295)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25296)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25299)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25300)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:01:07,684 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:01:07,686 | server.py:144 | FL finished in 8.45792949800125\n",
      "INFO flwr 2023-05-15 12:01:07,689 | app.py:202 | app_fit: losses_distributed [(1, 0.22153578867497148)]\n",
      "INFO flwr 2023-05-15 12:01:07,691 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.29923949620161)], 'reward': [(1, 1.0786938612502526)], 'global_regret': [(1, 0.2205456349513584)], 'local_regrets': [(1, {0: 0.22436559436995154, 1: 0.2343495206491863, 2: 0.6574114766634076, 3: 0.22720114866305488})]}\n",
      "INFO flwr 2023-05-15 12:01:07,694 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:01:07,696 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:01:07,726 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:01:17,530\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:01:21,776 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6650939392.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:01:21,779 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:01:21,784 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25318)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:01:25,195 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:01:25,197 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:01:25,199 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:01:25,203 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25318)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25318)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25323)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25323)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25321)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25321)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25325)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25325)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:01:29,507 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:01:29,561 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:01:29,566 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25318)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25323)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25321)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25325)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:01:34,492 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:01:34,494 | server.py:144 | FL finished in 9.29163581300054\n",
      "INFO flwr 2023-05-15 12:01:34,497 | app.py:202 | app_fit: losses_distributed [(1, 0.12456612628821888)]\n",
      "INFO flwr 2023-05-15 12:01:34,500 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.29923949620161)], 'reward': [(1, 1.178889612903434)], 'global_regret': [(1, 0.1203498832981767)], 'local_regrets': [(1, {0: 0.13792317064207293, 1: 0.5555548841479092, 2: 0.1262455443074298, 3: 0.13572549170117854})]}\n",
      "INFO flwr 2023-05-15 12:01:34,503 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:01:34,506 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:01:34,536 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:01:44,796\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:01:49,416 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6654408295.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:01:49,423 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:01:49,426 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25345)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:01:52,849 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:01:52,851 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:01:52,854 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:01:52,857 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25345)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25345)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25342)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25342)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25347)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25347)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25348)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25348)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:01:57,098 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:01:57,151 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:01:57,156 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25345)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25342)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25347)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25348)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:02:02,357 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:02:02,359 | server.py:144 | FL finished in 9.502912469999501\n",
      "INFO flwr 2023-05-15 12:02:02,362 | app.py:202 | app_fit: losses_distributed [(1, 0.1606983124661727)]\n",
      "INFO flwr 2023-05-15 12:02:02,365 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3006350158627265)], 'reward': [(1, 1.1401476656005864)], 'global_regret': [(1, 0.16048735026214073)], 'local_regrets': [(1, {0: 0.16044306195932342, 1: 0.17204383269240237, 2: 0.1720670718574504, 3: 0.5954238690012278})]}\n",
      "INFO flwr 2023-05-15 12:02:02,367 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:02:02,370 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:02:02,403 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:02:12,041\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:02:16,123 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6616051303.0}\n",
      "INFO flwr 2023-05-15 12:02:16,127 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:02:16,129 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25371)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:02:18,981 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:02:18,983 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:02:18,985 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:02:18,988 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25371)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25371)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25368)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25368)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25373)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25373)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25375)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25375)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:02:22,469 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:02:22,511 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:02:22,515 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25371)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25368)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25373)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25375)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:02:25,975 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:02:25,976 | server.py:144 | FL finished in 6.988945368000714\n",
      "INFO flwr 2023-05-15 12:02:25,979 | app.py:202 | app_fit: losses_distributed [(1, 0.18314693316554512)]\n",
      "INFO flwr 2023-05-15 12:02:25,981 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.29923949620161)], 'reward': [(1, 1.1150130178705977)], 'global_regret': [(1, 0.18422647833101266)], 'local_regrets': [(1, {0: 0.1792229845908936, 1: 0.19390393689497792, 2: 0.6302414108490044, 3: 0.186403985973018})]}\n",
      "INFO flwr 2023-05-15 12:02:25,984 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:02:25,986 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:02:26,015 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:02:33,824\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:02:37,687 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6606890599.0}\n",
      "INFO flwr 2023-05-15 12:02:37,689 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:02:37,690 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25397)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:02:40,084 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:02:40,085 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:02:40,087 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:02:40,089 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25397)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25397)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25398)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25398)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25391)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25391)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25393)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25393)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:02:42,937 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:02:42,974 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:02:42,977 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25397)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25393)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25398)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25391)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:02:45,889 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:02:45,891 | server.py:144 | FL finished in 5.802349379999214\n",
      "INFO flwr 2023-05-15 12:02:45,894 | app.py:202 | app_fit: losses_distributed [(1, 0.14377944367523202)]\n",
      "INFO flwr 2023-05-15 12:02:45,896 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2969856338365422)], 'reward': [(1, 1.1505928446689184)], 'global_regret': [(1, 0.14639278916762444)], 'local_regrets': [(1, {0: 0.1344085695784978, 1: 0.628646515451706, 2: 0.13452404036228788, 3: 0.13472323495415017})]}\n",
      "INFO flwr 2023-05-15 12:02:45,898 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:02:45,900 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "11a3807a5af34f0a92c2766df5ddaa69",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:02:46,062 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:02:54,947\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:02:58,312 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6615067034.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:02:58,314 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:02:58,316 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25418)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:03:00,380 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:03:00,381 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:03:00,382 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:03:00,384 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25418)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25418)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25420)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25420)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25419)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25419)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25421)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25421)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:03:02,862 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:03:02,895 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:03:02,898 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25421)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25418)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25420)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25419)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:03:05,482 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:03:05,483 | server.py:144 | FL finished in 5.09976604700023\n",
      "INFO flwr 2023-05-15 12:03:05,485 | app.py:202 | app_fit: losses_distributed [(1, 0.06070370969037641)]\n",
      "INFO flwr 2023-05-15 12:03:05,486 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3022363505278558)], 'reward': [(1, 1.2469162506873743)], 'global_regret': [(1, 0.05532009984048138)], 'local_regrets': [(1, {0: 0.07672864927313705, 1: 0.46103399466054407, 2: 0.08338613268132393, 3: 0.07885064779221491})]}\n",
      "INFO flwr 2023-05-15 12:03:05,488 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:03:05,490 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:03:05,513 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:03:12,404\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:03:15,970 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6608774349.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:03:15,973 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:03:15,975 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25445)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:03:18,087 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:03:18,088 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:03:18,090 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:03:18,091 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25445)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25445)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25438)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25438)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25440)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25440)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25439)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25439)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:03:20,417 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:03:20,451 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:03:20,455 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25445)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25438)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25440)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25439)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:03:23,650 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:03:23,652 | server.py:144 | FL finished in 5.561242653999216\n",
      "INFO flwr 2023-05-15 12:03:23,655 | app.py:202 | app_fit: losses_distributed [(1, 0.07756093851053242)]\n",
      "INFO flwr 2023-05-15 12:03:23,658 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.298458148633066)], 'reward': [(1, 1.2214224666590752)], 'global_regret': [(1, 0.07703568197399045)], 'local_regrets': [(1, {0: 0.0783733788016186, 1: 0.5395677556831046, 2: 0.07310044004247357, 3: 0.07638676516064705})]}\n",
      "INFO flwr 2023-05-15 12:03:23,659 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:03:23,661 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:03:23,686 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:03:32,663\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:03:36,170 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6603948852.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:03:36,172 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:03:36,174 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:03:38,259 | server.py:274 | Received initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25466)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:03:38,261 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:03:38,262 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:03:38,264 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25466)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25466)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25467)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25467)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25463)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25463)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25464)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25464)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:03:40,586 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:03:40,619 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:03:40,622 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25466)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25467)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25463)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25464)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:03:43,968 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:03:43,970 | server.py:144 | FL finished in 5.706050741999206\n",
      "INFO flwr 2023-05-15 12:03:43,973 | app.py:202 | app_fit: losses_distributed [(1, 0.06663250318143794)]\n",
      "INFO flwr 2023-05-15 12:03:43,975 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3022363505278558)], 'reward': [(1, 1.2376844298846648)], 'global_regret': [(1, 0.06455192064319289)], 'local_regrets': [(1, {0: 0.0722466351616562, 1: 0.07485478576191718, 2: 0.5040488114644673, 3: 0.07256436598342549})]}\n",
      "INFO flwr 2023-05-15 12:03:43,977 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:03:43,980 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:03:44,006 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:03:51,992\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:03:55,703 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6600590541.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:03:55,706 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:03:55,709 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25491)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:03:58,058 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:03:58,060 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:03:58,062 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:03:58,064 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25491)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25491)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25492)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25492)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25493)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25493)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25489)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25489)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:04:00,781 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:04:00,819 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:04:00,823 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25491)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25492)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25493)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25489)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:04:04,346 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:04:04,348 | server.py:144 | FL finished in 6.285001947000637\n",
      "INFO flwr 2023-05-15 12:04:04,351 | app.py:202 | app_fit: losses_distributed [(1, 0.06119165084286133)]\n",
      "INFO flwr 2023-05-15 12:04:04,355 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.119594968831794)], 'reward': [(1, 1.053970497524083)], 'global_regret': [(1, 0.06562447130771148)], 'local_regrets': [(1, {0: 0.5065924261317974, 1: 0.06473674842602446, 2: 0.06238257982587864, 3: 0.06823943463345974})]}\n",
      "INFO flwr 2023-05-15 12:04:04,359 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:04:04,367 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:04:04,442 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:04:14,042\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:04:18,326 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6589689856.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:04:18,329 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:04:18,331 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25523)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:04:21,403 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:04:21,405 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:04:21,407 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:04:21,410 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25523)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25523)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25521)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25521)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25519)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25519)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25522)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25522)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:04:25,084 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:04:25,142 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:04:25,146 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25523)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25521)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25519)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25522)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:04:30,016 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:04:30,018 | server.py:144 | FL finished in 8.608678122998754\n",
      "INFO flwr 2023-05-15 12:04:30,024 | app.py:202 | app_fit: losses_distributed [(1, 0.06699201420217141)]\n",
      "INFO flwr 2023-05-15 12:04:30,027 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.119594968831794)], 'reward': [(1, 1.0520080151322528)], 'global_regret': [(1, 0.0675869536995421)], 'local_regrets': [(1, {0: 0.5244894016544293, 1: 0.06689368321332421, 2: 0.06840295113056763, 3: 0.06536660645607985})]}\n",
      "INFO flwr 2023-05-15 12:04:30,029 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:04:30,034 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "80e71bfc6ac24fd68da02e9ad71d7cf9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:04:30,298 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:04:40,310\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:04:44,580 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6610580685.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:04:44,582 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:04:44,585 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25546)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:04:47,849 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:04:47,851 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:04:47,854 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:04:47,856 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25546)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25546)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25542)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25542)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25544)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25544)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25547)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25547)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:04:51,456 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:04:51,506 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:04:51,510 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25546)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25542)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25544)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25547)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:04:55,383 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:04:55,385 | server.py:144 | FL finished in 7.529703973999858\n",
      "INFO flwr 2023-05-15 12:04:55,388 | app.py:202 | app_fit: losses_distributed [(1, 0.04492233404480187)]\n",
      "INFO flwr 2023-05-15 12:04:55,393 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3030353685816036)], 'reward': [(1, 1.2580010720481007)], 'global_regret': [(1, 0.04503429653350427)], 'local_regrets': [(1, {0: 0.04363168937237943, 1: 0.04482889242362116, 2: 0.045996151487301094, 3: 0.5024171885416209})]}\n",
      "INFO flwr 2023-05-15 12:04:55,395 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:04:55,398 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:04:55,431 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:05:03,707\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:05:07,529 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6614333440.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:05:07,531 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:05:07,533 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25565)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:05:09,948 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:05:09,949 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:05:09,951 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:05:09,953 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25565)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25565)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25566)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25566)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25569)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25569)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25570)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25570)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:05:13,317 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:05:13,357 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:05:13,361 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25565)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25566)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25569)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25570)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:05:17,097 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:05:17,099 | server.py:144 | FL finished in 7.146315402000255\n",
      "INFO flwr 2023-05-15 12:05:17,102 | app.py:202 | app_fit: losses_distributed [(1, 0.06999197359874026)]\n",
      "INFO flwr 2023-05-15 12:05:17,104 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3015660087924534)], 'reward': [(1, 1.234444060985771)], 'global_regret': [(1, 0.06712194780668387)], 'local_regrets': [(1, {0: 0.07848545938674184, 1: 0.08272379911627101, 2: 0.07515600821404228, 3: 0.5007872133236206})]}\n",
      "INFO flwr 2023-05-15 12:05:17,106 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:05:17,109 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:05:17,174 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:05:25,434\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:05:29,090 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6632717517.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:05:29,092 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:05:29,095 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25591)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:05:31,665 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:05:31,667 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:05:31,668 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:05:31,670 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25591)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25591)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25589)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25589)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25588)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25588)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25593)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25593)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:05:34,338 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:05:34,379 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:05:34,382 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25591)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25589)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25588)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25593)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:05:37,685 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:05:37,687 | server.py:144 | FL finished in 6.016926630998569\n",
      "INFO flwr 2023-05-15 12:05:37,689 | app.py:202 | app_fit: losses_distributed [(1, 0.07665087219395984)]\n",
      "INFO flwr 2023-05-15 12:05:37,692 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.117286771480485)], 'reward': [(1, 1.0299024644827786)], 'global_regret': [(1, 0.08738430699770672)], 'local_regrets': [(1, {0: 0.5027586714105526, 1: 0.09011386806054927, 2: 0.0862339269089968, 3: 0.08468160804145577})]}\n",
      "INFO flwr 2023-05-15 12:05:37,693 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:05:37,695 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:05:37,722 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:05:46,318\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:05:49,907 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6621529293.0}\n",
      "INFO flwr 2023-05-15 12:05:49,909 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:05:49,910 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25619)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:05:52,313 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:05:52,314 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:05:52,315 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:05:52,317 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25619)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25619)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25614)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25614)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25621)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25621)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25620)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25620)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:05:55,062 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:05:55,097 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:05:55,100 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25619)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25614)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25621)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25620)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:05:58,167 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:05:58,169 | server.py:144 | FL finished in 5.852286279001419\n",
      "INFO flwr 2023-05-15 12:05:58,172 | app.py:202 | app_fit: losses_distributed [(1, 0.036311617468253565)]\n",
      "INFO flwr 2023-05-15 12:05:58,174 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1172867714804848)], 'reward': [(1, 1.0780974029771033)], 'global_regret': [(1, 0.03918936850338196)], 'local_regrets': [(1, {0: 0.48676554406692873, 1: 0.038249158090226706, 2: 0.03846344743536173, 3: 0.038952905926212436})]}\n",
      "INFO flwr 2023-05-15 12:05:58,175 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:05:58,177 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:05:58,208 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:06:07,955\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:06:11,350 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6620913664.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:06:11,352 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:06:11,355 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25644)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:06:13,573 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:06:13,574 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:06:13,576 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:06:13,577 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25644)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25644)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25642)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25642)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25639)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25639)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25641)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25641)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:06:15,906 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:06:15,939 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:06:15,943 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25641)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25644)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25642)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25639)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:06:18,782 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:06:18,783 | server.py:144 | FL finished in 5.206226428999798\n",
      "INFO flwr 2023-05-15 12:06:18,786 | app.py:202 | app_fit: losses_distributed [(1, 0.03449873407490919)]\n",
      "INFO flwr 2023-05-15 12:06:18,788 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3030353685816036)], 'reward': [(1, 1.2684660620655093)], 'global_regret': [(1, 0.03456930651609419)], 'local_regrets': [(1, {0: 0.03333636434313986, 1: 0.03535460157815909, 2: 0.036986065483558705, 3: 0.4895024905404947})]}\n",
      "INFO flwr 2023-05-15 12:06:18,790 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:06:18,792 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bceb9e9d1f0d40fb874201406bafe6e6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:06:18,987 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:06:27,480\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:06:31,013 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'memory': 6619122074.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:06:31,016 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:06:31,017 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:06:33,288 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:06:33,290 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:06:33,291 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:06:33,293 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25665)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25665)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25665)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25666)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25666)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25664)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25664)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25670)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25670)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:06:35,791 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:06:35,824 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:06:35,828 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25665)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25666)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25664)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25670)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:06:38,684 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:06:38,685 | server.py:144 | FL finished in 5.392124474999946\n",
      "INFO flwr 2023-05-15 12:06:38,687 | app.py:202 | app_fit: losses_distributed [(1, 0.042291583895256446)]\n",
      "INFO flwr 2023-05-15 12:06:38,689 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2995547962893361)], 'reward': [(1, 1.2584886996763776)], 'global_regret': [(1, 0.041066096612958694)], 'local_regrets': [(1, {0: 0.045215428142976, 1: 0.48857283415971514, 2: 0.046986063362406696, 3: 0.045576595561642716})]}\n",
      "INFO flwr 2023-05-15 12:06:38,691 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:06:38,693 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:06:38,718 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:06:46,205\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:06:49,795 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6617665946.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:06:49,797 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:06:49,799 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25686)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:06:52,094 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:06:52,096 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:06:52,098 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:06:52,100 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25686)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25686)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25691)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25691)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25688)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25688)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25690)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25690)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:06:54,864 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:06:54,902 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:06:54,905 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25686)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25691)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25688)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25690)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:06:58,185 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:06:58,188 | server.py:144 | FL finished in 6.088242460999027\n",
      "INFO flwr 2023-05-15 12:06:58,190 | app.py:202 | app_fit: losses_distributed [(1, 0.051144296280827825)]\n",
      "INFO flwr 2023-05-15 12:06:58,193 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1161498365774984)], 'reward': [(1, 1.0642714947984526)], 'global_regret': [(1, 0.051878341779047404)], 'local_regrets': [(1, {0: 0.5082605298503093, 1: 0.049311001131736275, 2: 0.05299038931519178, 3: 0.05119985047178851})]}\n",
      "INFO flwr 2023-05-15 12:06:58,195 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:06:58,197 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:06:58,225 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:07:07,534\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:07:11,144 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6622122804.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:07:11,146 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:07:11,149 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25713)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:07:13,772 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:07:13,774 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:07:13,776 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:07:13,778 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25713)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25713)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25714)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25714)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25715)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25715)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25712)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25712)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:07:16,942 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:07:16,984 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:07:16,989 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25713)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25715)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25712)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25714)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:07:20,904 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:07:20,906 | server.py:144 | FL finished in 7.128230959000575\n",
      "INFO flwr 2023-05-15 12:07:20,909 | app.py:202 | app_fit: losses_distributed [(1, 0.02809940785308637)]\n",
      "INFO flwr 2023-05-15 12:07:20,911 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1161498365774984)], 'reward': [(1, 1.089529176601018)], 'global_regret': [(1, 0.026620659976481047)], 'local_regrets': [(1, {0: 0.4920174278270294, 1: 0.025936557031077435, 2: 0.026591419550620294, 3: 0.02503681264933271})]}\n",
      "INFO flwr 2023-05-15 12:07:20,914 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:07:20,916 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:07:20,951 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:07:30,494\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:07:34,382 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6630914868.0}\n",
      "INFO flwr 2023-05-15 12:07:34,385 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:07:34,389 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25735)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:07:37,589 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:07:37,591 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:07:37,593 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:07:37,595 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25735)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25735)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25737)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25737)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25736)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25736)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25738)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25738)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:07:41,173 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:07:41,221 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:07:41,225 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25735)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25738)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25737)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25736)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:07:45,228 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:07:45,230 | server.py:144 | FL finished in 7.63473533800061\n",
      "INFO flwr 2023-05-15 12:07:45,233 | app.py:202 | app_fit: losses_distributed [(1, 0.03261403955383791)]\n",
      "INFO flwr 2023-05-15 12:07:45,235 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1161498365774987)], 'reward': [(1, 1.0833779259685037)], 'global_regret': [(1, 0.03277191060899585)], 'local_regrets': [(1, {0: 0.49150134471906876, 1: 0.03222170743822761, 2: 0.030484261160435063, 3: 0.03343343054333471})]}\n",
      "INFO flwr 2023-05-15 12:07:45,239 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:07:45,242 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:07:45,280 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:07:54,776\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:07:58,926 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6634630759.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:07:58,929 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:07:58,931 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25762)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:08:01,665 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:08:01,667 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:08:01,668 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:08:01,670 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25762)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25762)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25763)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25763)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25760)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25760)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25761)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25761)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:08:04,892 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:08:04,936 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:08:04,940 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25762)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25763)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25760)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25761)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:08:09,163 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:08:09,165 | server.py:144 | FL finished in 7.495162021999931\n",
      "INFO flwr 2023-05-15 12:08:09,168 | app.py:202 | app_fit: losses_distributed [(1, 0.02750230139785024)]\n",
      "INFO flwr 2023-05-15 12:08:09,171 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3019474693126813)], 'reward': [(1, 1.2753573171559092)], 'global_regret': [(1, 0.02659015215677147)], 'local_regrets': [(1, {0: 0.029904885589042886, 1: 0.4767632523168517, 2: 0.03048307428801848, 3: 0.030042579043203132})]}\n",
      "INFO flwr 2023-05-15 12:08:09,176 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:08:09,179 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "020830e11d4f4b308d4fa2c6aa1128e3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:08:09,425 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:08:18,880\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:08:22,568 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6639190836.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:08:22,570 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:08:22,572 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25784)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:08:25,184 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:08:25,186 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:08:25,188 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:08:25,190 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25784)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25784)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25786)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25786)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25781)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25781)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25785)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25785)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:08:28,377 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:08:28,416 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:08:28,420 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25784)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25786)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25781)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25785)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:08:31,732 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:08:31,734 | server.py:144 | FL finished in 6.5442313219991775\n",
      "INFO flwr 2023-05-15 12:08:31,737 | app.py:202 | app_fit: losses_distributed [(1, 0.0127485092797801)]\n",
      "INFO flwr 2023-05-15 12:08:31,739 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3001366814758042)], 'reward': [(1, 1.287351334494948)], 'global_regret': [(1, 0.012785346980855617)], 'local_regrets': [(1, {0: 0.011793629288453383, 1: 0.4717550768174351, 2: 0.012382004882319683, 3: 0.012247911776627252})]}\n",
      "INFO flwr 2023-05-15 12:08:31,741 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:08:31,744 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:08:31,776 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:08:40,601\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:08:44,306 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6638188135.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:08:44,309 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:08:44,311 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25804)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:08:46,741 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:08:46,743 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:08:46,745 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:08:46,747 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25804)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25804)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25808)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25808)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25810)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25810)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25806)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25806)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:08:49,722 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:08:49,762 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:08:49,766 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25804)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25808)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25810)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25806)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:08:53,132 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:08:53,134 | server.py:144 | FL finished in 6.387526219001302\n",
      "INFO flwr 2023-05-15 12:08:53,138 | app.py:202 | app_fit: losses_distributed [(1, 0.016752752023211224)]\n",
      "INFO flwr 2023-05-15 12:08:53,140 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.302560793486469)], 'reward': [(1, 1.2855964303699645)], 'global_regret': [(1, 0.01696436311650414)], 'local_regrets': [(1, {0: 0.015709505829882786, 1: 0.47576384583166703, 2: 0.016073108218465405, 3: 0.01664913385854403})]}\n",
      "INFO flwr 2023-05-15 12:08:53,142 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:08:53,145 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:08:53,178 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:09:02,070\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:09:05,791 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6647566336.0}\n",
      "INFO flwr 2023-05-15 12:09:05,794 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:09:05,795 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25827)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:09:08,421 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:09:08,422 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:09:08,424 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:09:08,426 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25827)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25827)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25832)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25832)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25830)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25830)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25834)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25834)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:09:11,527 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:09:11,566 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:09:11,570 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25827)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25832)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25834)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25830)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:09:15,429 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:09:15,431 | server.py:144 | FL finished in 7.005127694999828\n",
      "INFO flwr 2023-05-15 12:09:15,436 | app.py:202 | app_fit: losses_distributed [(1, 0.010523377646404182)]\n",
      "INFO flwr 2023-05-15 12:09:15,439 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.302560793486469)], 'reward': [(1, 1.292238504696791)], 'global_regret': [(1, 0.010322288789678224)], 'local_regrets': [(1, {0: 0.010732255087841744, 1: 0.01081934683971319, 2: 0.46615822870404233, 3: 0.011568265599734479})]}\n",
      "INFO flwr 2023-05-15 12:09:15,441 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:09:15,444 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:09:15,543 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:09:24,923\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:09:28,715 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6633417933.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:09:28,717 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:09:28,719 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25856)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:09:31,586 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:09:31,588 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:09:31,589 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:09:31,591 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25856)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25856)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25853)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25853)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25858)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25858)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25859)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25859)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:09:34,640 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:09:34,683 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:09:34,687 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25856)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25853)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25858)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25859)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:09:38,069 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:09:38,071 | server.py:144 | FL finished in 6.480490767000447\n",
      "INFO flwr 2023-05-15 12:09:38,075 | app.py:202 | app_fit: losses_distributed [(1, 0.013563203336225755)]\n",
      "INFO flwr 2023-05-15 12:09:38,078 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1143218370256485)], 'reward': [(1, 1.0997744900283548)], 'global_regret': [(1, 0.014547346997293788)], 'local_regrets': [(1, {0: 0.4699499070790635, 1: 0.014383441575209252, 2: 0.013659853539126948, 3: 0.013444196797218632})]}\n",
      "INFO flwr 2023-05-15 12:09:38,080 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:09:38,083 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:09:38,159 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:09:47,331\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:09:50,845 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6644713063.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:09:50,848 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:09:50,850 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25878)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:09:53,355 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:09:53,356 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:09:53,358 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:09:53,360 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25878)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25878)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25877)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25877)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25876)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25876)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25882)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25882)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:09:56,076 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:09:56,117 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:09:56,120 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25878)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25877)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25876)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25882)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:09:59,287 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:09:59,289 | server.py:144 | FL finished in 5.929540533999898\n",
      "INFO flwr 2023-05-15 12:09:59,292 | app.py:202 | app_fit: losses_distributed [(1, 0.010072764640307978)]\n",
      "INFO flwr 2023-05-15 12:09:59,295 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1143218370256485)], 'reward': [(1, 1.1040971021825783)], 'global_regret': [(1, 0.01022473484306973)], 'local_regrets': [(1, {0: 0.46898426649693864, 1: 0.009521186680680607, 2: 0.009227018044416365, 3: 0.009743172984911206})]}\n",
      "INFO flwr 2023-05-15 12:09:59,297 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:09:59,299 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e4287810e6f1417f83c18739d9afb569",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:09:59,529 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:10:06,737\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:10:10,459 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6649177293.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:10:10,461 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:10:10,463 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25904)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:10:12,913 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:10:12,915 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:10:12,916 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:10:12,918 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25904)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25904)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25905)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25905)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25898)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25898)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25902)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25902)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:10:15,770 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:10:15,809 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:10:15,813 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25904)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25898)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25902)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25905)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:10:19,298 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:10:19,300 | server.py:144 | FL finished in 6.382108804999007\n",
      "INFO flwr 2023-05-15 12:10:19,303 | app.py:202 | app_fit: losses_distributed [(1, 0.007028247787508897)]\n",
      "INFO flwr 2023-05-15 12:10:19,305 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3042985780761)], 'reward': [(1, 1.2980012186276848)], 'global_regret': [(1, 0.006297359448414591)], 'local_regrets': [(1, {0: 0.008291382762530462, 1: 0.4619973054772344, 2: 0.007392175617531035, 3: 0.007616712938455022})]}\n",
      "INFO flwr 2023-05-15 12:10:19,308 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:10:19,310 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:10:19,506 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:10:30,164\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:10:33,520 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6652203828.0}\n",
      "INFO flwr 2023-05-15 12:10:33,522 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:10:33,524 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25926)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:10:35,665 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:10:35,667 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:10:35,668 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:10:35,669 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25926)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25926)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25929)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25929)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25928)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25928)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25925)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25925)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:10:38,240 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:10:38,276 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:10:38,279 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25926)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25929)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25928)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25925)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:10:41,435 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:10:41,437 | server.py:144 | FL finished in 5.767665484001554\n",
      "INFO flwr 2023-05-15 12:10:41,440 | app.py:202 | app_fit: losses_distributed [(1, 0.005096823705190259)]\n",
      "INFO flwr 2023-05-15 12:10:41,442 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3027903591850882)], 'reward': [(1, 1.297897315391026)], 'global_regret': [(1, 0.004893043794062885)], 'local_regrets': [(1, {0: 0.005310878969401814, 1: 0.46100356131262105, 2: 0.0055453434472359925, 3: 0.005712096737216717})]}\n",
      "INFO flwr 2023-05-15 12:10:41,444 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:10:41,446 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:10:41,520 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:10:49,405\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:10:53,126 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6681219482.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:10:53,128 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:10:53,130 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25945)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:10:55,879 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:10:55,880 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:10:55,882 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:10:55,884 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25945)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25945)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25949)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25949)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25947)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25947)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25951)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25951)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:10:59,003 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:10:59,047 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:10:59,051 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25945)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25949)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25947)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25951)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:11:02,694 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:11:02,696 | server.py:144 | FL finished in 6.812791894999464\n",
      "INFO flwr 2023-05-15 12:11:02,700 | app.py:202 | app_fit: losses_distributed [(1, 0.005436016914629366)]\n",
      "INFO flwr 2023-05-15 12:11:02,703 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1136376213822246)], 'reward': [(1, 1.1075753732507767)], 'global_regret': [(1, 0.00606224813144801)], 'local_regrets': [(1, {0: 0.46291779867878996, 1: 0.00500535661188231, 2: 0.005521565351549067, 3: 0.005483932662010788})]}\n",
      "INFO flwr 2023-05-15 12:11:02,705 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:11:02,708 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:11:02,814 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:11:12,338\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:11:16,050 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6682163200.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:11:16,052 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:11:16,054 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25973)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:11:18,783 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:11:18,784 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:11:18,786 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:11:18,788 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25973)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25973)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25968)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25968)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25971)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25971)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25970)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25970)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:11:21,787 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:11:21,827 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:11:21,831 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25973)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25971)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25968)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25970)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:11:25,257 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:11:25,259 | server.py:144 | FL finished in 6.4714550739990955\n",
      "INFO flwr 2023-05-15 12:11:25,264 | app.py:202 | app_fit: losses_distributed [(1, 0.008002564414330579)]\n",
      "INFO flwr 2023-05-15 12:11:25,267 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1136376213822246)], 'reward': [(1, 1.1047926033305067)], 'global_regret': [(1, 0.008845018051718622)], 'local_regrets': [(1, {0: 0.46483150070575713, 1: 0.00829536485969594, 2: 0.0078089014557726644, 3: 0.008259076281810907})]}\n",
      "INFO flwr 2023-05-15 12:11:25,270 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:11:25,272 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:11:25,495 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:11:34,200\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:11:37,826 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6665500672.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:11:37,829 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:11:37,830 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=25998)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:11:40,409 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:11:40,411 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:11:40,413 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:11:40,414 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=25998)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25998)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25993)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25993)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25992)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25992)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25991)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=25991)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:11:43,448 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:11:43,490 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:11:43,494 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25998)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25993)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25992)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=25991)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:11:47,053 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:11:47,055 | server.py:144 | FL finished in 6.641022428999349\n",
      "INFO flwr 2023-05-15 12:11:47,058 | app.py:202 | app_fit: losses_distributed [(1, 0.008690863175499074)]\n",
      "INFO flwr 2023-05-15 12:11:47,061 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3042985780761)], 'reward': [(1, 1.2957509055621292)], 'global_regret': [(1, 0.008547672513970875)], 'local_regrets': [(1, {0: 0.008179548640961137, 1: 0.4661600347211813, 2: 0.008172122577563891, 3: 0.009436332408004606})]}\n",
      "INFO flwr 2023-05-15 12:11:47,063 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:11:47,065 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bfed0df1be5e4563bbe2dff256aadb9e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:11:47,355 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:11:56,787\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:12:00,589 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6668988007.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:12:00,592 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:12:00,594 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26019)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:12:03,042 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:12:03,043 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:12:03,045 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:12:03,046 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26019)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26019)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26021)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26021)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26020)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26020)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26016)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26016)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:12:05,870 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:12:05,907 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:12:05,911 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26019)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26021)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26020)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26016)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:12:09,647 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:12:09,649 | server.py:144 | FL finished in 6.60298407099981\n",
      "INFO flwr 2023-05-15 12:12:09,653 | app.py:202 | app_fit: losses_distributed [(1, 0.003911889623177674)]\n",
      "INFO flwr 2023-05-15 12:12:09,655 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3004512530080938)], 'reward': [(1, 1.2964190340945638)], 'global_regret': [(1, 0.00403221891353049)], 'local_regrets': [(1, {0: 0.0027062396087479705, 1: 0.0032282204756674147, 2: 0.4639199596239253, 3: 0.002977724430084893})]}\n",
      "INFO flwr 2023-05-15 12:12:09,657 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:12:09,659 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:12:09,714 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:12:19,369\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:12:23,140 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6661659444.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:12:23,142 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:12:23,144 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26041)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:12:25,932 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:12:25,934 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:12:25,936 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:12:25,938 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26041)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26041)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26045)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26045)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26043)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26043)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26042)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26042)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:12:29,030 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:12:29,075 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:12:29,079 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26041)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26045)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26043)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26042)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:12:32,817 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:12:32,818 | server.py:144 | FL finished in 6.880983125000057\n",
      "INFO flwr 2023-05-15 12:12:32,822 | app.py:202 | app_fit: losses_distributed [(1, 0.005105913928376123)]\n",
      "INFO flwr 2023-05-15 12:12:32,825 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3044038174589094)], 'reward': [(1, 1.2990733107510943)], 'global_regret': [(1, 0.00533050670781437)], 'local_regrets': [(1, {0: 0.0034855946090899493, 1: 0.4661358346703525, 2: 0.0034974791156193335, 3: 0.004489332964157692})]}\n",
      "INFO flwr 2023-05-15 12:12:32,827 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:12:32,830 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:12:32,881 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:12:40,999\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:12:44,893 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6680625972.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:12:44,895 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:12:44,897 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26069)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:12:47,843 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:12:47,845 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:12:47,848 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:12:47,850 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26069)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26069)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26065)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26065)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26067)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26067)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26062)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26062)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:12:51,293 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:12:51,337 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:12:51,341 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26069)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26067)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26065)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26062)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:12:55,685 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:12:55,687 | server.py:144 | FL finished in 7.836770963998788\n",
      "INFO flwr 2023-05-15 12:12:55,690 | app.py:202 | app_fit: losses_distributed [(1, 0.001934815534775445)]\n",
      "INFO flwr 2023-05-15 12:12:55,692 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1133336066437414)], 'reward': [(1, 1.1103524061268477)], 'global_regret': [(1, 0.002981200516893509)], 'local_regrets': [(1, {0: 0.4581547841687314, 1: 0.002848875986269393, 2: 0.0021200105322749844, 3: 0.0018001770975407969})]}\n",
      "INFO flwr 2023-05-15 12:12:55,696 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:12:55,698 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:12:55,897 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:13:05,188\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:13:09,166 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6695504282.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:13:09,168 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:13:09,170 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26088)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:13:11,960 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:13:11,961 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:13:11,964 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:13:11,965 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26088)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26088)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26093)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26093)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26090)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26090)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26089)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26089)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:13:15,861 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:13:15,906 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:13:15,910 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26088)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26093)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26090)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26089)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:13:20,622 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:13:20,625 | server.py:144 | FL finished in 8.659695694999755\n",
      "INFO flwr 2023-05-15 12:13:20,630 | app.py:202 | app_fit: losses_distributed [(1, 0.004238199285133873)]\n",
      "INFO flwr 2023-05-15 12:13:20,633 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3028923611730598)], 'reward': [(1, 1.2989056083441808)], 'global_regret': [(1, 0.003986752828879112)], 'local_regrets': [(1, {0: 0.004594549147357453, 1: 0.004219897776164003, 2: 0.004462624846650752, 3: 0.46086031101607816})]}\n",
      "INFO flwr 2023-05-15 12:13:20,637 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:13:20,640 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:13:20,802 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:13:31,134\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:13:35,796 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6682959463.0}\n",
      "INFO flwr 2023-05-15 12:13:35,800 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:13:35,803 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26116)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:13:39,717 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:13:39,718 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:13:39,722 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:13:39,725 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26116)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26116)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26112)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26112)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26110)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26110)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26115)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26115)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:13:44,343 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:13:44,410 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:13:44,415 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26116)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26112)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26110)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26115)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:13:50,486 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:13:50,488 | server.py:144 | FL finished in 10.7639674130005\n",
      "INFO flwr 2023-05-15 12:13:50,493 | app.py:202 | app_fit: losses_distributed [(1, 0.002267623075700746)]\n",
      "INFO flwr 2023-05-15 12:13:50,500 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1133336066437414)], 'reward': [(1, 1.110964693647197)], 'global_regret': [(1, 0.0023689129965445135)], 'local_regrets': [(1, {0: 0.4613350275732548, 1: 0.0016550167264219287, 2: 0.0019053240274662304, 3: 0.001359709621374703})]}\n",
      "INFO flwr 2023-05-15 12:13:50,504 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:13:50,506 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9250020e843c43e08c30e6e6f5aa3942",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:13:50,966 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:14:02,857\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:14:07,435 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6677676852.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:14:07,441 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:14:07,445 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26140)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:14:11,531 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:14:11,533 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:14:11,536 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:14:11,539 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26140)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26140)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26136)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26136)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26134)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26134)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26137)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26137)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:14:16,791 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:14:16,863 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:14:16,869 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26140)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26134)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26137)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26136)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:14:23,414 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:14:23,416 | server.py:144 | FL finished in 11.877818394001224\n",
      "INFO flwr 2023-05-15 12:14:23,422 | app.py:202 | app_fit: losses_distributed [(1, 0.0036655180591861638)]\n",
      "INFO flwr 2023-05-15 12:14:23,426 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3029242552901334)], 'reward': [(1, 1.29919071742803)], 'global_regret': [(1, 0.0037335378621032806)], 'local_regrets': [(1, {0: 0.0030594990631667655, 1: 0.4637444205586225, 2: 0.0025627536749079963, 3: 0.00247998458576195})]}\n",
      "INFO flwr 2023-05-15 12:14:23,429 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:14:23,432 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:14:23,578 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:14:34,721\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:14:38,974 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6681429607.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 12:14:38,977 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:14:38,980 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26160)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:14:42,518 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:14:42,521 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:14:42,523 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:14:42,525 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26160)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26160)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26162)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26162)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26167)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26167)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26165)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26165)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:14:46,748 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:14:46,803 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:14:46,809 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26160)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26167)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26162)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26165)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:14:51,805 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:14:51,808 | server.py:144 | FL finished in 9.282642726000631\n",
      "INFO flwr 2023-05-15 12:14:51,812 | app.py:202 | app_fit: losses_distributed [(1, 0.003863697127316553)]\n",
      "INFO flwr 2023-05-15 12:14:51,814 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3004815122332372)], 'reward': [(1, 1.296693773662486)], 'global_regret': [(1, 0.003787738570750422)], 'local_regrets': [(1, {0: 0.003249281074443346, 1: 0.004021048650598577, 2: 0.003473505170500607, 3: 0.4618955392594382})]}\n",
      "INFO flwr 2023-05-15 12:14:51,817 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:14:51,821 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:14:51,977 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:15:01,202\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:15:05,220 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6677643674.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:15:05,225 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:15:05,226 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26189)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:15:08,227 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:15:08,229 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:15:08,231 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:15:08,234 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26189)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26189)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26187)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26187)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26191)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26191)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26190)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26190)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:15:11,799 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:15:11,846 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:15:11,850 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26189)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26191)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26190)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26187)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:15:15,537 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:15:15,539 | server.py:144 | FL finished in 7.305066499000532\n",
      "INFO flwr 2023-05-15 12:15:15,542 | app.py:202 | app_fit: losses_distributed [(1, 0.0011635626162343864)]\n",
      "INFO flwr 2023-05-15 12:15:15,544 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3044367238489007)], 'reward': [(1, 1.303238534779824)], 'global_regret': [(1, 0.0011981890690765415)], 'local_regrets': [(1, {0: 0.00011565441477813953, 1: 0.4601355889543826, 2: 0.0006147098912521785, 3: 0.0009728828502391708})]}\n",
      "INFO flwr 2023-05-15 12:15:15,547 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:15:15,549 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:15:15,607 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:15:25,054\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:15:28,851 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6674285364.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 12:15:28,853 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:15:28,855 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26211)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:15:31,599 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:15:31,601 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:15:31,603 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:15:31,605 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26211)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26211)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26209)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26209)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26215)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26215)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26213)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26213)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:15:34,699 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:15:34,743 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:15:34,746 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26211)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26215)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26209)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26213)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:15:38,438 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:15:38,441 | server.py:144 | FL finished in 6.835896189999403\n",
      "INFO flwr 2023-05-15 12:15:38,445 | app.py:202 | app_fit: losses_distributed [(1, 0.004642906726815401)]\n",
      "INFO flwr 2023-05-15 12:15:38,448 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3029242552901334)], 'reward': [(1, 1.2982587989110201)], 'global_regret': [(1, 0.0046654563791133806)], 'local_regrets': [(1, {0: 0.004173791084015141, 1: 0.003137977297310786, 2: 0.46483467147157126, 3: 0.0036097727000793016})]}\n",
      "INFO flwr 2023-05-15 12:15:38,450 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:15:38,452 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 12:15:38,600 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 12:15:46,801\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 12:15:50,643 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6678727476.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 12:15:50,646 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 12:15:50,649 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=26238)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 12:15:53,320 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 12:15:53,321 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 12:15:53,323 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 12:15:53,325 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=26238)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26238)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26236)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26236)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26234)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26234)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26231)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=26231)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:15:56,566 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 12:15:56,607 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 12:15:56,611 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26238)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26234)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26231)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=26236)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 12:16:00,127 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 12:16:00,129 | server.py:144 | FL finished in 6.804288743998768\n",
      "INFO flwr 2023-05-15 12:16:00,133 | app.py:202 | app_fit: losses_distributed [(1, 0.004403221159909833)]\n",
      "INFO flwr 2023-05-15 12:16:00,136 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3004815122332372)], 'reward': [(1, 1.2961800795909477)], 'global_regret': [(1, 0.004301432642289884)], 'local_regrets': [(1, {0: 0.0038665749897759034, 1: 0.003909944214754879, 2: 0.0033053699884392908, 3: 0.46371558109238414})]}\n",
      "INFO flwr 2023-05-15 12:16:00,138 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 12:16:00,140 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    }
   ],
   "source": [
    "client_0_sample_size_fn = lambda n: int(np.log(n))\n",
    "sample_size_fns = {0: client_0_sample_size_fn,\n",
    "                   1: lambda n: int((n-client_0_sample_size_fn(n))//(NUM_CLIENTS-1)),\n",
    "                   2: lambda n: int((n-client_0_sample_size_fn(n))//(NUM_CLIENTS-1)),\n",
    "                   3: lambda n: int((n-client_0_sample_size_fn(n))//(NUM_CLIENTS-1))}\n",
    "\n",
    "global_regrets, global_regrets_std, fed_local_regrets, fed_local_regrets_std = run_federated_training_experiments(data, aux, sample_size_fns, num_iters=5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "7a042dff-99a1-4a6c-9d39-fa800751bf1d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "client_id = 2\n",
    "\n",
    "# Apply moving average smoothing\n",
    "window_size = 2\n",
    "local_regrets_smooth = np.convolve(local_regrets[client_id], np.ones(window_size) / window_size, mode='same')\n",
    "local_regrets_std_smooth = np.convolve(local_regrets_std[client_id], np.ones(window_size) / window_size, mode='same')\n",
    "\n",
    "global_regrets_smooth = np.convolve(global_regrets, np.ones(window_size) / window_size, mode='same')\n",
    "global_regrets_std_smooth = np.convolve(global_regrets_std, np.ones(window_size) / window_size, mode='same')\n",
    "\n",
    "fed_local_regrets_smooth = np.convolve(fed_local_regrets[client_id], np.ones(window_size) / window_size, mode='same')\n",
    "fed_local_regrets_std_smooth = np.convolve(fed_local_regrets_std[client_id], np.ones(window_size) / window_size, mode='same')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "a0c64e7a-b952-4463-8ac0-cdb302c5dac0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnwAAAHNCAYAAACEk6YbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACgBElEQVR4nOzdd2BV9f3/8ec5dyY3gwQIUwSBALJBRFtFUawVFUXF2aqVobXapYJo+2srftvagcU9itbRYVUEUbRaFcGFKJWlMkRkJowEMu4+5/P74+be3CT3Zt6bnCTvx/drc3PPuJ+bD0le+UxNKaUQQgghhBAdlt7WBRBCCCGEEOklgU8IIYQQooOTwCeEEEII0cFJ4BNCCCGE6OAk8AkhhBBCdHAS+IQQQgghOjgJfEIIIYQQHZwEPiGEEEKIDs7e1gVob5RSmGZ616rWdS3tryEaR+rCWqQ+rEXqwzqkLqwl3fWh6xqapjXpGgl8TWSaipKSyrTd327XycvzUFbmJRw20/Y6omFSF9Yi9WEtUh/WIXVhLa1RH/n5Hmy2pgU+6dIVQgghhOjgJPAJIYQQQnRwEviEEEIIITo4CXxCCCGEEB2cBD4hhBBCiA5OAp8QQgghRAcngU8IIYQQooOTwCeEEEII0cFJ4BNCCCGE6OAk8AkhhBBCdHAS+IQQQgghOjgJfEIIIYQQHZy9rQsghBCi81BKYZoGppmeTeU7I9PU8PttBIMBDEO1dXE6vWT1oes6um5D07Q2KZcEPiGEEGkXDofx+Srw+SowTaOti9PhHDqkS4i2kGT1oes2MjKyyMjIwm5v3QjWLgLf+vXrufzyy/nb3/7GxIkTG3XNhg0bePDBB1m3bh2maVJYWMiNN97IqaeemubSCiGEiBcOhzh8uAiAjAwPLlcGuq4DbdPS0RHZbJq07llI3fpQmKaJ3+/D6y3H6y2na9ee2O2OViuT5QPfzp07+dGPftSkv1xWrVrFjTfeSI8ePbjhhhvQdZ1//vOfzJ49mwceeIApU6akscSp0UYtvkIIkVKmaVBaegCbzUZ+fg903dbWReqQ7HadcFha+KwiWX24XBlkZ+dSUlJMaekBunbt2WrfE5aetPHmm29y6aWXcvDgwUZf4/P5uOOOOygoKOD5559n5syZ/OAHP+Df//43ubm5/OlPf0pjiVMn8tevEEK0b15vJYZh0KVLgYQ9IYh063bpUoBhGPh8la33uq32Sk00Z84cbrrpJrp37855553X6OveeustDh48yM0330x+fn7s+S5dujB//nymTZtGMBhMR5FTSilpmhdCtH/BoA+Xy93q45WEsDK73Y7T6SYQ8LXaa1o28O3YsYOf//znvPTSS/Tv37/R13300UcAnHbaaQCYpkllZSRBX3jhhdx44404nc6UlzfVFBL4hBDtm2maBIMBnM6Mti6KEJbjcmUQDAZabbKNZf/kWrFiRbOC2VdffYXH48Hr9fLrX/+ad955h2AwSN++fbnpppuYPn16GkorhBCitshsXIXD0XoD04VoLyITNiLLFLXGMC7LBr7mtsKVlZWhaRpXXHEFQ4YM4Xe/+x1+v5+nnnqK22+/nfLycq6++uoWlc1uT1/F2GyRe9t0HWXZ2ukcYnVhs2xDeKci9WEtjamPaMNFW6071llEv7yaBjIaqO01tj50Xav6mN5cEdXhIkUwGKSiooITTzyRhx9+OPb81KlTOffcc7n33nuZPn062dnZzbq/rmvk5XlSVdykMj1ObDLA2RJycqQ7ykqkPqylvvrw+20cOqRjs+mt8guts5M/hqylofowTR1d18nNzcTtdqe9PB0u8GVkRH74fP/736/xfGZmJhdeeCEPPfQQ69ati43xayrTVJSVeVtczmRsNp2cnAwqKgOYYflTrS1F66KszIdhyHIHbU3qw1oaUx/R8UmGoWTJkDTStEh9GIYpLXwW0Nj6MIzI2nxHj3rx+Zq2GHlOTkaTA36HC3y9evViy5YtdOvWrc6x6HMVFRUteo3W+MFlGgbhcNpfRjSCYZjyy8pCpD6spb76kIWAW0c0VEjYs4am1kdr/UHU4dp/R48eDcCWLVvqHNu1axcAffv2bdUyNYd83wohhBAiVTpc4Dv//PNxOBw89thjeL3VXa8HDx7kpZde4phjjmHUqFFtWEIhhBBCiNbVrrt0d+/ezbp16+jXrx9jx44F4JhjjmHevHncfffdzJgxgxkzZhAMBvn73/+O1+tl0aJF7WPGmDTxCSGEECJF2nXgW7t2LfPnz2f69OmxwAeRCRvHHHMMjz/+OIsWLcJmszF69GgWLVrEmDFj2q7ATSB5TwghhKifUop//evveL2VDBpUyGmnTW7rIlmWpmQPryYxDJOSkvTtfWe36+TleThcWoYZbgctkR1YtC5KSytlkoAFSH1YS2PqIxQKcvjwfrp27YXDYf0djtozu13vlN8XL774b+699w9AZP3eJ574O/37D2jjUjWuPlry/ZGf72nyLN0ON4avo5Ct1YQQQojk9u/fxyOPPADAmDHjCAaD/Pa3v8EwmrbESWchgU8IIYQQ7YpSit//fgE+n5fLL/8eCxc+QGHhUD7/fBP/+tezbV08S5LAZ1HtYmKJEEII0QaWLn2RTz9dy/DhI7nhhptwOp0sWPB7PB4Pixc/xjff7GzrIlqOBD7Lki5dIYQQoraiov089NB95OTk8pvf/A67PTL/tE+fvsyb90uCwYB07SbQrmfpdmQS94QQQnQGGzeu58YbZ6FpGosXP8vgwYX1nt+zZy/efHNVwmNnnDGFM874JB3FbPck8FmUTJ4WQgiRLkopzjlnctKtRp1OF3l5eQwdOozvfGdq2pY7MQyDP//5HpRSnH321AbDXmsLBPxcddUMysvLePLJf9C7d5+2LlKzSZeuEEII0cns3bun3n3lg8EAxcVFvPvuO9x5523cdttPCAT8KS/H66+/yvbtW9F1nauvvi7l928pl8vNjTf+hMrKShYs+GW77iaWFj6LUihk2oYQQoh02LLly9jjsWPHM2PGFbHPDSNMUVERq1a9w8aN6wH48MP3WbToz8yde2fKyhAOh3nyyccBmDTpdPr1OzZl906lM86YwvPPj2Ljxg28+OK/ufTSKxq+yIKkhc+ipEdXCCFEumzZ8kXs8UknfYtJk06P/Td58hSuuOJ7PPzwYi655LLYea+++jJlZWUpK8Nbb71BUdF+AC688JKU3TcdbrjhZgD++tdHOHToUBuXpnkk8AkhhBCdzNat1S18Q4YMS3re9dffhK5HooJhGDWCYkstWfI8AAUFPRg/fkLK7psOo0ePZeTIUXi9lTz99OK2Lk6zSJeuRcmkDSGEEOmybduW2OPCwqFJz8vIyKB79wKKi4sA8HpTs7Xorl072bx5IwCTJk2ud+3ZlSvf4he/mNfs15o0aTK//e0fm3191LRpF7Fx4waWL1/K1VdfR7du3Vt8z9YkLXwWJXFPCCFEOuzfv4+jR48C0Lt3H3JycpKeaxgG5eXlsc+7du2WkjK8++47scdjx46r99wNGz5r0WuNHDm6RddHnXHGWWRkZBIKhVi2bElK7tmapIXPsiTyCSGESL3GducCrFnzYaxVLysru97WwKb4+OOPYo+HDx9Z77lnnHEWY8aM5x//eJpNmzYAMHfunXTpklfn3KeeWhzrdr7jjl+RlZXN8OEjUlJml8vF+PEn8N57q1i+fCnXXTenXe2KJYHPoqRLVwghRDrEz9AdMiR5gCsq2s+f//z72OeXX34VTqezxa9vmiZffvk5EBm/11DX6IgRowB4/PGHAHC73Zx33gWxsYXx7r9/IQDZ2TlMnXp+i8ta24QJJ/Hee6s4dOggmzdvYsSI+sOqlUjgsyiJe0KIzkYpRTBktnUxWp3TobdqS1F9gS8YDLJ//z5WrVrJP/7xNOXlkVm5EyZM5HvfuzYlr79v3158Ph8Axx7bv1HXBAIBdu36BoDjjhuUMOyVl5ezf/8+AAYNGpySstZWWDgk9vjTTz+WwCdaTlr4hBCdiVKK3z27ju17j7Z1UVrdoL65zL9qXKuFvvgJGz/72U31nut0OrnookuZM+fG2J61LRUNZUC94wfjff31jtiix8nCXPz7GjQoPTt2DBw4CE3TUErx+eeb0vIa6SKBTwghhDW0n+FQ7daBA8WUlBxu1LnDhh3PggV/oGfPniktQ/xaftnZuY26Zvv2hsNcfMtlulr4MjM95Ofnc/jwYfbs2Z2W10gXCXwWEzJCPLHuOfpl9mN019QMNBVCCKvTNI35V42TLt00i5+wMX78BC6+uHph5crKCnbt+obly1/iyJEjfPHF59xzzwIWLnwgpeULhYKxxx6Pp1HXbN++Lfa4MS186dyTNysrm8OHD3Pw4MG0vUY6SOCzmLd3vcfr21YC8NCZf5AdN4QQnYamabictrYuRocW3wo2ceLJTJp0ep1zLrvsKmbPvpr9+/exdu0a3n77Tc488zspK4PDUT3xo7Kycev6RQOfpmlJA9/WrZHAZ7PZ6N//uBaWMjmPJwsAv9+XttdIB1mHz2JK/KVtXQQhhBAdVHzgS9YK1qVLF66//kexz1988d8pLUNubnU3bnl548ZsRgNf7959yMys2yoYCPjZvTsyqaN//wEpmU2cTHTCSHtakgWkhc+C2tc/ICGEEO1HfJfu4MHJl2Q5/fQzycn5A2VlR9mw4TP27dtL79596r13aWkpS5b8mw8+eI89e3ZhGAYFBT0YN24Cl156Bf36HQtAr169Y9c0Zm/e/fv3UVERWfw5eXfutgYndTSnrIn4/X4gsgtJeyItfEIIIUQnUFJymEOHIuPOCgp60KVLl6Tn2u12TjllUuzzlSvfqvfeH3/8EVdddQlPPvk4R46UMmHCRMaNO4FAIMDSpS/UmODQq1fvWCvdN9/sbLDc27ZtjT1ONmEjfvzewIH1j99rSlkTOXz4EADduhU0WHYrkRY+i2lvTcRCCCHah+gOFNC4SQ0nn/xtVqxYDsDq1Su58sqrE563adNG5s+/BV3X+eUv7+I73zkn9rtMKcXq1e9y/PHVkxB1XWfYsOP59NO1HDhQzKFDB+tdfHn79vjAl7j1Lv6c+t5bU8tam8/no7S0BKDeVkArkhY+i5G4J4QQIh1qjt8bUs+ZERMnnozD4QBg8+ZNsZateMFgkLvu+gWBQIBf/er/OPvsqTUaLjRNY9Kk0+u0Jk6ceHLs8ebN9a9nV3OGbuIwF99SeMwx/RKe09yyxotvSUzVlm2tRQKfEEII0QlEZ7FC4wJfZqaH0aPHApHt0N57b1Wdc1aseJl9+/YyefKUGl3ADZk0aXLs8bp1a+s9N9qlm5WVVWP8X7zojiBArAUuVWWNF7/Y8vjxJzbrHm1FAp/lSBufEEKI1Ivv0o3fIqw+3/rWqbHHq1atrHP83XffAWDatOlNKkvfvscwcuRoAN56603C4XDC8yorKygqiuzMMXBg8skYXbrkxx7/9Kc3MmvW1TVaBltS1ngff/wREJktPHTosGbfpy1I4LMYiXtCCCFS7ejRIxQXFwGRhYOTtZTV9u1vVwe+devWUllZUeN4tPWtOd2bF100A4AjR0r56KP3E56zffv22Faj9c2+nT37hxx33EBstsg6jrqu19mntyVlhciM4v/971MApk49v1n3aEsyacNqZNKGEEKIFMvN7cJ7733S5Ov69Olb73VlZUfRdR2Xy93ke0+ePIXHHnuI/fv3sWLFK5xyyml1zhk9ekyjyj1ixEiefvq5es9pSVkB3n77TUKhEJmZnlhYbU+khc9iJO4JIYRoLzyeLEzTZPfuXU2+1m63c911c4DILOCvvtqe2sLV0pKyAixd+iIAl1xyGTk5jdsD2EraReBbv349w4YNY82aNc26/l//+hdDhgxhyZIlKS5Z6mkS+YQQQrQT48dPAOChhxbh9XprHCsuLmLt2o/qvf7ss6cyaFAhSikWL340beWElpV17do1bN++lcxMD5dfflVay5kulu/S3blzJz/60Y8wzeZtqL1jxw5+//vfp7hUQgghhJgz50bWrfuEDz54j0svvYChQ4fhdrvZs2cPO3Zs59prZzFhwklJr9d1nVtumceNN85i1ap32LLlS4YMSb4DSFuV9YknImF01qwb2mXrHli8he/NN9/k0ksv5eDBg826PhQKceutt8a2W2l/pLVPCCGEdfXrdyxPPPEs559/IW63m08++ZhPPvkY0zSYPv0Szj57aoP3GDlyNKtXr+W99z5JW9hrSVlXr17Jxo0bGD9+AjNmXJ628qWbZVv45syZw7vvvsugQYM49dRTeeWVV5p8j0WLFrFz505mz57Ngw8+mIZSpl7NRSChanKSEEIIYUk9e/Zi3rxftHUxGqWpZQ0EAtx33714PB7mz/9Vu94Ny7KBb8eOHfz85z/nBz/4AY8+2vR+/Y8//pjFixdz9913t+sKEkIIIUTbcLlcPP/8srYuRkpYNvCtWLECp9PZrGvLysqYO3cuZ555JhdffHHKJ2vY7enrCdfjwqnNpqHrElbbis2m1/go2pbUh7U0pj5MU35+tYborw3pFbKGptaHzaalNVdEWTbwNTfsAfzqV78iFApx1113pbBEEbqukZfnSfl9o1wuR+xxly7pex3ReDk5GW1dBBFH6sNa6qsPv9/GoUN6q/1C6+zkjyFraag+TFND13VyczNxu5u3NmBTWDbwNdfSpUtZsWIFjz32GPn5+Q1f0ESmqSgr8zZ8YjMFg9Xbyxw5Uil/rbUhm00nJyeDsjIfhtG8WeIidaQ+rKUx9REMBjBNE8NQhMNSZ+miaZH6MAxTfmdYQGPrwzAUpmly9KgXn69pk0tzcjKaHPA7VODbs2cPCxYs4LzzzmPkyJGUlEQ2UI6ut+P1eikpKSE7OxuHw1HfreqVzh9c8f84Iv8Y5Lu3rRmGKb+sLETqw1rqqw/DkJ9frSH6e0PCnjU0tT5a6w+iDhX4Pv74YyoqKnjllVcSzupdsGABCxYs4Omnn2bixIltUMKGycLLQgghhEi1DhX4TjnlFJ588sk6z7/33nssXryYmTNncsoppzB0aPrW+RFCCCGEsJoOFfgKCgooKCio83xRUREAgwYN4lvf+lZrF6vZTGUiiy8LIYQQoqXa9ZSe3bt3s2zZMv73v/+1dVFSJn7NQCUDMoQQQgiRAu068K1du5a5c+fy3HPPtXVRUkYDtKqgp5DAJ4QQQoiW05Q0IzWJYZiUlFSm7f7//XIpI95bxtqcDKZeeh+2jtXr3q7Y7Tp5eR5KSytlVqgFSH1YS2PqIxQKcvjwfrp27YXD0fy1VUXD7HZdvi8spDH10ZLvj/x8T5OXZWnXLXwd0TFfb8ZjKk4/4pUWPiGEEEKkhAQ+y6kewxeZtCGEEEII0TIS+KymxqSNNiyHEEIIIToMCXwWJi18QgghhEgFCXwWJmP4hBBCCJEKEvgsTFr4hBBCCJEKEvgsJr5NT1bMEUIIIUQqyCJvFhMf8Uzp0hVCCCGSUkrxr3/9Ha+3kkGDCjnttMltXSTLksBnOdUhT0mXrhBCCJHUkiXP8+CDfwHA6XTyxBN/p3//AW1bKIuSLl2LqdHCJ126QgghREL79+/jkUceAGDMmHEEg0F++9vfYBhGG5fMmiTwWZjM0hVCCCHqUkrx+98vwOfzcvnl32PhwgcoLBzK559v4l//erati2dJEvgspsakDaRLVwghhKht6dIX+fTTtQwfPpIbbrgJp9PJggW/x+PxsHjxY3zzzc62LqLlSOCzGJmlK4QQQiRXVLSfhx66j5ycXH7zm99ht0emI/Tp05d5835JMBiQrt0EZNKGxdQcwyctfEIIITq2jRvXc+ONs9A0jcWLn2Xw4MJ6z+/Zsxdvvrkq4bEzzpjCGWd8ko5itnsS+CxMxvAJIYRIB6UU55wzmYqKioTHnU4XeXl5DB06jO98Z2raljsxDIM///kelFKcffbUBsNeawsE/Fx11QzKy8t48sl/0Lt3n7YuUrNJl67FqHo+E0IIIVJh7949ScMeQDAYoLi4iHfffYc777yN2277CYGAP+XleP31V9m+fSu6rnP11del/P4t5XK5ufHGn1BZWcmCBb9s193E0sJnOdUhT5ZlEUIIkQ5btnwZezx27HhmzLgi9rlhhCkqKmLVqnfYuHE9AB9++D6LFv2ZuXPvTFkZwuEwTz75OACTJp1Ov37HpuzeqXTGGVN4/vlRbNy4gRdf/DeXXnpFwxdZkLTwWYzM0hVCCJFuW7Z8EXt80knfYtKk02P/TZ48hSuu+B4PP7yYSy65LHbeq6++TFlZWcrK8NZbb1BUtB+ACy+8JGX3TYcbbrgZgL/+9REOHTrUxqVpHgl8FiMLLwshhEi3rVurW/iGDBmW9Lzrr78JXY9EBcMwagTFllqy5HkACgp6MH78hJTdNx1Gjx7LyJGj8HorefrpxW1dnGaRLl2rUfFbq0ngE0IIkXrbtm2JPS4sHJr0vIyMDLp3L6C4uAgAr7cyJa+/a9dONm/eCMCkSZPRNC3puStXvsUvfjGv2a81adJkfvvbPzb7+qhp0y5i48YNLF++lKuvvo5u3bq3+J6tSVr4LEbF/Zs3VfsdHCqEEMKa9u/fx9GjRwHo3bsPOTk5Sc81DIPy8vLY5127dktJGd59953Y47Fjx9V77oYNn7XotUaOHN2i66POOOMsMjIyCYVCLFu2JCX3bE3Swmc1cY16pilj+IQQQqRWY7tzAdas+TDWqpeVlV1va2BTfPzxR7HHw4ePrPfcM844izFjxvOPfzzNpk0bAJg79066dMmrc+5TTy2OdTvfccevyMrKZvjwESkps8vlYvz4E3jvvVUsX76U666bU2/LpNVI4LOYGmP4TGnhE0IIkVrxM3SHDEke4IqK9vPnP/8+9vnll1+F0+ls8eubpsmXX34ORMbvNdQ1OmLEKAAef/whANxuN+edd0FsbGG8++9fCEB2dg5Tp57f4rLWNmHCSbz33ioOHTrI5s2bGDGi/rBqJRL4LCZ+sWWFBD4hhBCpVV/gCwaD7N+/j1WrVvKPfzxNeXlkVu6ECRP53veuTcnr79u3F5/PB8Cxx/Zv1DWBQIBdu74B4LjjBiUMe+Xl5ezfvw+AQYMGp6SstRUWDok9/vTTjyXwiearsSyLtPAJIToRpRRBM9TWxWh1Tt3Rql2D8RM2fvazm+o91+l0ctFFlzJnzo2xPWtbKhrKgHrHD8b7+usdsUWPk4W5+Pc1aFB6duwYOHAQmqahlOLzzzel5TXSRQKfxfiD1SFPyRg+IUQnoZRi4bqH2HH0m7YuSqs7Lrc/Px/3w1YJfQcOFFNScrhR5w4bdjwLFvyBnj17prQM8Wv5ZWfnNuqa7dsbDnPxLZf1tfDt3r2LK664CJfLRWHhUObOvZMBA45rVDkyMz3k5+dz+PBh9uzZ3ahrrEICn8V4A+HYY0Na+IQQnUr7GQDfXsVP2Bg/fgIXX1y9sHJlZQW7dn3D8uUvceTIEb744nPuuWcBCxc+kNIwGgoFY489Hk+jrtm+fVvscWNa+Orbk9fv93H22VP53/8+ZePG9dx77x+4775HGlUOiExeOXz4MAcPHmz0NVYggc9qtOpOXU1a+IQQnYSmafx83A+lSzfN4lvBJk48mUmTTq9zzmWXXcXs2Vezf/8+1q5dw9tvv8mZZ34nZWVwOKonflRWNm5dv2jg0zQtaeDbujUS+Gw2G/37J2+xGzx4CL/85V18/fUOvv/9S9m0aSOGYWCz2RpVFo8nC4gEx/akXazDt379eoYNG8aaNWsadb7P5+Pee+/l7LPPZsSIEUyYMIE5c+awfv36NJc0tWQdPiFEZ6JpGi6bs9P915rj9+IDX7JWsC5dunD99T+Kff7ii/9OaRlyc6u7ccvLjzbqmmjg6927D5mZdVsFAwE/u3dHhgP07z+gUbOJBww4jry8fILBALt372pUOYDYhJH2tCQLtIMWvp07d/KjH/2o0WvSKaX40Y9+xPvvv893v/tdrrnmGkpKSvjnP//JVVddxeOPP87JJ5+c5lKniJIWPiGEEKkT36U7eHDyJVlOP/1McnL+QFnZUTZs+Ix9+/bSu3efeu9dWlrKkiX/5oMP3mPPnl0YhkFBQQ/GjZvApZdeQb9+xwLQq1fv2DWN2Zt3//59VFREFn9O3p27rcFJHYkMGjSYtWvX8NVX2+jff0CjrvH7/UBkF5L2xNItfG+++SaXXnppk/rJX331Vd5//32uv/56Fi1axJVXXslNN93ECy+8gNvt5u67705jiVtOi5unKy18QgghUqWk5DCHDkV+nxYU9KBLly5Jz7Xb7ZxyyqTY5ytXvlXvvT/++COuuuoSnnzycY4cKWXChImMG3cCgUCApUtfqDHBoVev3rFWum++2dlgubdt2xp7nGzCRvz4vYEDGzdD98iRI7GWw/gxgg05fPgQAN26FTT6GiuwbAvfnDlzePfddxk0aBCnnnoqr7zySqOue//99wG44oorajzfq1cvTjzxRN566y1KSkrIz89PeZlTQYvfP9eUvXSFEEKkRnQHCqh/UkPUySd/mxUrlgOwevVKrrzy6oTnbdq0kfnzb0HXdX75y7v4znfOiXV3KqVYvfpdjj++ercLXdcZNux4Pv10LQcOFHPo0MF6F1/evj0+8CVuvYs/pzHvDeDee/9AaWlJnevr4/P5YtdEWyzbC8u28O3YsYOf//znvPTSS/Tv37/R182dO5cXX3wx4TTyw4cjU9EbOzCzLcSPCJCdNoQQQqRKzfF7Q+o5M2LixJNxOBwAbN68KdayFS8YDHLXXb8gEAjwq1/9H2efPbXG2DZN05g06fQ6rYkTJ1YPrdq8uf717GrO0E0c5uJbCo85pl+99wNYtWolb731BgUFPQD46qvtDV4DNVsSU7VlW2uxbAvfihUrmrWFS15eHnl5dffX+/TTT/nss88YOnRojQGjzWG3py8nx3fpoplpfS1RP5tNr/FRtC2pD2tpTH2YZvsa1N5eRfOVpoGqp2MoOosVGhf4MjM9jB49lk8++RjTNHnvvVVccMFFNc5ZseJl9u3by+TJU2p0ATdk0qTJPPTQfQCsW7eW006bnPTcaJduVlZWjfF/8aI7ggCUlpbQs2evpPcrKzvKn//8O5xOF/fccy9z5lzDgQPFlJUdJSen/nwQv9jy+PEnJjynsfURZbNprfK73rKBLxX79UUVFxdz2223AXDzzTe36F66rpGX17h1g5ojftKP3Z7e1xKNk5PTvgbmdnRSH9ZSX334/TYOHdJb7RdaZ9fQH0Nbt1Z36Q4bNqxRdXLqqZP45JOPgUi37sUXX1Lj+KpVKwGYPv3iJtVx//7HMmrUGDZs+Iy3336Tn/3sFux2R53zKisrKCqq3i4t2Wvk5VUP0/rpT39Ev379uOOO/5ewe/e++/7M4cOHuemmnzBs2FD69x/Atm1b+frrrxg//oR6y7127UcA9OnTlxEjhtd7bkP1YZoauq6Tm5uJ2+2u99xUsGzgS5U9e/Zw3XXXsXfvXmbOnMmUKVNadD/TVJSVeVNUugTi/hwI+YOUljZujSKRejabTk5OBmVlPgxDZky3NakPa2lMfQSDAUzTxDAU4bDUWbpoWqQ+DMNM2qJ09OgRioqKgMjCwQUFPRtVJyeddArwJwA+/XQtR4+Wxdahg+pWw6FDj29yHU+ffgkbNnxGaWkp7733Hqecclqdc778ciuq6k0NHDg46WvMmvVDSkoOV3XtKjRNp2/fY+uc//77q3n99RWMGDGKSy+9inDYZNCgQrZt28qWLVsYPXpc0vKWlZWxbt2nAJxzznlJy9KY+gAwDIVpmhw96sXna9oQrpycjCb3dnTowLdhwwZuvPFGDh48yHXXXcfcuXNTct90/uCK79I1TEN+SFqAYZhSDxYi9WEt9dWHYcjEs9YQDRX1hYvc3C68994nTb53nz59672urOwouq7jcjW9hWry5Ck89thD7N+/jxUrXkkY+EaPHtOoco8YMZKnn36u3nPKy8v54x9/i8vl4o47fhVbT2/w4EJee63hiRtvv/0moVCIzEwPF100I+l5jamPeK31B1GHbWP/73//y9VXX82hQ4eYO3cu8+bNa+siNYoW/w9E1uETQghhYR5PFqZpNmnh4ii73c51180BIt3FjZ040Vz337+QQ4cOMmfOjTVm2EYngjT0+kuXvgjAJZdc1uBYPyvqkIHvP//5Dz/+8Y8xDIO//OUvzJw5s62L1ATViU/J1mpCCCEsbPz4CQA89NAivN6aw52Ki4tiY96SOfvsqQwaVIhSisWLH01bOT/88H1WrFjOqFFjmDGj5rJt0QksX3+9I7Z4c21r165h+/atZGZ6uPzyq9JWznTqcIHvyy+/5LbbbsNut/PXv/6V7373u21dpCaJ79JV0sInhBDCwubMuZGcnFw++OA9Lr30Am699cf84hdzufbaK5kxYxobN26o93pd17nllnlomsaqVe/UWDomVSorK/jjH3+L2+2u0ZUblZ2dTc+everdYu2JJyJhdNasG9pl6x608zF8u3fvZt26dfTr14+xY8cC8Mc//pFAIMDpp59OUVERy5Ytq3PdWWedRWZmZmsXt1Hiu3SlhU8IIYSV9et3LE888SxPPbWYtWvX8MknH+N2uyko6MH06Zdw9tlTG7zHyJGjWb16bdrK+MADf+HAgWJ++tNb6dv3mITnDB5cSFHRfrZv31pni7XVq1eyceMGxo+fwIwZl6etnOnWrgPf2rVrmT9/PtOnT2fs2LGEw2HWrFkDwMqVK1m5cmXC69566y3rBr4aLXyy8LIQQghr69mzF/Pm/aKti5HUvHm/aLB8v/vdnxM+HwgEuO++e/F4PMyf/6sai0q3N5pSjZ1HIiAyI62kJH1Lpbz/r58zqiyybcvmk6Zy0qhL0/Zaon52u05enofS0kqZFWoBUh/W0pj6CIWCHD68n65de+FwpG5tVVGX3a7L94WFNKY+WvL9kZ/vafKyLB1uDF9HomRrNSGEEEKkgAQ+i4nv0jVNaXwVQgghRMtJ4LOYmuvwhdusHEIIIYToOCTwWYwm6/AJIYQQIsUk8FlM/PwfUwKfEEIIIVJAAp/l1FiIr+2KIYQQQogOQwKfxWhKunSFEEIIkVoS+CxMunSFEEIIkQoS+CxGky5dIYQQQqSYBD6LqbGXrgQ+IYQQQqSABD6LqdHCJ126QgghhEgBCXwWU3MdPtlpQwghhBAtJ4HPaqRLVwghhBApJoHPYuIXXpZJG0IIIYRIBQl8FlNjHT4lXbpCCCGEaDkJfBZTc9KG0XYFEUIIIUSHIYHP0qRLVwghhBAtJ4HPYmqM4ZNZukIIIYRIAXtbF0DUFD+GTyZtCCGEEPVTSvGvf/0dr7eSQYMKOe20yW1dJEuSwGcxNWfpSgufEEIIUZ8lS57nwQf/AoDT6eSJJ/5O//4D2rZQFiRdupZTYyG+tiuGEEIIYXH79+/jkUceAGDMmHEEg0F++9vfYBgy6bE2CXwWI+vwCSGEEA1TSvH73y/A5/Ny+eXfY+HCBygsHMrnn2/iX/96tq2LZzkS+Cym5hg+aeETQgghElm69EU+/XQtw4eP5IYbbsLpdLJgwe/xeDwsXvwY33yzs62LaCkS+CxGxvAJIYQQ9Ssq2s9DD91HTk4uv/nN77DbI1MS+vTpy7x5vyQYDEjXbi0yacNipEtXCCFEZ7Nx43puvHEWmqaxePGzDB5cWO/5PXv24s03VyU8dsYZUzjjjE9SWr4PPniPuXN/isPh4Kmn/kW/fsem9P6tQQKfxcR36WrSwieEECINlFKcc85kKioqEh53Ol3k5eUxdOgwvvOdqWld6sQwDP7853tQSnH22VMbDHtt4VvfOoUxY8bx2Wfr+Mtf/sjChQ+0dZGaTLp0LUar8VgCnxBCiNTbu3dP0rAHEAwGKC4u4t133+HOO2/jttt+QiDgT0tZXn/9VbZv34qu61x99XVpeY1UuPbaWQB8/PFHrF27po1L03TSwmcx8YFPSQufEEKINNiy5cvY47FjxzNjxhWxzw0jTFFREatWvcPGjesB+PDD91m06M/MnXtnSssRDod58snHAZg06XRLd5WecMKJDBkyjC1bvuDxxx9mwoSJbV2kJmkXLXzr169n2LBhrFnT+ET90ksvceGFFzJmzBhOOeUUfvOb33D06NE0ljI1anbpyhg+IYQQqbdlyxexxyed9C0mTTo99t/kyVO44orv8fDDi7nkksti57366suUlZWltBxvvfUGRUX7AbjwwktSeu90uOCCiwD4/PNNrF//vzYuTdNYPvDt3LmTH/3oR5hm48PPo48+yu23306XLl247bbbOP/883n++ee5+uqr8fvT0ySdKtKlK4QQIt22bq1u4RsyZFjS866//iZ0PRIVDMOoERRTYcmS5wEoKOjB+PETUnrvdJgy5Ts4nU4Aliz5dxuXpmks3aX75ptvcueddzapZa6oqIj777+fSZMm8eijj8b+oQ4fPpxbbrmFZ555htmzZ6eryC1We1kWTZPVWYQQQqTWtm1bYo8LC4cmPS8jI4Pu3QsoLi4CwOutTFkZdu3ayebNGwGYNGkymqYlPXflyrf4xS/mNfu1Jk2azG9/+8dmXx+VmelhwoSJvP/+alavXkVFRQVZWVktvm9rsGwL35w5c7jpppvo3r075513XqOvW758OaFQiGuvvTYW9gDOO+88+vTpw5IlS9JR3BSSWbpCCCHSZ//+fbGGlN69+5CTk5P0XMMwKC8vj33etWu3lJXj3XffiT0eO3Zcvedu2PBZi15r5MjRLbo+3tix44HIxJaPPno/ZfdNN8u28O3YsYOf//zn/OAHP+DRRx9t9HXr10cGmI4eXbdyR44cyeuvv055eTnZ2dkpK2sqycLLQggh0qmx3bkAa9Z8GGvVy8rKrrc1sKk+/vij2OPhw0fWe+4ZZ5zFmDHj+cc/nmbTpg0AzJ17J1265NU596mnFse6nu+441dkZWUzfPiIlJU7vqxr1nzIlClnp+ze6WTZwLdixYpYP3lTFBUVkZOTk7CJtWfPngDs3buXoUOb/4/Wbk9fw6gWl/E0FDabZRthO7zo117qwBqkPqylMfVhmsm76ETqRHtCGzsEKH6G7pAhyX8XFhXt589//n3s88svv6pZv5cTMU2TL7/8HIiM3+vWrXu9548YMQqAxx9/CAC32815511Qoycv6v77FwKQnZ3D1Knnp6S88YYMGYbD4SAUCsW6pOM1tT5sNi2tuSLKsoGvuf+oysvLyczMTHjM7XYD4PV6m10uXdfIy/M0+/qG1J60kc7XEo2Tk5PR1kUQcaQ+rKW++vD7bRw6pDf6F5pSCsLBVBavfbA76x2/1liN/WMovoVv2LDja9RNMBhk3769rFq1kmeffSo2K/fEE0/i2mt/kLJgsnv3Hnw+HwD9+w9o1H0DgQC7du0CYODAQTiddSNMeXk5+/fvA2Dw4MK0BCm73U3v3n345pud7N69C8MI4XK56pzXUH2Ypoau6+TmZsbySTpZNvC1REPr19lstmbf2zQVZWXND4wNqTEzV8GRI5XSs9tGbDadnJwMysp8GIYskdPWpD6spTH1EQwGME0Tw1CEw/XXmVIK78v/h1m8PR3FtTRbj8FkTLuj2aFP0yL1YRhmo35fbN1aPWHjJz+5sd5znU4nF110KXPm3AjYGqzHxtqzZ2/scXZ2dqPuu23bdgwjDMDAgYMTXvPFF9WziJOdkwrRcY9KKfbu3Vdj/cDG1odhKEzT5OhRLz5f0/b8zcnJaHJvR4cLfB6Ph9LS0oTHon9NtHRGTbr+AUGtLl1lEg437htYpI9hmGmtc9E0Uh/WUl99GEbTfnhpSBdwc0R/RzTmd8WBA8WUlBxu1H2HDTueBQv+EBsOVZ/du3dxxRUX4XK5KCwcyty5dzJgwHFJz49fzy87O7dR5dm+vTqoDhqUePu1+O7qQYMGp6y8tcWXufbahE2pD6BRfxClQocLfH379mXz5s14vd46XbtFRUXouk6PHj3aqHQNk3X4hBCdkaZpZEy7Q7p00yy+O3f8+AlcfHH1wsqVlRXs2vUNy5e/xJEjR/jii8+5554FLFz4QIPl8/t9nH32VP73v0/ZuHE99977B+6775Gk54dC1fXs8TRu6NL27dtij5OFufjlZurbk7ep5a0tvszBYKDR17WlDhf4Ro0axX/+8x82bNjASSedVOPYxo0bGTx4sKXXzKkR+CTvCSE6EU3TwFF3LJRInfgWsIkTT2bSpNPrnHPZZVcxe/bV7N+/j7Vr1/D2229y5pnfqfe+gwcP4Ze/vIuvv97B979/KZs2bcQwjKRDqByO6nH6lZWNW9svGvg0TUsa+KLd1Tabjf79k7fYNbW8tcWX2elsH/9mO9x0t3POOQeHw8Ff//rXGmP5XnnlFfbt28dFF13UhqWrn1KqRquetPAJIYRIpfjAl6wFrEuXLlx//Y9in7/4YuN3lBgw4Djy8vIJBgPs3r0r6Xm5udVdouXljdtcIRr4evfuQ2Zm3VbBQMDP7t3fAJGJII2Z/NnY8tYWX+b61jG0knYd+Hbv3s2yZcv43/+q97Pr06cPN9xwA6tXr+a6667j3//+N/fccw+33347I0eO5PLLL2/DEtdPoWqN4ZPAJ4QQInXiu3QHD06+JMvpp59JTk4klG3Y8Bn79u1Nem5t0da3r77alvScXr16xx43Zn/e/fv3UVFRXuP+tW3btg3DMOo9p7nlrS26cLWmafTs2avR17Wldh341q5dy9y5c3nuuedqPH/TTTfx61//mgMHDnDXXXfx2muvcdlll7F48eJWmfrcXJEWvmpa3P8KIYQQLVFScphDhw4CkbXvunTpkvRcu93OKadMin2+cuVbjXqNI0eOxFri4sfc1darV+9YK9033+xs8L7btm2NPU42YSN+/N7AgcnH78VrbHnjBYPB2NIv/fodm7K1CdOtXYzhu/nmm7n55pvrPH/RRRcl7aK94ooruOKKK9JdtJRSqBoJXJO9dIUQQqRIdPcJqH9CQ9TJJ3+bFSuWA7B69UquvPLqBq+5994/UFpaAsD27VuTnqfrOsOGHc+nn67lwIFiDh06WO/iy/H3StZ6F39OY95fU8obb+vWLwmFQkDDO4RYSbtu4eto6rbwSdITQgiRGjXH7w1p8PyJE0/G4XAAsHnzJg4fPlTv+atWreStt96goCCyEsZXX9W/puLEiSfHHm/evKnec2vO0E0c5uJbCo85pl+994OmlzcqurUbRBakbi8k8FmIQoGM4RNCCJEG8QsuNybwZWZ6GD16LBDZCu2991YlPbes7Ch//vPvcDpd3HPPvTgcDg4cKKasLPmEjEmTJscer1u3tt6yRLt0s7Kyaoz/i1deXj0WMNpql8ryRq1fH5k34HS6OOmkbzd4vlW0KPA98MAD/Pe//23wvOeff5758+e35KU6BbtuTzCGTwghhGi5+C7dwsKGAx/At751auzxqlUrk563aNGfOHz4MLNmXc/gwYUce+wAoP5xcX37HsPIkaMBeOutNwmHwwnPq6ysoKgoMmZu4MDkkzG6dMmPPf7pT29k1qyrk75+c8oLka1Z16z5CIBTT51k6WXeamtx4HvjjTcaPO/dd99lxYoVLXmpTkHXdHRVvQaQdOkKIYRIhaNHj1BcXARAVlZ20lay2r797erAt27dWiorK+qc8/77q/nPf15jxIhRXH7594DqMXQNBaiLLpoBwJEjpXz00fsJz9m+fXtsmbX6Zt/Onv1DjjtuYGwtPV3XOfbY/ikt79tvvxFbaHn69Bn1nms1TZq08dhjj8W2J4v68ssvWbRoUdJrysvLWb16daNX0u7saqzDJ3lPCCFECuTmduG99z5p8nV9+vSt97ry8nL++Mff4nK5uOOOX6HrkXakwYMLee21hidCTJ48hccee4j9+/exYsUrnHLKaXXOGT16TKPKPmLESJ5++rl6z2lpeZctWwLAsGHDGTNmXINlspImBb5QKMTDDz+MpmmRCQaaxrZt29i6teGZLVdeeWWzC9mZyMLLQggh2ov771/IoUMHufnmn9Gv37Gx56MTKxqaCGG327nuujn83//9mtWrV/LVV9sZOHCQJcu7bt0nfPHF5wDMmfPDtJUxXZoU+GbPng1EZpMqpXjwwQcZMmQIZ511VtJrXC4X/fv3Z8qUKS0raScRH/JkRo0QQgir+vDD91mxYjmjRo1hxoyay6BFJ4V8/fWOBrcsO/vsqTz33D/Yvn0rixc/ym9/+0dLlvdvf/srEJmZO2FC+5mdG9WkwOd0OvnRj6q3W3nppZc4+eSTuemmm1JesM6qZpduZB0+IYQQwkoqKyv44x9/i9vtrtE1GpWdnU3Pnr0oKtrP7t276N9/QNJ76brOLbfM48YbZ7Fq1Tts2fIlQ4Yk3wWkLcr74YfvsW7dJzgcDn7609tSWrbW0qKFl99+++1UlUOQbKcNIYQQwloeeOAvHDhQzE9/eit9+x6T8JzBgwspKtrP9u1b6w18ACNHjmb16vqXZmmJlpb35JNPadYYSCvRlGr5Ym+lpaW88MILfPzxxxQVFXHKKacwb948HnnkEQoLCznjjDNSUVZLMAyTkpLKtNxbKZOKx6+Lfb7T7WDMDxZjGGZaXk/Uz27XycvzUFpaSTgsddDWpD6spTH1EQoFOXx4P1279sLhaB/bT7VXdrsu3xcW0pj6aMn3R36+B5utaQO/Wry12urVq7n11lspKyuLTeQYNmwYAK+//jqLFi3immuu4fbbb2/pS3V8tbK3LnM2hBBCCJECLZoXsG3bNm666Sa8Xi9XXnkljz76KPENhjNmzCA7O5unnnpKun8bo1bgk1m6QgghhEiFFrXwPfzwwwSDQR5++GFOP/30OsevuuoqRo4cyWWXXcazzz7bobp200LVbP6VdfiEEEIIkQotauFbs2YNo0aNShj2okaNGsW4cePYtq3+1atFXTqQgiGWQgghhOjkWhT4ysrK6NGjR4PndenShaNHG96QuNOz2TlE9V6AGgol3bpCCCGEaKEWBb6CggK2bNnS4HlbtmyhoKCgJS/VKWiaztO2GTxUeTogLXxCCCGESI0WBb7TTjuNXbt28be//S3pOX/729/Ys2cPp556atJzRDUDnbAZGVqpKTClhU8IIYQQLdSiSRs33HADr732Gvfccw9r1qzhpJMiW40cOHCAF154gVWrVvHmm2+Sk5MT25ZN1E8pYhFPA5QykE3WhBDtm/zhKkRdrft90aLAV1BQwBNPPMGPf/xj3nnnHVauXAlEJnOsWbMGpRQFBQUsWrSI3r17p6K8HZ5SClNFAp6uFCaK5DsQCiGEdWlVe0OapiwILERt0e8LTWudRp0WL7w8bNgwXnvtNd544w0++ugjioqKMAyDgoICJkyYwNSpU3G73akoa6dgKlBVgU8DFPKDUgjRPtlsdjRNJxgM4HJltHVxhLCUYNCPpunYbK3TrNOiwPf3v/+dIUOGcMIJJzB16lSmTp2aqnJ1WgqFWdWFqwOmMmVTXSFEu6RpGm53Jn5/JVlZubEWPyE6O6UUfr8Xtzuz1b4vWhT4HnjgAXJycvjPf/6TqvJ0ekqBWZXwNAWGBD4hRDuWkZGFz1fJ0aOHyc3tKqFPdHpKKY4ePYxhGGRkZLXa67Yo8Hm9Xk444YRUlUUQnbRRFfgApaRLVwjRfjmdLrp06caRI4cIhQK43Zk4nW50XUf+mk0d09QwDJkcYxV160NhmibBoB+/34thGHTp0g2n09VqZWpR4Js0aRJr1qxh79699OnTJ1Vl6tSUUrHAp6MImwYya0MI0Z653Znk5/fA56vA662gsrKsrYvU4ei6LpNjLCRZfWiajtudSUZGVquGPWhh4Lv66qvZtm0b06ZN48wzz6SwsJDc3OTjNC655JKWvFynEJmlW92la0oLnxCiA3A6XTidLnJy8jEMQ3ovUshm08jNzeToUa+08llAsvqITtBoq2ENLQp83//+99E0DaUUL7/8coNvQgJfwxTEtfBJ4BNCdCyapmG3t3iBCBHHbtdxu934fAbhsPzOaGtWrY8WfdddeOGFMgA3xWpM2gBM2VpNCCGEEC3UosD3+9//PlXlEFVMpdDjZumGldHGJRJCCCFEe2fZPbtKS0tZsGABkydPZtSoUUybNo0XXnihUdcGg0EeeOABzjrrLEaMGMHJJ5/MvHnzKC4uTnOpWy6+hU9HSZeuEEIIIVqsRS18S5cubdR5DoeDrKws+vXrx4ABAxo83+v1MnPmTLZu3cqVV17Jcccdx+uvv86dd97JoUOHuOGGG+q9/uc//zlvvvkmp556Kj/4wQ/YtWsXzz77LGvWrGHJkiXk5+c3qtxtofakDUMCnxBCCCFaqEWB7/bbb2/yGL5BgwZxzz33cPzxxyc959lnn2Xz5s0sXLiQc889F4DLLruM2bNn88ADD3DBBRfQq1evhNdu2rQpFvb++te/xp4fOnQo8+bN48knn+SWW25pUplbU+11+Ezp0hVCCCFEC7WoS/fHP/4xI0aMQClFTk4OU6dOZfbs2cyaNYvzzjuP/Px8lFL06tWLKVOmUFhYyLZt2/jBD37A/v37k9536dKl9OjRIxb2IDKza9asWYRCIZYvX5702p07dwIwefLkGs9PmTIFgM8//7wF7zj94tfhsyGTNoQQQgjRci1q4Rs9ejQPPPAAU6dO5e677yYzM7PG8WAwyG9+8xuWLVvGH/7wB0444QSef/55fvnLX7J48WJ+8Ytf1LlneXk5O3bs4Kyzzkr4egAbNmxIWqaBAwcCsG3bthrPf/311wD06NGjaW+ylcWP4QMwzXAblkYIIYQQHUGLAt+DDz5IQUEBv//973E6nXWOO51O7rrrLj766CMWLVrEM888w4wZM/jb3/7GqlWrEt6zuLg41ipYW0ZGBrm5uezZsydpmYYNG8b3v/99/vnPfzJw4EAmT57M3r17+c1vfkNWVhY/+MEPmv+Gq9jt6ZvrEj9LF0ApI62vJ5Kz2fQaH0XbkvqwFqkP65C6sBar1keLAt8XX3zBpEmTEoa9KJvNxsiRI1m5cmXsuYEDByYNfOXl5QB1WgujIosZ+uot1zXXXMPnn3/O3Xffzd133x273+OPP87gwYPrvbYhuq6Rl+dp0T3qo2k1W/gcTltaX080LCcno62LIOJIfViL1Id1SF1Yi9Xqo0WBz+Px1NvaFrVnzx5cruo944LBIG63O+G5qmrMmkoydk0pVbXpdmLbt2/nyiuvxOfzMXPmTMaNG0dRURFPPPEEs2bN4qGHHuJb3/pWg2VOxjQVZWXeZl/fmPujqgOfz+ultLQyba8nkrPZdHJyMigr82EYMlu6rUl9WIvUh3VIXVhLa9RHTk5Gk1sQWxT4xo8fzxtvvMFzzz3HZZddlvCcJUuWsGnTptgkilAoxIYNG+jbt2/C8z2eSGuW3+9PeNzv9yedoQvw8MMPc/ToUe69916mTp0ae37q1Kmcf/75zJs3j7feeqveVsmGpHOrFFMBcS18IcNaW7N0RoZhSh1YiNSHtUh9WIfUhbVYrT5aFPhuuukmVq9eza9//WveeecdzjjjDHr16oVpmhQVFfHOO+/w7rvv4nQ6ufnmmwkEAsyaNYvS0lLmzJmT8J59+/ZF0zSKiorqHPN6vZSVldGzZ8+kZdqyZQsej4dzzjmnxvP5+flMmTKFf/3rX+zYsYOhQ4e25K2njVIKM27ytDJCbVgaIYQQQnQELQp8gwcP5rHHHmP+/PmsXLmSd999t8ZxpRQ9e/bkd7/7HccffzxfffUVa9euZdSoUUlbBD0eDwMHDmTjxo11jq1fvx6AcePGJS2T0+lEKYVhGHU26DZNM1Yuq6o9S1fJOnxCCCGEaKEWBT6AE044gRUrVrBy5Uo+/PBD9u3bRzgcpmfPnkycOJHvfOc7sfF7eXl5PPnkk5x44onYbLak95w2bRoLFy7k1Vdfja3Fp5Ri8eLFOJ3OGl21tZ122mls3ryZ559/niuuuCL2fHFxMW+88Qbdu3dv8cSNdFJVXboGVevwhaSFTwghhBAt0+LAB5Gt084666yEa+fFy8/P5+STT27wftdccw0vv/wy8+bNY9OmTQwYMIDXXnuNDz74gLlz51JQUADA7t27WbduHf369WPs2LEAzJw5k7fffpu77rqL9evXM27cOIqLi/nnP/9JRUUFDz74YJ2WPyuJtj6aaNhQsg6fEEIIIVosZclnw4YNrFmzhqKiIoYOHcqMGTNYuXIlo0aNavLetW63m2eeeYaFCxeybNkyKisrGTBgAPfccw8XXnhh7Ly1a9cyf/58pk+fHgt8WVlZ/P3vf+eRRx7h9ddf55VXXiEzM5Nx48Zx4403MmrUqFS95ZSL7LIRYaDhQKFkxpUQQgghWkhTLRzQtm/fPm677TbWrVsXe+7888/nD3/4A5dddhlffvklf/rTnxps/WsvDMOkpCQ9y6SYSjHrnncA+F3XZ8lUJptOm8HJQ85t4EqRDna7Tl6eh9LSSkvNtOqspD6sRerDOqQurKU16iM/39PkZVlatAx0aWkp3/ve9/j0008ZPHgw1113XY0JEcceeyyBQICf/exnfPnlly15qU4h/msXnbhhhqVLVwghhBAt06LA9+ijj7Jv3z5++MMf8vLLL3PbbbfVOP6HP/yBX//614TDYR5//PEWFbQziG9rNaoCnzIk8AkhhBCiZVoU+P773/9y7LHH8pOf/CTpOZdffjmDBw+OLakikosPfLEWPgl8QgghhGihFgW+4uLiRi1gPGDAAA4cONCSl+oU4rt0Da0q8MksXSGEEEK0UItm6WZnZ7N3794Gz9uzZw/Z2dktealOQdc1HDYdtOoWPhWWhZeFEEII0TItauE74YQT+Pzzz/n444+TnvPhhx/y+eefM378+Ja8VKdgt+ncfMkofnb52OouXWnhE0IIIUQLtSjwzZ49G03T+OEPf8jf/va32ExcwzDYvXs3zz77LD/+8Y/RdZ0f/OAHKSlwRzdmcDfGD+tR3cJnSgufEEIIIVqmRV26I0eO5O677+b//b//xz333AOApmmsWLGCFStWAKDrOnfeeWdsYWTROKYWyeLKkMAnhBBCiJZp8U4b06dPZ9SoUTz99NOxnTYMw6B79+6ceOKJfP/732f48OGpKGunoYG08AkhhBAiZVKytdrAgQP5zW9+k/R4dB2+H/7wh6l4uU7B1CTwCSGEECI1mjWGr7i4mOeff57HH3+cd999l/p2Z/voo484//zzue+++5pdyE5HkxY+IYQQQqROk1v4HnvsMe677z6MuLFlI0aM4NFHHyU/Pz/23OHDh/nd737Hq6++ilIKl8uVmhJ3EmZVFtdM2RdRCCGEEC3TpBa+N998k4ULFxIOhxkxYgRnnXUWXbp0YePGjcyfPz923uuvv87UqVNjYe/kk09m2bJlKS98R6aikzakhU8IIYQQLdSkFr5//vOfaJrGvHnzuPbaawGoqKjguuuuY9WqVezcuTMWCpVSdOvWjdtvv53zzjsvHWXvsDRNi43hQwKfEEIIIVqoSS18W7dupXfv3rGwB5CVlcXPfvYzlFLcf//9sbB38cUX89prr0nYa6Zoly5KunSFEEII0TJNauE7cuQI3/72t+s8H112ZcWKFXg8Hu655x7OPPPM1JSwE9Ko7tJFxvAJIYQQooWaFPjC4TC5ubl1no/fJ/fxxx+XRZZTQMUmbUiXrhBCCCFapkVbq0VpVePNTjjhBAl7qaBV77QB0sInhBBCiJZJSeCL6tmzZypv16lFu3RlWRYhhBBCtFRKA1+0pU+0jIYG0cAnkzaEEEII0UIpDXwidWJduvXsYiKEEEII0RhN3mnjv//9b8IZuJqmJT0Wf1w0TKN60oauTDRNcp8QQgghmq/Jgc/r9eL1ept8TLp7m0iXLl0hhBBCpEaTAt/TTz+drnKIeBoozRZ5KE17QgghhGihJgW+E088MV3lELXFAp+08AkhhBCiZWTShiXFz9KVFj4hhBBCtIwEPouKdunq0sInhBBCiBaSwGdBmgaaLmP4hBBCCJEalg18paWlLFiwgMmTJzNq1CimTZvGCy+80OjrN2zYwPXXX8+ECRMYP348V1xxBatXr05jiVOsKvDpSOATQgghRMtYMvB5vV5mzpzJc889x1lnncUdd9xBfn4+d955J4888kiD169atYorr7yS7du3c8MNN3DTTTdx+PBhZs+ebfm1ADUtsg4fcbN0ZUUbIYQQQrREk9fhaw3PPvssmzdvZuHChZx77rkAXHbZZcyePZsHHniACy64gF69eiW81ufzcccdd1BQUMDzzz9Pfn4+ANOnT+fss8/mT3/6E1OmTGm199Ismhbr0rVJ4BNCCCFEC1myhW/p0qX06NEjFvYgsnDzrFmzCIVCLF++POm1b731FgcPHuTmm2+OhT2ALl26MH/+fKZNm0YwGExr+VMiOoZPunSFEEII0UKWa+ErLy9nx44dnHXWWXWOjR49GoiMz0vmo48+AuC0004DwDRNfD4fHo+HCy+8MPUFTgMN0PRI1ehKEd1sTQghhBCiOSwX+IqLi1FKJeyyzcjIIDc3lz179iS9/quvvsLj8eD1evn1r3/NO++8QzAYpG/fvtx0001Mnz69xWW029PXMKpXbammx03asNk02ZquDdhseo2Pom1JfViL1Id1SF1Yi1Xrw3KBr7y8HIDMzMyEx91uNz6fL+n1ZWVlaJrGFVdcwZAhQ/jd736H3+/nqaee4vbbb6e8vJyrr7662eXTdY28PE+zr28MpRR2lzPyekqRm5ve1xP1y8nJaOsiiDhSH9Yi9WEdUhfWYrX6sFzgU1Xrzqkk688ppWKtYIkEg0EqKio48cQTefjhh2PPT506lXPPPZd7772X6dOnk52d3azymaairMzbrGsbw27Xycpyo8yqlj4UZWWVGEbaXlIkYbPp5ORkUFbmwzBkAey2JvVhLVIf1iF1YS2tUR85ORlNbkG0XODzeCKtWX6/P+Fxv9+fdIYuRLp9Ab7//e/XeD4zM5MLL7yQhx56iHXr1sXG+DVHOJy+byhNi0xQqd5pQxEOKwxDxvC1FcMw01rnommkPqxF6sM6pC6sxWr1Ya0OZqBv375omkZRUVGdY16vl7KyMnr27Jn0+mgY7NatW51j0ecqKipSVNrUizZs6rZo4GvDwgghhBCiQ7Bc4PN4PAwcOJCNGzfWObZ+/XoAxo0bl/T66EzeLVu21Dm2a9cuIBIqrU7XHZGPyDp8QgghhGgZywU+gGnTprF3715effXV2HNKKRYvXozT6WTq1KlJrz3//PNxOBw89thjeL3VY+0OHjzISy+9xDHHHMOoUaPSWv5U0G2R3nabgqq9N4QQQgghmsVyY/gArrnmGl5++WXmzZvHpk2bGDBgAK+99hoffPABc+fOpaCgAIDdu3ezbt06+vXrx9ixYwE45phjmDdvHnfffTczZsxgxowZBINB/v73v+P1elm0aFG7WOIkGvhkL10hhBBCtJQlA5/b7eaZZ55h4cKFLFu2jMrKSgYMGMA999xTY/HktWvXMn/+fKZPnx4LfBCZsHHMMcfw+OOPs2jRImw2G6NHj2bRokWMGTOm9d9QM9hs1QsvJ5mwLIQQQgjRKJYMfAD5+fncfffd9Z5z0UUXcdFFFyU8dvrpp3P66aenoWStQ7dFxvDZAFNZZ5aPEEIIIdofS47hE/EtfBL4hBBCCNEyEvgsylbVwqcrhYkEPiGEEEI0nwQ+i7LZ47t0ZZsNIYQQQjSfBD6Lstuie+lKl64QQgghWkYCn0Xp9uplWQxp4RNCCCFEC0jgsyi7vXprtYYCn65bf11BIYQQQrQdCXwWFW3hswGGkTzwaRp4DR+61KQQQgghkpCYYFG6zRZ7HDJCSc/TNI3KUCVlwQpp6RNCCCFEQpZdeLmzs1ctywJghINJzwsrg2AoRIAQDpsdt+6WnTmEEEIIUYO08FlUtEsXwKynhS9kBjGUSdgIU+o/ioFM8BBCCCFETRL4LEq3V3fpmkYg4TmaphEwgphmZNmWYChEqf8IaNLEJ4QQQohqEvgsyhY3hi8YCic8R9MU/nDNMOgN+jkaLEOT4XxCCCGEqCKBz6LsNlusczYcStylG1YG4VozeJVSVAQqqQxXoknqE0IIIQQS+CzLZtMwiQS2cDhxl27QCGKadcfsGabJUX85QRWQlj4hhBBCSOCzKpuuYVaFNSNBl25s/F6SKbkhI0yp/wgGsi2bEEII0dlJ4LMom65hRFv4jFDdljpN4Q/7672HPxjkiP8ImtSyEEII0alJFLAoTYtr4QvXHcMXMsMYZsOtd5VBH0eDZbIosxBCCNGJSeCzsGgLn2GEgerApmlV6+81IvAppSj3V+INe2UShxBCCNFJSeCzMLMqoJm1dtrQNI1AOIBq5JYahmlQ6j9KSCXfsUMIIYQQHZcEPguLztINhYM1xvApFP56tltLJBQOU+I/itJlEocQQgjR2Ujgs7D4SRvxQmaoUd25tQWCfo74j8okDiGEEKKTkV/9FqaqqseIa+HTNAgYgdh2ak27H1QGfJQHK2QShxBCCNGJSOCzsOgYvsikjYjI+L0giubtl2sqk4pgJaaSrl0hhBCis5DAZ2FGtIXPCBAORwKaqQyCRssmX5imSVgl3p9XCCGEEB2PBD4LC0erxwgRMiMtekHVvPF78QxlEjITLOYshBBCiA5JAp+FhTUbAJoRWXNP1yEYbnngU0pVtRJK4hNCCCE6Awl8FhbW7ABoRphQ2ETXdfxGICX3DoSDaFrzxgEKIYQQon2RwGdhhh4JfMoIEQ4pwmaYUIJt1pp1b9MkrIyU3EsIIYQQ1mbZwFdaWsqCBQuYPHkyo0aNYtq0abzwwgvNute//vUvhgwZwpIlS1JcyjSzOQDQjBBKU/hDQYwUza41zMg4PiGEEEJ0fPa2LkAiXq+XmTNnsnXrVq688kqOO+44Xn/9de68804OHTrEDTfc0Oh77dixg9///vdpLG36KJsTAM2ILMFcGfY3a/29RExlEjJCuB1uGrlDmxBCCCHaKUsGvmeffZbNmzezcOFCzj33XAAuu+wyZs+ezQMPPMAFF1xAr169GrxPKBTi1ltvxTDaZ9elZo8EPt0Mo5TCG/ShaaQsoPmNIDlOrdF78gohhBCifbJkl+7SpUvp0aNHLOxBZMHhWbNmEQqFWL58eaPus2jRInbu3Mns2bPTVdS0sjlckY/KIKQMvIEQqVxLJWyEMGUcnxBCCNHhWS7wlZeXs2PHDkaPHl3nWPS5DRs2NHifjz/+mMWLF3PnnXfSt2/flJezNdgd7shHZRBWIQLB1C6WbJhKFmAWQgghOgHLdekWFxejlErYZZuRkUFubi579uyp9x5lZWXMnTuXM888k4svvjjlkzXs9vTlZJtNj310ZmREXs80MTEIV03YsKXo9TUgjIE7je+nPYuvC9H2pD6sRerDOqQurMWq9WG5wFdeXg5AZmZmwuNutxufz1fvPX71q18RCoW46667Ul4+XdfIy/Ok/L615eRkkJOTA4AdE82uyHA7cbgceNypqzanUycvK/3vpz3Lyclo6yKIOFIf1iL1YR1SF9ZitfqwXOCLTiBINpFAKYWuJ0/NS5cuZcWKFTz22GPk5+envHymqSgr86b8vlE2m05OTgZlZT60qmVZHMrk8JEyQqaBXVOYIQepmmYRsBs4w25QsutGbfF1YRipmR0tmk/qw1qkPqxD6sJaWqM+cnIymtyCaLnA5/FEWpv8fn/C436/P+kM3T179rBgwQLOO+88Ro4cSUlJCRBZ5iX6saSkhOzsbBwOR7PLGA6n/xvKMEzcrsjXwqFMyv0muk3hDxq4nXaUmZrIF1RhAqEQNuv9U7AMwzBbpc5F40h9WIvUh3VIXViL1erDcr/l+/bti6ZpFBUV1Tnm9XopKyujZ8+eCa/9+OOPqaio4JVXXuGVV16pc3zBggUsWLCAp59+mokTJ6a87KnmdEW6tR1K4fWFycrSU/6PxzQVITOMTbfcPwUhhBBCpIjlfst7PB4GDhzIxo0b6xxbv349AOPGjUt47SmnnMKTTz5Z5/n33nuPxYsXM3PmTE455RSGDh2a2kKnid3hxqAq8AXDZOHEME0MU6VserWpIjtuZNgyZD0+IYQQooOyXOADmDZtGgsXLuTVV1+NrcWnlGLx4sU4nU6mTp2a8LqCggIKCgrqPB9tLRw0aBDf+ta30lfwFLM7M2KBr9IfApwoBSHDxJXC2T/+cIBcZ+oWdBZCCCGEtVgy8F1zzTW8/PLLzJs3j02bNjFgwABee+01PvjgA+bOnRsLdbt372bdunX069ePsWPHtnGpU8/miMzwcSiFNxAEPJimwgibaHY9ZQEtbIQxlIFmvWUZhRBCCJEClgx8brebZ555hoULF7Js2TIqKysZMGAA99xzDxdeeGHsvLVr1zJ//nymT5/eIQOfbo/stOEwqQp8oIi08EX3WPvqyNfYdTvH5hzT7NcxlUlIhXDiSkWxhRBCCGExlgx8APn5+dx99931nnPRRRdx0UUXNXivxp5nOfbosiyKkrilYKITN7Yd2cGS7a+goTFrxPfJd3dp1suYpknICOGyu6RbVwghhOiApA/PymxOIFJJB0oqY2HMME1KfEd59es3AVAo3t+3ptkvo4CgEUJL4T69QgghhLAOCXxWZnfGHmpmkNIjBgBh02DZV68RMALku/MA+LxkCwd9h5v9UoFwEJWy5ZyFEEIIYSUS+KxMt8cimEMPsWefF13T+OTQxxR7i3HZXFw6+AKG5A0CYPXeD5v9UpHlWcIpKLQQQgghrEYCn4Vpmka4ahs5px7i6z2V7Pfv4YuyzQCcd9x3yHXlcGrvk9DQ2HZkB/sq6i5Y3RimaRI2QykruxBCCCGsQwKfxRlVgc+hhTjgLWfl/rcBGJE3ksF5xwHQNSOf4V0ji0mv3te8Vj5TKYJmUMbxCSGEEB2QBD6LM3QbAF0ygjgHrSeoghS4CxiXfwJG3H663+59Irqms7NsN7vK9jTrtfzhIJL3hBBCiI5HAp/FRQOfrctu9Kyj6KaDqb0m49AdhOL21e3iymV0t+EArNr7YbO2STMMg7AyUlNwIYQQQliGBD6LM22RwKcRWXjZ+Hok2QY4bTYMw6zRIndyrwnYNRt7K/ez4+g3TX8tJeP4hBBCiI5IAp/FKVtkbWyHArO4P/7DBewuqsRpBjEVxCe+bGcW4wpGA5GxfE1t5TNMs2o9vpQVXwghhBAWIIHP6myR3Ta66hn08RcCsKPIAH8FNuoms5N6jcepOyj2HmRL6fYmv1zQkIkbQgghREcjgc/i8jzdARjjPJYB3SPduzsPKgJ+H7aQH2qFvgx7BhN6RPYVXr3vI0xl0hRBI9Tka4QQQghhbRL4LM7hzATAqaBft8hzxUehwhdC+SrQEmSzCT3H4ra5KfGXsvnwl016PdM0CStZgFkIIYToSCTwWZzmcAGgmwbZGRpdsyLP7z4Efr8XLejFbqtZjS6bi5N6jQfg/X0fY5iNn3lrKJOQTNwQQgghOhQJfBan2SNj+LSqbc+OjfTw8s0hFVlGpbIcR9XSLfHGdR+Fx5HJ0WAZ6w9tbvTrKaWqJm7IOD4hhBCio5DAZ3VVXbqZR/agmWGO7R4JYt8cjIQzn9eHHvKh6zWr0mFz8K1eJwLwwf6PCRmNb7ULGAE0renr+AkhhBDCmiTwWZxz2GngcOOuPET3He/TK1fhsIE3CAfLIBQOYfgrsWt1q3J0t+HkOnOoDHlZd3BDo1/TMExZgFkIIYToQCTwWZye0wP9lCtRmkb24a/pXrSevl0jx745BEpB0B/AliCg2XQb3+4daeX7aP+nBIxAo15TxvEJIYQQHYsEPotTCuy9Cyk57tsA5O9dzymeHQB8c1BhKoUv4McWDmBLMJZveNeh5Lvz8Bt+1hb9r1GvaZomISMsCzALIYQQTaBpoOsapmm95c0k8Fmewqbb8PYcQmmvEQCMK/uA4+zFFB2BQEgRDBiY/krset2Epms6p/Y+CYC1xf/DG/I16lUj4/gk8QkhhBDJaJqGroOpGQSUn/JQOcWVBynxH7Vco4kEvnZAt9nQdZ2SY8ZTkXcsujKZnf0O+VoZuw9HtkTzBYPYjHCCvTdgSN4gemR2J2iGWFP0aaNeMyQLMAshhBAx0dY7TQeDMH7Tx9HQEYq8BymuOMjByhJKvEfxhvxtXdSEJPBZnFKgo+NyONA0jQMDT8Xv6UqmFmRO9tsUHfRHunX9fvSwH5utbreupmmc2vtkANYdWE95sKLB1zVMRVjJOD4hhBCdUzTgoSnChKgMV1ISKKWospjiyoMcqizhiLccfzBAyAhbshs3ngS+9kCHDLcNXddQNjtFhWfit3noYSvj1PKVKCNMMGhg+CqxJ2lDPi73WPp4ehFWBh/uX9vgS5rKrFqPL8XvRQghhLCgSPeshtJMggQoD1VwyHeYosoDHKg4xGHvEcp8FQRCIcKGgana1/JlEvjaBTs2TcfljLTeGc5M9g85E79ycJytmJztazBNhS8YQg8HE4690zSNSX0jrXzrD23mSOBova+olCJoygLMQgghOqa64+/KOOA7RFHlAQ5WHKbUe4SKgJdgOETYNFDtLODVJoGvPdA0FBpuhx1b1cQMMzufV/VJmEqj4Mg27JUl+AN+tJAfe4LZugD9svvSP+cYTGXySfFnDb5sINy4ZVyEEEIIK2tw/F1F1fi7gI9QOIxhmrTveFeXBL52QNNt6IDdruN0VIc51b0vG0PHAJBT/AXBkIkR8GKv55/phB7jANh0+IsGd98wTCXr8QkhhGh3Eo6/89cz/q4TTFKUwNcOaGiRVj5TkeG0R/4RE9lXd5V/KADZh3ZA0I8vEEQLBdAT7LwBMCCnH7nOHAJGkC9Lt9X7uqZpElLh1L4ZIYQQIsXqG39XHB1/52+/4+9SQQJfO6BpOnrVWDq7Xcdlj7Ty5XngSEYP9oW7oJthPAe2EQgG0UI+7Alm60bupTG6+3AAPju4qd7XNZVJyJBxfEIIIawl6fi7irrj74wOMP4uFSTwtQeaTnS6rDIVbleklU/TNIYfo7MqEGnlyy3+gmAwTDjox2Ymb5kb2e14dE1nX2URB7yH6n3pgBGUmbpCCCHaTMLxd8EjFHkP1B1/Z3TM8XepYNnAV1payoIFC5g8eTKjRo1i2rRpvPDCC4261ufzce+993L22WczYsQIJkyYwJw5c1i/fn2aS50emqZjt9ljnztsGs6qFrwhveF/oeOoNJ04AhW4SnbjCwTRQ4m3WgPIcngY3OU4AD47uLHe1w4ZIYwE+/QKIYQQ6ZBs/N3++PF3vnL8wWCnGX+XCpYMfF6vl5kzZ/Lcc89x1llncccdd5Cfn8+dd97JI488Uu+1Sil+9KMf8cgjjzB06FDuuOMOrrnmGjZv3sxVV13Fhx9+2ErvInVMpZHtzMbpcAGRxZhdLju6puF2aPTvaeejwCAAcvZ/QTAUQgW9CbdaixrTPbJN2+aSLQTrmbxhmiZhGccnhBAiTRo7/i7YicffpYK94VNa37PPPsvmzZtZuHAh5557LgCXXXYZs2fP5oEHHuCCCy6gV69eCa999dVXef/997n++uv5+c9/Hnv+4osv5vzzz+fuu+/m1VdfbZX3kTKahs2TRzddp6TyEH6/D5dDx2e3EQyFGX6MxjtFQ5js/pzMsn2UHi0hnJWJ3Uge1I7NPoYurlyOBI7yRcnW2Li+2kxTETSCOO1O5HtMCCFES2mahqYpwsogZIYIhUP4jSChcGRLT8PiO1a0V5Zs4Vu6dCk9evSIhT2I/AOZNWsWoVCI5cuXJ732/fffB+CKK66o8XyvXr048cQT2b59OyUlJekpeJqYpsK0e7Dl9ia/4Dg8ud1xOJxkuh3omkbvPFAZ2WwO9QUge//n+PwNT94Y0y3Syrf+UPLJGwolEzeEEEI0S3PG34n0sFzgKy8vZ8eOHYwePbrOsehzGzZsSHr93LlzefHFF+nZs2edY4cPHwZIuN9se2CaoNuyyczrg61LL7LzC8jKzsZhdzC8r8Yq/zAAsg5uJ+z3ooK+pFutAYzoNgxd0yPjIrwHk57nN4IoGQIrhBCiATL+zrosF/iKi4tRSiXsss3IyCA3N5c9e/YkvT4vL48RI0bUaZH69NNP+eyzzxg6dCi5ubkpL3drUUrh1t04HR7CrgwcXXvi7tKNEf3sbDd6sj+ci26Gce7bQjAUTLrVGoDHkUlhl4FA/Uu0mKZJuJ5Zv0IIITonGX/XflhuDF95eTkAmZmZCY+73W58Pl+T7llcXMxtt90GwM0339yyAhJZCy9dbDa9xsdk8jJyQFeYVOB3Z5Kf52FgzzCrS4ZyqX0N2fu/oPy4MWQYAVyZuYSSjOcb13MUX5Zu4/OSLUzpfypOm7PuSRqECeGyJzjWgTW2LkTrkPqwFqkP62jNuoi2HxjKIGgECZohAuEAIdOoO/5OBx0N6FxDgqKbI9hsuqXGvlsu8EUXR0y2SKJSCl1v/D/qPXv2cN1117F3715mzpzJlClTWlQ+XdfIy/O06B6NkZOT0fA5ZgYHKw+j6WWE9XwmDA7ywqrjOD9zHRn+MhxH9uLq3oXMDAdBLXFVj8waRLdv8jnkLWFHxQ5O7Dsm4XmazSQ3JyPpDh4dWWPqQrQeqQ9rkfqwjnTVhalMguEQQSNIwAjhDwcwlYGpmyhdYbdr2K0XJ9pcdra1vjcsV0MeTyRM+f3+hMf9fn/SGbq1bdiwgRtvvJGDBw9y3XXXMXfu3BaXzzQVZWXeFt8nGZtNJycng7IyH4bR8NgGp5aBy+ajzLDRv6cLd4aDNYFBnO7+AvuOzyjrMQCXXobf5ko6VmJ0t+G8tWs1H+xax9DcoYnLpYewhZ24dFeL3l970tS6EOkl9WEtUh/Wkaq6iLTeaShMQmaIoBGKteAZpompTOmSbQRd18hxQ3m5j3A4Pd8bOTkZTW7RtVzg69u3L5qmUVRUVOeY1+ulrKws4YSM2v773/9y66234vf7mTt3LjNnzkxZGdNVgfEMw2z062Tbsyi1VxJ2ehjRr4zV24ZwmusLMkr3UFJ6ELszEy3LjZHkfsfnDWXl7vcpqjzA3qNF9PQU1C0PJuW2ShwuJ6bZub7hm1IXIv2kPqxF6sM6mloXkeVRIt2zIRWKteIFjVAs4MmWZM1QNezLat8bluuf83g8DBw4kI0b6+4AEd0pY9y4cfXe4z//+Q8//vGPMQyDv/zlLykNe1bk1B1kZbgI252MG5zFYTOHz0N9Isd2bcQMB7CZyXfLyHRkUJgXWbi5vp03fEE/Ydl1Qwgh2qWG9p8tkf1nOzTLBT6AadOmsXfv3hoLJCulWLx4MU6nk6lTpya99ssvv+S2227Dbrfz17/+le9+97utUeQ2pRRkOT04HDpZeTkM6FG9v25m0VZCvgr0sB9bPWMfoztvfF6ylYARSHhO2DTwhb2yt64QQlhcovXvjsj6d52a5bp0Aa655hpefvll5s2bx6ZNmxgwYACvvfYaH3zwAXPnzqWgINLluHv3btatW0e/fv0YO3YsAH/84x8JBAKcfvrpFBUVsWzZsjr3P+uss5LOAm6PlAK3zY3H7eBIyGTc4ExefK83B80culOGvudLlCcPe05m0m/qY7L6kO/Oo8RfyueHtzK2YGSC11FUhnxkObKQZfmEEMJaNK1q/TsVJhgOEjSC+I0gpmlG/pMWu07NkoHP7XbzzDPPsHDhQpYtW0ZlZSUDBgzgnnvu4cILL4ydt3btWubPn8/06dMZO3Ys4XCYNWvWALBy5UpWrlyZ8P5vvfVWhwp8AHbNhseVwVFvgAHH5uH5pIJ3fUO4xLMW1+5NhAaNw1bPWnrRnTfe3rOazw5uZEz3umsZAlVb4Phxae50vp1OpfrrXPOHsfxsFkIkEz/+LmCGKPGFOOwrwx8Myvg7kZAlAx9Afn4+d999d73nXHTRRVx00UWxz+12O5s2JV9AuCMzTRVr5Ss3YNRxGXz8+UCmef6H03uEQNEO7Bk52F0ewkbicXgjug3j3b0fRMZ0eA/Qy9OjzjmGaeIN+chwZ3S6yRuppOtaZKkDM0gwHMRE1VivSte0WBDU0NE00Ig8F302+nn1Z1WPtOrPEqn5O0BCphDtQfz+s8Gq/WcDVfvPajbwaE4qg/6kk/OEsGzgE03ntrnJcDgp14OMKMzjg899fOQfyCT3FhzfbMTsPQS7K4tk7XwZdjdD8waxuWQLnx3cmDDwAfhDAcKuMDrtc4u6tqBpkR/YYWUQNAL4Q5H/DNNI2M2uRS+KPkaL/j9E45xG/GdUX6LFvaYeC4Z6XBjUtOrnaodMreq5+kOmFndlzXMSkZApRONFf14oFGEzHPnD0AgRMAIYhhlrwYuydcL1UUXTSeDrSBRk2DPwuPyYudC/h4PVB4cyyb0F56Fv8FUcwubJRdNsSZv6x3QfyeaSLXxRspUz+p6Ky1533b2wYeAN+ch2ZMkv63pEu1yCZpBAOIA/HIjNfmtoLI2CWBKK/W+av9bpDJk6GjQ5ZMbFTE3DRBEyQijNBE1JyBQdRjTgmcqU8XcibSTwdSBKRVrp3E4nFb4Qo4bk8nJxiK3hXhTa96Pv+Awtvw92d07Srdb6ZPWiqzufw/4SNpdsYVzBqLqvg8Ib8pLl8NDZtsxpSHxXbSAcxBf2ETYMDMNEWXymS9uETC0uRFb9b5KQabPrVOCmojKAaZjUDpl6VcujjhYJko0JmVosaiYMmYlbMqW7XLRMjfXvTFn/TrQOCXwdjEN34NQdZLjs9O+XRYbrMO/4hlGYvR/n3i8IDDsFmzubUJLrNU1jTPcRvLV7FZ8d3MTY7iMTT94wwvjNAO5OPnmjqV21oiYVFyobCplKU5FfkEa4ReOUEoXM6n/iSVoy40Io1B8yIzMlq0NmnVZLLXlkrHMkwYm1z6l7SmP+CKvvHqru8QQ/A0wUwXAIEwNTM+te0+RSNO6qRGWpeYf443XfS9tJPP6uzv6zQqSJBL4OxjQVmY5MfA4/XluYEQOz+eTzPhwhmy7hcvQ9n0Nud3TdmXSrtRFdh/Lunvc56DvEvsoi+mTV3crOME28QS+ZGZ1v8kZLumpF22tKyEyVhC2ZNU9IcE3TX6XJZzQrC0Uustk1KnBTXunHDLfwC9io99/y4KbVeRB/TKv1fLIAm3g4Q+LXqz5mqHDC8XdCtBYJfB2Q2+bCZrPhdtsZVpjN2s/LeKdyCNM9n2DfuZ7wwAk4st0EkrSSuO1uhuYXsunwF3x2cFPCwAfgDwcJmSFsneCfUXvuqhVtL2HIrHlCu6M0HUMZse8DIYS1ydSeDkhDx+PIxO3Qyctx0LfAxZrgIMLYsVWUYO7fit1fgdOWPKhFd974snQb/nCSnTeMML6wr8EulvYoukp9KBzCZ3gp8ZdSVHmAg5WHKfUexR8MEjYMCXtCCCHaBQl8HZBSigy7G5tmI9Nt4/jB2fiUk3Xh4wCwf7OeUOVRHCEvjiShr7enJ90zuhI2w2w+/GXS16oIeVF0jL/uI/tMaoQJURGu4ID3EPvKiznkLaXMX1HVbdsx3qsQQojORQJfB+XQHLjsTtwOOwP7ZeBy6rxVGdlf1168E7OilFDFERwhP/YEoS86eQPgs4Mbk84YC4cN/IY/fW8kzXRdA00RVAHKQmUUeYs5UHmIksqjVAZ9GErG5QkhhGj/JPB1YJmODHQNcrOcDBngocjowm6tFxqKzA1vYPgqMCpLcRpBbHrdRZSH5w/Frts55C9hb2VRwtcwlUllyEt76dWNdtWamoHf9ElXrRBCiE5BAl8HpVRk5w2bbsfttHH8IA8A/zxyAobNhe3oATyfvIxRWYZZUYJLGdj0mv8cXHYXw/IKgUgrXzKBcJCQSrbQS9ur3VV70HeI4oqDHKoska5aIYQQnYIEvg7MptnIcLjRgGN7eejR1cleI4+3c8/GcLixlR8i85NlhMtLUeUlOFHotbboiXbrbj78JZsOfZHwdcKGgddikzfq7aoN+AgZYemqFUII0WlI4OvAImvyZaBrNjJcNo4flAXAB0V57B16NoYjE1tFCZmfLCNUdhAqSnBpNRc27Z3Vk/EFYwBYsfO/fFmyLeFreYM+FEba31My0lUrhBBCJNfxF1Dr5Jy6E4fdgRkyGVWYw3ufllJSofiiLB91/Hfp88V/sFcewbN2GZUnTMOp6biz8vGb1Vv7nHnMqYTMIBsOfc7yr/+DXbczqMuAGq8TNsL4DD+ZtsxW20IqsqOBImSGZAFkIYQQaWMqE3/Yjy/2nw9v2I8/7Mcb9uEzIs9Fj3f1dOHHY2ejWyhmWackIj0UZDkyCIQCdMl2MGSAh03bKljxP4Ov+2QzefB3OW77Gzh8ZXjWLsV7wgU4NQ2XJ4+AYUQ2JtI0zj72DMKmweclW1j61QouGXw+/XP6xV7GVIrKoBdPZnoDnyyALIQQoiUM08BvBPCGfdWBLVwzsNV+7DcSr0ebTFmwHF/Yj0fPStO7aDoJfB2cUuC2Z2DXywmbcObJ3QDFpm2VfLFXsfOghymDz2ZS6Rs4/WVkfvwSvokXYkfHldUFfzgMgK7pTO0/hZAZYtuRHSzZ/gqXDr6Qvtm9Y68VDIcImEEcOFNW/uq9asMEjSD+YKQlT/aqFUIIETbD+OJb2mq1wvkMP75QzRa4gBFs9uu5bS4y7G4y7Bm1PlY/9rgyGdl3MF20HEIh6/ye0lSyBdZEQoZhUlJSmbb72+06eXkeSksrCbdgg/h4uq5R4i+hzF+JieLwUT97ivy89+kRDh+JzK4dku/jB643yQgcwXRk4J94AfaCAYQzcgkY4di9wmaYJdtf5euyb3DqDi4fchG9PD1ix3MzsslzdWnR/ro1umqNtuuqtdl1crLdlJX7MVJUF6L5pD6sRerDOjpKXYTMcJJWtuQtb0Gz+StExEKazU2Gw02GrW54y7Rn4La7ybS7cdvddSY2JmKz6/TtXoA96Exb4MvP92CzNW0ahgS+JmqPgQ8goPwcqizBRFHuDVJWGcQ0FZ9v87FmQymGCbk2Pz/r+l/ywiWYdheVE87H3aeQkDuHQLg69IWMEM9ve5ndFXtx21xcMeRiCjK7AeCw2+npKUBTTfuHWKOr1rBGV21H+SHaUUh9WIvUh3VYrS6UUrXCW4LAZvjxhnz4DX+sazVkhhu+eQIaWp2gVvtjJLBlkFl1nsvmalR4aw4JfB1Eew18mg7FlQfwh4IYSlFa7icUNlEKvF7F6rWH+aYoQIYW5Kbc/9JXP4Rpc1Ix/nwy+h9P0OEhZBqxiRwBI8i/ty5lX2URmfYMrhxyMV0z8tE0ja6ZXfDYPfWO5avTVRu2XldtKn6IRgb6BvAbAfxhP37DX/W5P/Z82Ayjazbsug1d07FrNmy6DVvsOVuN52yaDZuux45XP1d1TdxjKy2V01JW+6XW2Ul9WEc660IpRdAMxgJbNJzFP67+WB3oDNW8VRt0TY8ENVvybtNoa1tm1fMum8tSP+sk8HUQ7TbwaVAeqqDUewQ0MJTC6w/jC4QJh010TeObXT7e/qQEFQxwffbbDHQcwNTtlI85j8zjhmPanCibA1PXMRR4g17+seVFir0HyXJ4uGroJXRx5eJ2uumR2Q1l1i6DNbpqGyv6Q/RomQ9voGZYi4wDibwHX9gfCXTR49HPw/4WdTekgq7psUCYKFDGh8jq8KjXOG7XbLFAWvua6PH4EGpr4Fxd05v1w1kChrVIfVhHY+tCKUXACNQKa8m6TKPj3vyYtX+YN7Zcml4V1up2ldbsLq1+zqk7LRXemkMCXwfRXgMfgEGYA5WHCFWNydN0DcNUeP0hvP4Qpgm6qfHummK2fVPJrOx3GOIowtBsHCmchNZnEBkZHnSbDc3hQtmcVKgwf/vyRQ76DpPrzOHKoReT5+5Cd08+Lj3yV5cVumojf6VWLd9S9UPMXxXY4lvb4lvhAkYgdk5Ly+rUHbjtbtw2V52Pdt2OqQwMZWKYBmFlYCgj0toZ9zEce2zWPF71OKyMZv9gbm22aBBNFB6TPGfXbWS4nBhh0NETBM6aYTXZvfQ610Sua24Q7awk8LUtpVRVd6ifoAqA3eBweRmVQW+9496a+7PMrtvrtLwlCmzxgc6hOzrl95QEvg6iPQc+Xdc45DtMRcBb43lN1wgbJpX+EIFAGKfdwb5vSvjv2sNcrL/LcOdeAEx0gtndMbr2hYK+qC690e0OKs0gT+76LyXBMrq6u3Dt8ZfRPbs7Lt0Z66oNmwZho+ULM4fMcI0WtFhoq6eVzV8V3Foahuy6vUZQi3YluO0uMmxu3HYX7iQf0zVWpDalVJ0QmCgkhk0Ds0aIrBU4a4XJaOA0EwZSs1YgNeq8VntZMidRSGxa62iirnW9zrmapqMRGXukaRqx/6v65Vjj+aqPQK3niLum6vP6rqnxWkCSe8VfVx8JfKljKrOBiQqJW96aK/oHaOLAlqAr1ebGYXOk8B13bBL4Ooj2HPgA/GbV5I0E4UfTNcJhkwp/CE1paH4f731STM/9axnt+Iautprv29TtGHm9MLr15UhOV54o20iZ4aPA1YXrjptKljsLEw2l2aJbYYCmE1YmPiOI1wjgCwdiC1j6Qv7q1req0OaLa21rybiQKF3TybC5cdldsdCWqNXNbXeT6cqgW04ORkDDgQO7LqsYNZepzFigTNxqWTckxodQQxmYmondoeH1BwiFw3HXRANnuDrcxt2zvnDbXoJoW0kaCDUNvXZATRpYq4+T4F71h9Oqu9V3r+YE5vj3FTte8/7x75ta96r9uonfV/Xnkda4QI3gFt+lGmjiGm/xnDYnmXY3WS4PTs1Z9cdn9eSEROPg5GdZekng6yDae+BDUxR5DxAMJR9bFgl+BsEw2EIBDuw7zP+2VVK8v4Jj2E+hfT+FjiKy9Jo/pAyHiy0unS0Zdo5mdyHb040yTHwqhN+M/OczgoRU82ZixcqHlqQ1LVFwq3meQ7c3uotBWjCsJR31YSozLlzW7kY3q0JiuMZzNQJpkm71RPeMf04phUJVfSTusYLoMag+r+o4tc5VithxEtwrdk/RLrhsrjoTEupb7y3D5o60HsvPKkuxauCTmN/JaOh4HJkEQ0eTnqNMhU3XyXRrGI4MevXrRUHeYbxeN1/tz2XV7kKeOajoqZdSaC9iiHM/gxzFOEMBjg/B8RXAwXJgNwBBDfy6jk/X8OsafpuOX9cI2WyEbHZMmwPT4UDZXWB3oTnc2JwZ2J2Z2JweXM5MMh2RH26Z9gycdhc2uz0y9VjXUVqk5RAt8lihoSJ/gkcex/9yVDV/eYrOTdd0nDYd6PjdVbVDYDRQxiKjok5IrB0445/XbBoej5PyCn9kTG4991KRi2o9VzPwUk8IrnF9wrImuU7FSpwwJCcO0fW9/yRfs0bcy21z199t2sg13oRoLgl8nYxSigy7mwpbZWzyRtJzTYWugS3DDu6euINBcvL8jBrkp/Soj43f2Fi/K5+V5cejY9LPfojRmUUMz9hLvlGCw4x0vzoVOA2TnGb2xioAuxNld6HsTpTDGflod4HDBXZn5KMjEhY1hxvlcKE53eDMAJcHzeGqEw7RNRQ6SqPqowZxP8R1vWY3kRDtWXV3bGruZ7Pr5HjcuE1pVRKiPZDA1wk5dSf5mV2oCFbiDwUaXPfOMCN/0WpOB84MF8rMpUeXMF17Bjh1tI9dRZV8tiPAlr0F7CwrYFnZKAB0TDL1EFm2IB57kGxbiEw9iEePfMzQQ2RoQdyEcGtBXET+c6gQThXEYQbRMSO/n8JBtHDzt8NRmo6qCoeRjy6Uw1n10V0VGN3gygBHBrgy0DIysefkkGE6MOwusNnjWhCrWg+rAmKd1glpQRRCCGEhEvg6IdNUuDQ37gw3PoePsmAFwVCwwbXwlFKEw5FmOs2u4XBm4MjyMDCvK8cdF8RX6eXzr8r5bIePvSUmJjoVposK0wXNWo5O4cDArUWCYYYWjDzW4x5XPZ+hh/DoQTKqnnNXBUmXFowMplYmWtAHQV+TShAi8k1iB5TNEQmLscDoAqe7RlBUTjc4M1FON8qZAc4MDGcGypkZaZWE6pAYDYhVLYpCCCFEulg28JWWlvLAAw/w9ttvc/jwYfr378/VV1/NJZdc0qjrX3rpJZ566il27txJVlYWZ511Fj/96U/Jzc1Nc8nbD2VChi0Dd4Ybr8NLWbCCUDjcqNYppUAZCjDQdSDTQY4nj5O6d+PUkzQIhAkFDYKhMP6gQTAcJhgyCAQN/GGDYNggGDQJhczI47AiFFaEDEUwrAgbilAYQoaNsOEkZGRSbkCJoQgbEApDuBFdxBoKJ5EWxeqAGGlRTPpYj38+hEurWrfQCKEZIfBXNO/rjUbY5sK0OTHtLkxHJCwqhwvNZkPTHWC3odnskf/skY/Y7Wg2B+g2lM0WaWnU7SibHXQbaDaUHnmsoufoOuh2TD3usaZX9Y/HxUsJm0II0SlYMvB5vV5mzpzJ1q1bufLKKznuuON4/fXXufPOOzl06BA33HBDvdc/+uijLFy4kJNPPpnbbruNPXv28Mwzz7Bu3Tqee+453G53K70T64tkOw2P3UOGI4PKoJeKaPBrxPUaYNPtuOyOyMBjRwYO3U4wFJmJaKrIiixExw4phUIDpTBRKGXGPobNyDpvoCIzI02TsBFGmZGZj5HWsKrB3aaJaUaDokG4KjCGwybhsCIYNgmFzUiIDBmEDBV5PmRWhUnFUUNxyFCEwxAyFCGDWNAMRz83wTTMui2KcS2JGVWtju4az8efG8SmRTqAHYYfDD80v3e62Uw0TGyYmo6p2SL/oaM0G6Zuq/poR2k2VFVIVHp1mIwEzqoQWhU80SOPI8/ZI8G1KqhGHtvQ7Y7qY7aqUKrbQLOjbJGyRO8vhBAiPSwZ+J599lk2b97MwoULOffccwG47LLLmD17Ng888AAXXHABvXr1SnhtUVER999/P5MmTeLRRx9F1yOznoYPH84tt9zCM888w+zZs1vtvbQXSoGmdLId2WQ6MqgIVlAZ9CWd2GHTbTjs9tjSAQ7dEQlkJoTNyFZtaBp1foVr1ethVd0peiB2OBoQo6copTAxqxYVNmNbsRkqHFnfDYVhRNZjM5WBqcCMtlwpE9OMvD+TSItf9P2iRSamVPWpolWFUFQknGmahsthxx8IEgyFCQWjIdKsCphmVciMPD5qKA6HzaoQWn1OMGSCEUYLB7AbQWxmALsRwm4GcJgh7CqEjoFNRSKZHQObZmLHxK4Z2OI/1niu5rk2zag6bmLDwKHVHJupo9AJU9WvbDmm0jA0HTPy1Yj8VxVKTc1GSLPh021VobU6pEYCqq2qNdOG0uxVrZzRsKpXtYpGAid6pNUU3RYLptQKqJHQGjmu2yP/2ew6uk2P/NsWQoh2xpKBb+nSpfTo0SMW9iASEGbNmsXq1atZvnw5c+bMSXjt8uXLCYVCXHvttbGwB3DeeeexcOFClixZIoGvHkopdGx0cXXB4/BQHirHG/QTNozIXqk2G5mOjNieh1X5CNNsWoKo22usaj1f+4TIsqY2dGyaHWLBMHJMc1afaSoDE4WpzOr/qPpoGoSr1lIzzaoxdFr1ki3xyzvYdA1PlhsqdBxVsxBVZDvgqtLFz+qNLviqUEqLvQMt+rHqGhVd8LpqokekS9WMpFEUWlUINUyFaajIosImmFUflakIGgpDKQxDYZoqdtw0iZxvROrDNBXKNFCGAUY48tGMPMY00cxI6ymGAcpAM6v/01XkXE0Z6MqMfdRV5Dkbkce6isazSMjUMbGpyOP4QBoNrfUGUk2hYwAGsUGf0X8G0Y8t36yl2UwFBjphbBiq6mPkHWOgx8Jp5KMt9tHUI4FVVbWqKt2GQo8tGxT9K0dV/RtXsb96tLi/gKqer3ouco5OrOU87nMVe65qq7ha/yk0NE2Pe464x3pkJq9etZhw9DX06nJoWuRzzWYjw+3EHwhH/ilrGpoeOV+LXV/1UY/Ojq/5XORh1WLFcd/T8Z9r8Z8TLYaW9Fj0c2p9Hn9ciM7IcoGvvLycHTt2cNZZZ9U5Nnr0aAA2bNiQ9Pr169fXODfeyJEjef311ykvLyc7OztFJe6YTFNhw06+K58sRwBv2IfL5orsj4sea81rS/HhsGaA1NEBHVs0J9YMh1rsqliXcnw4jC2MqysyHHYMu0kQg/gZuLF1w1QkBNYIqFpVHKzxeyX6iZ5gWYwGujJVdXlRVEfL2q8LoKraMGuvvqGqw2dVj3rV59XhFFW7zFSnVqLXRM9XgBl5q4qar2lGv05mJF+airBp4jUi4dQwzEggNRRG2MA0w6iwgRkOocJhCIdRZhhlmhAOgWmgjHAkiKIwwyEIh2MhFdNEN8NoVWFUMw00VfVcfDBVkSAba0OsCqY2IsdtWvTzSFCtG0gjM88dmI1b2sQCIbU9MKv+YFJV7e/Vj7Vax2odV5HtHqPPmTWer3u+Gf1cVd8PiJtxX/s/YoG8+vyqx1VLORF3/9h5WvR7RI/dn7jXA6rOjafV/KhVf29S1eOhapwX/dbUYsc1XYv7wzv68yFyTp1rYzuSVD+OHldV3+Wx8mmJyha9c/Tnn1bjeO1vkNgfISQ+N+7HTOQPh7hr6pRfi7tnVfFqf22p83n8z7/447V+UMb/pRD3XPRrkuhYDVXrKGq6xr5jvZw8cjBWYrnAV1xcjFIqYZdtRkYGubm57NmzJ+n1RUVF5OTkkJWVVedYz549Adi7dy9Dhw5NXaE7MNNU2HGS63BVjZ9rn4P8mxMO7XYbXXIyyVReQmGjRjiMhkJDRbqXTWUQNs1IN3O05TDW+hc39jBShJa9l+j/JrxP1Y++BMfiG0+rf9zF/ShNFGJq/WxrVONIbPX3BIvINuL62I9nreZzdptGZqabisoApqmqfoCrWHiN+5UR90sJtGiLa9xvMS3ucXxLbKR9USOoIn8MKNPADBsQDmOGApihqoAaCqOMcPUxI4yqCqoYkecwI+dQ1bIaCafhWEiNNY9HP1YNJYg+p1WNWY1FDwWoWGypcX7sV3X02vjjVddWP447JxpjlBmLM7EIo+KO141BteIRsWsiwyEarucoPfYPNsE/2o7QGJfo+7T9/QgVTRT8xsbBbr8jr3tBWxclxnKBr7y8HIDMzMyEx91uNz5f8qU1ysvL670WIpNCWsJuT99q6NGtUpq6ZUrr6Ag/fRtP16N/QWrY9EgsTESLS0uaRlUXctXEEiJ7yKqqvWTj95QNV+3lKmv2NY6uR+rBYbc1eQhB89hozg4cDX2XaAkeNekGSU9p+ML6GieaXBhdJ8Nlxx8IoQwVi2yRP2pqBtnIY7Pmcyr6R0v0sVnnOmXGhdv442YkoCqzaocPZUbOrRqwq6q+/2L3MI1I2Uwzcq5SVS3RJtFBv/ETwmLnqOjSSWaNckc/V/HlrvVY1XgvZnXIi36/1/i+VzU/j14bd7jm57WPRxaKr/56NXx+pHar/wjVEhxPdE3881qC5xJeX/UiWrLjVWWp8Vdp/OvUef2qY9E/4EhwvwTnazXKk+D1a72OluycuPNqtrlWnxN05zOgRz6mbp3f5ZYLfLHtaZL8ElRK1RibV989krHZmj8bUNc18vI8zb6+sXJyMtL+GqJx0lkXZlX4E02Q09YFEDXI6Bgh6tA0HbvFVh6wXODzeCJhyu/3Jzzu9/uTztCNXl9aWprwWLRlMFF3b2OZpqKsrGUthPWx2XRycjIoK/NhGLJdUVuSurAWqQ9rkfqwDqkLa2mN+sjJyWhyT6DlAl/fvn3RNI2ioqI6x7xeL2VlZbGxeMmu37x5M16vt07XblFREbqu06NHjxaVMdwK+0YahtkqryMaJnVhLVIf1iL1YR1SF9ZitfqwTudyFY/Hw8CBA9m4cWOdY9EZuOPGjUt6/ahRkX1cE83k3bhxI4MHD25RC58QQgghRHtjucAHMG3aNPbu3curr74ae04pxeLFi3E6nUydOjXpteeccw4Oh4O//vWvNcbyvfLKK+zbt4+LLroorWUXQgghhLAay3XpAlxzzTW8/PLLzJs3j02bNjFgwABee+01PvjgA+bOnUtBQWSa8+7du1m3bh39+vVj7NixAPTp04cbbriB+++/n+uuu45zzjmHr7/+mmeeeYaRI0dy+eWXt+VbE0IIIYRodZYMfG63m2eeeYaFCxeybNkyKisrGTBgAPfccw8XXnhh7Ly1a9cyf/58pk+fHgt8ADfddBNdu3bl2Wef5a677qJbt25cdtll/PjHP5Z9dIUQQgjR6WhKFgFrEsMwKSmpTNv97XadvDwPpaWVlhrs2RlJXViL1Ie1SH1Yh9SFtbRGfeTne5o8S9eSY/iEEEIIIUTqSOATQgghhOjgJPAJIYQQQnRwEviEEEIIITo4CXxCCCGEEB2cBD4hhBBCiA5OAp8QQgghRAcngU8IIYQQooOThZebSCmFaab3S2az6RiGLJ5pBVIX1iL1YS1SH9YhdWEt6a4PXdfQNK1J10jgE0IIIYTo4KRLVwghhBCig5PAJ4QQQgjRwUngE0IIIYTo4CTwCSGEEEJ0cBL4hBBCCCE6OAl8QgghhBAdnAQ+IYQQQogOTgKfEEIIIUQHJ4FPCCGEEKKDk8AnhBBCCNHBSeATQgghhOjgJPAJIYQQQnRwEviEEEIIITo4CXwWUVpayoIFC5g8eTKjRo1i2rRpvPDCC21drHZpy5Yt/PjHP+akk05ixIgRnHHGGfzf//0f5eXlNc7bt28fc+fO5ZRTTmHMmDFceumlvPXWWwnvuW3bNm688UZOPvlkxo4dyzXXXMOnn36a8Nx169Zx7bXXMmHCBE444QRuuOEGtm/fnvL32d4YhsGVV17JkCFD6hyTumg9pmny7LPPMm3aNEaNGsVpp53G7bffTnFxcY3zpE7S7+uvv+YnP/kJEydOZMSIEZxzzjn87W9/wzTNGudJXaTP+vXrGTZsGGvWrKlzzApf93feeYfLL7+ccePGMXHiRG699VaKioqa9V41pZRq1pUiZbxeL9/73vfYunUrV155Jccddxyvv/46H374IT/72c+44YYb2rqI7caOHTu4+OKLsdlsXHXVVfTq1YvPPvuMZcuWMWjQIJ577jkyMzM5ePAgl112GUeOHOH73/8+PXr04IUXXmDz5s386U9/4vzzz4/d86uvvuLyyy/H5XJx5ZVX4vF4+Mc//sHevXt54oknOPHEE2Pnfvzxx1x33XX06dOHGTNmYJomTz/9ND6fj3//+98MHDiwLb4slvDggw9y3333AZFQHiV10brmzp3LsmXLOPPMM5k0aRJff/01f//73+nZsydLliwhJydH6qQV7Nmzh4svvhifz8dVV13FMcccw5tvvskHH3zA5Zdfzm9+8xtAvj/SaefOnXzve9/j4MGDPP3000ycODF2zApf9+XLl3PbbbcxfPhwpk2bRllZGX/729/IyspiyZIldO3atWlvWIk29+ijj6rCwkL1yiuvxJ4zTVPNnDlTDR8+XO3bt68NS9e+XHfddWr48OFqy5YtNZ5/6qmnVGFhoXr88ceVUkr9v//3/9SQIUPUp59+GjvH7/eradOmqYkTJ6rKysrY8zNnzlSjRo1Su3btij1XUlKiTjnlFDV16lRlmqZSKlJn5557rvr2t7+tSktLY+d+8803atSoUWrWrFnpeMvtwvr169Xxxx+vRowYoQoLC2sck7poPW+++aYqLCxUv/71r2s8v2TJElVYWKgeffRRpZTUSWu46667VGFhoXr11VdrPH/11VerwsJCtX37dqWU1EW6vPHGG2rChAmqsLBQFRYWqo8++qjG8bb+uldWVqqJEyeqadOmKb/fH3v+008/VUOGDFG/+tWvmvyepUvXApYuXUqPHj0499xzY89pmsasWbMIhUIsX768DUvXfgSDQT755BPGjx9PYWFhjWMXXnghAGvXrsUwDF5++WXGjBnDuHHjYue4XC6uvvpqSktLWblyJQCHDh1i9erVTJkyhWOOOSZ2bl5eHjNmzGD79u1s2LABgI0bN7Jt2zYuvvhiunTpEju3X79+fPe73+W9997jwIED6XnzFlZZWcmtt97KqaeeypgxY2ock7poXf/85z/xeDzccsstNZ4/99xzmTNnDv3795c6aSU7d+4E4PTTT6/x/JQpUwD48ssvpS7SZM6cOdx00010796d8847r85xK3zdV65cSWlpKVdddRUulyt27rhx4zjhhBNYvnw5wWCwSe9bAl8bKy8vZ8eOHYwePbrOsehz0X8son52u51XXnmFBQsW1Dl26NAhAHRdZ9u2bXi93jrhA6q/5uvXr6/xsTHnfvbZZzWejzdq1ChM02Tjxo1Ne1MdQHT85N13313nmNRF6zEMg7Vr13LiiSeSlZUFgN/vJxgM4nQ6ueWWW/jOd74jddJKBgwYAFBn7NbXX38NQI8ePaQu0mTHjh38/Oc/56WXXqJ///51jlvh6x69Jtm5FRUV7Nixo553WZcEvjZWXFyMUopevXrVOZaRkUFubi579uxpg5K1P7quc8wxx9CvX786x5544gkAJk6cGBucnuhr3rNnT4DY1zw6ODbRuT169Eh4bu/evRu8b2fxxhtv8OKLL7JgwQK6detW57jURevZs2cPgUCAvn378p///Ifzzz+f0aNHM2bMGGbOnBn75SF10jrmzJnDgAEDuP322/nwww/Zs2cPzz77LM899xwnn3wy48ePl7pIkxUrVnD99dfjdDoTHrfC1z0ddSSBr41FZ45mZmYmPO52u/H5fK1ZpA5n6dKlPP/88/Tq1YsZM2bU+zV3u90Asa95RUUFAB6Pp865GRkZCc9NdN/a53YGxcXF/PKXv+SSSy6JdVPVJnXReo4ePQrA+++/z6233srkyZN58MEHufHGG/nkk0+44oor2L17t9RJKykoKOCnP/0pRUVFXHvttZx55pksWLCAkSNH8uCDD6JpmtRFmiQLelFW+Lqno47sTTpbpJyqmiStkkyWVkqh65LLm+ull17izjvvJDMzk/vuuw+Px5P0aw3V9RD9mtdXPy05t6NTSjFv3jyys7O544476j2voWNSF6kRHe+zY8cO7r//fr7zne8AkTFjxx9/PD/84Q9ZtGgRp512WtJ7SJ2kzmOPPcaf//xnjj32WG677Ta6devGJ598wt///neuueYannjiCfn+aCNW+Lo35lybzdbQW6lBAl8bi/5V4Pf7Ex73+/0Jm4pFw6LLgGRnZ/PII48watQooPprnuivo2g9ZGdnp/Tc6HPRczu6J598ko8++ogHH3yQQCBAIBAAIBQKAVBSUoLNZpO6aEXRloIePXrEwl7UGWecQa9evfjggw+YOnUqIHWSThUVFTz44IMUFBTw/PPPk5ubC8BZZ53F8ccfz9y5c3n44YeZMGECIHXR2qzwcyk+G0TH3NY+t/bzDem8Ed4i+vbti6ZpCRdS9Hq9lJWVxfrrReOEQiHmz5/PfffdR48ePXj22Wc54YQTYsf79u0LkPBrHn0u+jVvzLnRQB49t/YCtvHPdZbw/s4776CUii1EGv3vf//7HwAnn3wy06dPl7poRdGvY6KxlNHny8vLpU5awddff43f7+ess86Khb2o888/n8zMTD788EOpizZiha97U+7bWBL42pjH42HgwIEJZ0RFZ+nETwsX9TMMg1tuuYUlS5YwZMgQnn/+eYYOHVrjnOOOO47s7OyEs59rf81HjhyJruv1njt27FiAWAti9Pna52qalnDGVUc0b948nnzyyTr/RXfZePLJJ/njH/8oddGK8vPz6devHzt37oy1uEaZpsmePXv+f3t3H1VVlTdw/IsICqKAoKUgKsKlHNDUCRRtQgMd3xIBzSbf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",
      "text/plain": [
       "<Figure size 707.107x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = ss_range\n",
    "\n",
    "c=5\n",
    "plt.rcParams['figure.figsize'] = [c*np.sqrt(2), c*1]\n",
    "\n",
    "sns.set_theme()\n",
    "cp = sns.color_palette()\n",
    "custom_color_order = [cp[0], cp[2], cp[1]]\n",
    "sns.set_palette(custom_color_order)\n",
    "\n",
    "plt.plot(x, local_regrets_smooth, label=r'$R_c(\\hat{\\pi}_c$)')\n",
    "plt.fill_between(x, local_regrets_smooth - local_regrets_std_smooth, local_regrets_smooth + local_regrets_std_smooth, alpha=0.2)\n",
    "\n",
    "plt.plot(x, fed_local_regrets_smooth, label=r'$R_c(\\hat{\\pi}_\\lambda$)')\n",
    "plt.fill_between(x, np.clip(fed_local_regrets_smooth - fed_local_regrets_std_smooth, 0, None), fed_local_regrets_smooth + fed_local_regrets_std_smooth, alpha=0.2)\n",
    "\n",
    "plt.plot(x, global_regrets_smooth, label=r'$R_\\lambda(\\hat{\\pi}_\\lambda)$')\n",
    "plt.fill_between(x, global_regrets_smooth - global_regrets_std_smooth, global_regrets_smooth + global_regrets_std_smooth, alpha=0.2)\n",
    "\n",
    "plt.xlabel('Total Sample Size', fontsize=16)\n",
    "plt.ylabel('Regret', fontsize=16)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "# plt.title(r'Heterogeneous Clients, Empirical Mixture $\\lambda=\\bar{n}$', loc=\"left\")\n",
    "plt.legend(fontsize=22)\n",
    "# plt.show()\n",
    "\n",
    "# plt.savefig('./data/heterogeneous-client2-exp1.png', dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "62243b0f-f5b0-433b-aa75-3c9e89fa7934",
   "metadata": {},
   "source": [
    "### Federated model on skewed client distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "a67ef362-92cd-4339-aac3-7e47cda6c867",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Aggregate: opt_reward=4.413742078833837, reward=3.138175648927359, regret=1.2755664299064196\n"
     ]
    }
   ],
   "source": [
    "# Aggregate all data\n",
    "X_train = []\n",
    "A_train = []\n",
    "Y_train = []\n",
    "true_costs_train = []\n",
    "true_costs_test = []\n",
    "X_test = []\n",
    "\n",
    "idx_to_weight_mapping = {}\n",
    "for client_id in range(NUM_CLIENTS):\n",
    "    lo = len(X_train)\n",
    "    X_train.extend(aux[client_id][\"X_train\"])\n",
    "    hi = len(X_train)\n",
    "    A_train.extend(aux[client_id][\"A_train\"])\n",
    "    Y_train.extend(aux[client_id][\"Y_train\"])\n",
    "    true_costs_train.extend(aux[client_id][\"true_costs_train\"])\n",
    "    true_costs_test.extend(aux[client_id][\"true_costs_test\"])\n",
    "    X_test.extend(aux[client_id][\"X_test\"])\n",
    "    \n",
    "    if client_id == 0:\n",
    "        weight = TRAIN_SIZES[client_id] + sum([TRAIN_SIZES[other_id]/2 for other_id in range(1, NUM_CLIENTS)])\n",
    "    else:\n",
    "        weight = TRAIN_SIZES[client_id] - TRAIN_SIZES[client_id]/2\n",
    "    idx_to_weight_mapping.update({i:weight/TRAIN_SIZES[client_id] for i in range(lo, len(X_train))})\n",
    "    \n",
    "X_train = np.array(X_train)\n",
    "A_train = np.array(A_train)\n",
    "Y_train = np.array(Y_train)\n",
    "true_costs_train = np.array(true_costs_train)\n",
    "true_costs_test = np.array(true_costs_test)\n",
    "X_test = np.array(X_test)\n",
    "\n",
    "# Compute AIPW scores\n",
    "crossfit_map, mu, e = utils.cross_fit_nuisance_params(X_train, A_train, Y_train, NUM_ACTIONS)\n",
    "noisy_costs_train = -utils.compute_AIPW_scores(X_train, A_train, Y_train, NUM_ACTIONS, crossfit_map, mu, e)\n",
    "data_train = utils.to_vw_format(X_train, A_train, noisy_costs_train, idx_to_weight_mapping)\n",
    "\n",
    "# Train model\n",
    "opt_global_model_w = VW(csoaa=NUM_ACTIONS,\n",
    "                      convert_to_vw=False,\n",
    "                      convert_labels=False,\n",
    "                      passes=1)\n",
    "opt_global_model_w.fit(data_train)\n",
    "\n",
    "# Evaluate on test data\n",
    "X_test_vw = utils.to_vw_format(X_test)\n",
    "regret, opt_reward, reward = utils.compute_regret(X_test_vw, true_costs_test, opt_global_model_w, opt_model=None, idx_to_weight_mapping=idx_to_weight_mapping)\n",
    "print(f\"Aggregate: opt_reward={opt_reward}, reward={reward}, regret={regret}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "55dcc746-bc32-4eea-ba23-ede21291aa16",
   "metadata": {},
   "outputs": [],
   "source": [
    "NUM_ROUNDS = 1\n",
    "\n",
    "def run_federated_training_experiments_v2(data, aux, sample_size_fns, num_iters=3):\n",
    "\n",
    "    local_regrets_mean = {k:[] for k in range(NUM_CLIENTS)}\n",
    "    local_regrets_std = {k:[] for k in range(NUM_CLIENTS)}\n",
    "    global_regrets_mean = []\n",
    "    global_regrets_std = []\n",
    "\n",
    "    for sample_size in tqdm(ss_range):\n",
    "        local_regrets_iters = {k:[] for k in range(NUM_CLIENTS)}\n",
    "        global_regret_iters = []\n",
    "        for i in tqdm(range(num_iters)):\n",
    "\n",
    "            # Subsample data\n",
    "            data_mod = {}\n",
    "            aux_mod = {}\n",
    "            client_weights = []\n",
    "            for client_id in range(NUM_CLIENTS):\n",
    "                client_sample_size = sample_size_fns[client_id](sample_size)\n",
    "                if client_id == 0:\n",
    "                    weight = client_sample_size + sum([sample_size_fns[other_id](sample_size)/2 for other_id in range(1, NUM_CLIENTS)])\n",
    "                else:\n",
    "                    weight = client_sample_size - client_sample_size/2\n",
    "                client_weights.append(weight)\n",
    "\n",
    "                data_mod[client_id] = random.sample(data[client_id], client_sample_size)\n",
    "                aux_mod[client_id] = {\"X_test\": aux[client_id][\"X_test\"],\n",
    "                                      \"true_costs_test\": aux[client_id][\"true_costs_test\"]}\n",
    "\n",
    "            client_weights = np.array(client_weights) / np.sum(client_weights)\n",
    "            \n",
    "            # Run federated learning\n",
    "            global_vw = server.run_federated_learning(data_mod, aux_mod,\n",
    "                                                      opt_global_model_w, opt_local_models,\n",
    "                                                      num_features=NUM_FEATURES,\n",
    "                                                      num_classes=NUM_ACTIONS,\n",
    "                                                      num_rounds=NUM_ROUNDS,\n",
    "                                                      num_clients=NUM_CLIENTS,\n",
    "                                                      client_weights=client_weights)\n",
    "\n",
    "            gr = global_vw.metrics_distributed[\"global_regret\"][-1][1]\n",
    "            global_regret_iters.append(gr)\n",
    "            \n",
    "            for client_id in range(NUM_CLIENTS):\n",
    "                lr = global_vw.metrics_distributed[\"local_regrets\"][-1][1][client_id]\n",
    "                local_regrets_iters[client_id].append(lr)\n",
    "\n",
    "        global_regrets_mean.append(np.mean(global_regret_iters))\n",
    "        global_regrets_std.append(np.std(global_regret_iters))\n",
    "        \n",
    "        for client_id in range(NUM_CLIENTS):\n",
    "            local_regrets_mean[client_id].append(np.mean(local_regrets_iters[client_id]))\n",
    "            local_regrets_std[client_id].append(np.std(local_regrets_iters[client_id]))\n",
    "            \n",
    "    global_regrets_mean = np.array(global_regrets_mean)\n",
    "    global_regrets_std = np.array(global_regrets_std)\n",
    "    for client_id in range(NUM_CLIENTS):\n",
    "        local_regrets_mean[client_id] = np.array(local_regrets_mean[client_id])\n",
    "        local_regrets_std[client_id] = np.array(local_regrets_std[client_id])\n",
    "        \n",
    "    return (global_regrets_mean, global_regrets_std,\n",
    "            local_regrets_mean, local_regrets_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "1a3940a0-b992-4f3a-8156-1d12f12f9569",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d5348c35f5b74ca58f5e09e8501358b9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/13 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5c5a34c2925542b486a75dc1a17b1711",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:13:18,402 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:13:25,222\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:13:28,256 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6237159424.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:13:28,257 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:13:28,258 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:13:29,728 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:13:29,729 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:13:29,731 | server.py:101 | FL starting\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28801)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:13:29,732 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28801)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28801)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:13:31,535 | server.py:229 | fit_round 1 received 4 results and 0 failures\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28796)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28796)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28797)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28797)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28800)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28800)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING flwr 2023-05-15 13:13:31,564 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:13:31,567 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28801)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28796)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28797)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28800)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:13:33,616 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:13:33,617 | server.py:144 | FL finished in 3.8849831450006604\n",
      "INFO flwr 2023-05-15 13:13:33,619 | app.py:202 | app_fit: losses_distributed [(1, 1.2983453218129508)]\n",
      "INFO flwr 2023-05-15 13:13:33,621 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.469087648140888)], 'reward': [(1, 0.33809674854927263)], 'global_regret': [(1, 1.1309908995916154)], 'local_regrets': [(1, {0: 1.423009053871209, 1: 1.3850132774003856, 2: 1.4264925661286252, 3: 1.416050975497294})]}\n",
      "INFO flwr 2023-05-15 13:13:33,622 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:13:33,623 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:13:33,632 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:13:40,054\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:13:42,153 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6246334874.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:13:42,155 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:13:42,156 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28824)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:13:43,939 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:13:43,940 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:13:43,942 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:13:43,943 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28824)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28824)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:13:45,817 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:13:45,846 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:13:45,849 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28823)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28823)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28821)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28821)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28822)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28822)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28824)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28823)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28821)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28822)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:13:48,186 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:13:48,188 | server.py:144 | FL finished in 4.2447813260005205\n",
      "INFO flwr 2023-05-15 13:13:48,192 | app.py:202 | app_fit: losses_distributed [(1, 2.241112156214738)]\n",
      "INFO flwr 2023-05-15 13:13:48,194 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1872083331376178)], 'reward': [(1, -1.1726843763265717)], 'global_regret': [(1, 2.359892709464193)], 'local_regrets': [(1, {0: 2.477830147592089, 1: 2.4611607289796598, 2: 1.9970907021908388, 3: 2.485551631742077})]}\n",
      "INFO flwr 2023-05-15 13:13:48,195 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:13:48,197 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:13:48,230 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:13:56,487\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:13:59,480 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'memory': 6150352077.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:13:59,481 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:13:59,482 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:00,951 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:00,952 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:14:00,953 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:14:00,954 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28846)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28846)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28846)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:02,662 | server.py:229 | fit_round 1 received 4 results and 0 failures\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28848)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28848)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28842)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28842)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28841)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28841)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING flwr 2023-05-15 13:14:02,687 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:14:02,689 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28846)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28848)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28842)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28841)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:04,586 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:14:04,587 | server.py:144 | FL finished in 3.633709275000001\n",
      "INFO flwr 2023-05-15 13:14:04,590 | app.py:202 | app_fit: losses_distributed [(1, 1.916665263634636)]\n",
      "INFO flwr 2023-05-15 13:14:04,591 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1872083331376178)], 'reward': [(1, -0.7806332111627106)], 'global_regret': [(1, 1.9678415443003279)], 'local_regrets': [(1, {0: 2.0181747098444585, 1: 1.948623340429847, 2: 2.0582096395241907, 3: 2.0988379503857697})]}\n",
      "INFO flwr 2023-05-15 13:14:04,593 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:14:04,595 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:14:04,604 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:14:13,617\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:14:15,284 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'memory': 6148158669.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:14:15,285 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:14:15,286 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:16,698 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:16,699 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:14:16,700 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:14:16,701 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28867)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28867)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28867)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28865)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28865)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28868)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28868)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28869)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28869)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:18,488 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:14:18,517 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:14:18,520 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28867)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28865)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28868)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28869)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:20,817 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:14:20,818 | server.py:144 | FL finished in 4.117107501999271\n",
      "INFO flwr 2023-05-15 13:14:20,821 | app.py:202 | app_fit: losses_distributed [(1, 2.121705658951881)]\n",
      "INFO flwr 2023-05-15 13:14:20,823 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1835309787525072)], 'reward': [(1, -1.0634847440153958)], 'global_regret': [(1, 2.247015722767912)], 'local_regrets': [(1, {0: 2.371924564338712, 1: 1.8993630821654617, 2: 2.323364448835948, 3: 2.349355126113123})]}\n",
      "INFO flwr 2023-05-15 13:14:20,824 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:14:20,826 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:14:20,834 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:14:28,481\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:14:31,600 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6143639143.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:14:31,601 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:14:31,602 | server.py:270 | Requesting initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:33,217 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:33,218 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:14:33,220 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:14:33,220 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28891)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28891)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28891)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:35,113 | server.py:229 | fit_round 1 received 4 results and 0 failures\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28887)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28887)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28888)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28888)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28890)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28890)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING flwr 2023-05-15 13:14:35,141 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:14:35,144 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28887)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28891)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28890)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28888)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:37,444 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:14:37,445 | server.py:144 | FL finished in 4.2248557829989295\n",
      "INFO flwr 2023-05-15 13:14:37,448 | app.py:202 | app_fit: losses_distributed [(1, 1.1777292773995403)]\n",
      "INFO flwr 2023-05-15 13:14:37,450 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1872083331376175)], 'reward': [(1, -0.015064522925198623)], 'global_regret': [(1, 1.2022728560628193)], 'local_regrets': [(1, {0: 1.2259733196045386, 1: 1.4502451398973313, 2: 1.2517595765502811, 3: 1.2401236591917226})]}\n",
      "INFO flwr 2023-05-15 13:14:37,452 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:14:37,454 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef524c3f32924b37b42622e3029ff2fd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:14:37,601 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:14:44,090\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:14:47,478 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6148121805.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:14:47,480 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:14:47,481 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28914)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:14:49,423 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:14:49,425 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:14:49,426 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:14:49,428 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28914)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28914)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28917)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28917)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28916)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28916)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28915)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28915)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:51,936 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:14:51,970 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:14:51,973 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28914)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28917)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28916)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28915)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:14:54,720 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:14:54,721 | server.py:144 | FL finished in 5.293252601000859\n",
      "INFO flwr 2023-05-15 13:14:54,724 | app.py:202 | app_fit: losses_distributed [(1, 0.7790035683330976)]\n",
      "INFO flwr 2023-05-15 13:14:54,726 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1985519875431734)], 'reward': [(1, 0.41162366475423995)], 'global_regret': [(1, 0.7869283227889344)], 'local_regrets': [(1, {0: 0.7971798639055477, 1: 0.7785896776698713, 2: 1.2025367272647252, 3: 0.7948925901379591})]}\n",
      "INFO flwr 2023-05-15 13:14:54,728 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:14:54,731 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:14:54,743 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:15:03,378\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:15:06,700 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6145165312.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:15:06,703 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:15:06,705 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28937)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:15:08,789 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:15:08,791 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:15:08,792 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:15:08,794 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28937)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28937)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28934)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28934)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28939)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28939)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28941)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28941)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:15:11,306 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:15:11,340 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:15:11,343 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28937)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28934)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28939)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28941)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:15:14,260 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:15:14,261 | server.py:144 | FL finished in 5.467246124999292\n",
      "INFO flwr 2023-05-15 13:15:14,265 | app.py:202 | app_fit: losses_distributed [(1, 0.8706432655715096)]\n",
      "INFO flwr 2023-05-15 13:15:14,267 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4334514167125652)], 'reward': [(1, 0.6045246930082145)], 'global_regret': [(1, 0.8289267237043532)], 'local_regrets': [(1, {0: 1.2298961415912617, 1: 0.8971944186041177, 2: 0.9039510408588539, 3: 0.9087160468775157})]}\n",
      "INFO flwr 2023-05-15 13:15:14,269 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:15:14,271 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:15:14,282 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:15:21,897\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:15:25,393 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6142584832.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:15:25,396 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:15:25,398 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28959)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:15:27,621 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:15:27,623 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:15:27,625 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:15:27,627 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28959)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28959)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28960)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28960)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28963)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28963)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28964)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28964)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:15:30,224 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:15:30,261 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:15:30,265 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28959)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28960)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28963)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28964)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:15:33,437 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:15:33,439 | server.py:144 | FL finished in 5.812767937000899\n",
      "INFO flwr 2023-05-15 13:15:33,443 | app.py:202 | app_fit: losses_distributed [(1, 0.8286534067998802)]\n",
      "INFO flwr 2023-05-15 13:15:33,445 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1935901084724843)], 'reward': [(1, 0.32587473439815823)], 'global_regret': [(1, 0.8677153740743269)], 'local_regrets': [(1, {0: 0.9214584747701249, 1: 1.0798332806380164, 2: 0.8726071511113974, 3: 0.8978993063256947})]}\n",
      "INFO flwr 2023-05-15 13:15:33,446 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:15:33,449 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:15:33,460 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:15:42,532\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:15:46,008 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6133343028.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:15:46,011 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:15:46,012 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=28987)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:15:48,178 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:15:48,180 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:15:48,182 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:15:48,184 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=28987)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28987)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28985)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28985)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28982)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28982)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28983)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=28983)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:15:50,737 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:15:50,771 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:15:50,774 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28987)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28985)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28983)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=28982)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:15:54,120 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:15:54,122 | server.py:144 | FL finished in 5.9387891970000055\n",
      "INFO flwr 2023-05-15 13:15:54,126 | app.py:202 | app_fit: losses_distributed [(1, 0.8588691907633278)]\n",
      "INFO flwr 2023-05-15 13:15:54,128 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1935901084724843)], 'reward': [(1, 0.29941284034828003)], 'global_regret': [(1, 0.8941772681242052)], 'local_regrets': [(1, {0: 0.9426649229410062, 1: 1.1120184659853343, 2: 0.9256437276805362, 3: 0.9123342320921484})]}\n",
      "INFO flwr 2023-05-15 13:15:54,130 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:15:54,132 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:15:54,147 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:16:02,611\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:16:06,291 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6130858394.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:16:06,294 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:16:06,296 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29005)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:16:08,621 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:16:08,622 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:16:08,624 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:16:08,626 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29005)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29005)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29007)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29007)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29008)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29008)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29009)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29009)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:16:11,422 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:16:11,460 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:16:11,464 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29005)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29007)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29008)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29009)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:16:15,462 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:16:15,463 | server.py:144 | FL finished in 6.837874924998687\n",
      "INFO flwr 2023-05-15 13:16:15,468 | app.py:202 | app_fit: losses_distributed [(1, 0.8355374995966361)]\n",
      "INFO flwr 2023-05-15 13:16:15,470 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.1985519875431734)], 'reward': [(1, 0.3545978086617756)], 'global_regret': [(1, 0.8439541788813992)], 'local_regrets': [(1, {0: 0.8548944147585098, 1: 0.8052210236410026, 2: 0.8007416565319032, 3: 1.338477489100843})]}\n",
      "INFO flwr 2023-05-15 13:16:15,472 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:16:15,474 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "626faff18a8645f9b04d65636c35c892",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:16:15,664 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:16:25,101\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:16:28,739 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6124123341.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:16:28,743 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:16:28,746 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29032)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:16:31,066 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:16:31,068 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:16:31,069 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:16:31,071 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29032)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29032)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29029)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29029)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29034)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29034)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29033)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29033)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:16:33,904 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:16:33,948 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:16:33,952 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29032)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29029)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29034)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29033)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:16:37,991 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:16:37,993 | server.py:144 | FL finished in 6.921738279999772\n",
      "INFO flwr 2023-05-15 13:16:37,996 | app.py:202 | app_fit: losses_distributed [(1, 0.35693254113272727)]\n",
      "INFO flwr 2023-05-15 13:16:37,998 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.201465798957118)], 'reward': [(1, 0.8486976475762603)], 'global_regret': [(1, 0.352768151380857)], 'local_regrets': [(1, {0: 0.34542627954917565, 1: 0.3513750467071437, 2: 0.367543571666626, 3: 0.8205698522536772})]}\n",
      "INFO flwr 2023-05-15 13:16:38,001 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:16:38,006 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:16:38,029 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:16:48,104\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:16:51,937 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6122346496.0}\n",
      "INFO flwr 2023-05-15 13:16:51,940 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:16:51,942 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29055)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:16:55,407 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:16:55,410 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:16:55,413 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:16:55,416 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29055)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29055)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29056)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29056)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29054)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29054)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29053)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29053)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:16:59,560 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:16:59,616 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:16:59,620 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29055)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29056)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29054)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29053)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:17:04,782 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:17:04,784 | server.py:144 | FL finished in 9.368515778000074\n",
      "INFO flwr 2023-05-15 13:17:04,788 | app.py:202 | app_fit: losses_distributed [(1, 0.3672091279633972)]\n",
      "INFO flwr 2023-05-15 13:17:04,791 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.415633300998404)], 'reward': [(1, 1.1001345543910457)], 'global_regret': [(1, 0.3154987466073578)], 'local_regrets': [(1, {0: 0.6886873541815568, 1: 0.40795528162103795, 2: 0.41144012537905844, 3: 0.4179383363176498})]}\n",
      "INFO flwr 2023-05-15 13:17:04,796 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:17:04,800 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:17:04,881 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:17:14,366\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:17:18,670 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6118453658.0}\n",
      "INFO flwr 2023-05-15 13:17:18,673 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:17:18,675 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29081)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:17:21,403 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:17:21,405 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:17:21,407 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:17:21,409 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29081)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29081)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29075)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29075)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29080)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29080)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29074)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29074)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:17:24,899 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:17:24,944 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:17:24,948 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29081)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29075)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29074)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29080)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:17:29,498 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:17:29,500 | server.py:144 | FL finished in 8.091367326000181\n",
      "INFO flwr 2023-05-15 13:17:29,504 | app.py:202 | app_fit: losses_distributed [(1, 0.5009187865698089)]\n",
      "INFO flwr 2023-05-15 13:17:29,508 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.204223814745951)], 'reward': [(1, 0.6908898577874409)], 'global_regret': [(1, 0.513333956958512)], 'local_regrets': [(1, {0: 0.5331827924847921, 1: 0.5388370899848074, 2: 0.8306809217795339, 3: 0.5581589276758167})]}\n",
      "INFO flwr 2023-05-15 13:17:29,511 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:17:29,514 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:17:29,534 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:17:39,531\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:17:43,882 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6077180724.0}\n",
      "INFO flwr 2023-05-15 13:17:43,886 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:17:43,888 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29110)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:17:46,893 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:17:46,895 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:17:46,898 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:17:46,900 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29110)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29110)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29107)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29107)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29109)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29109)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29105)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29105)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:17:50,282 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:17:50,323 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:17:50,327 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29110)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29107)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29109)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29105)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:17:54,130 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:17:54,132 | server.py:144 | FL finished in 7.232129365000219\n",
      "INFO flwr 2023-05-15 13:17:54,136 | app.py:202 | app_fit: losses_distributed [(1, 0.8876626988361639)]\n",
      "INFO flwr 2023-05-15 13:17:54,138 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.201465798957118)], 'reward': [(1, 0.31826302569570747)], 'global_regret': [(1, 0.8832027732614096)], 'local_regrets': [(1, {0: 0.8753683417249216, 1: 1.3751156041119066, 2: 0.8664699061970706, 3: 0.890881528956472})]}\n",
      "INFO flwr 2023-05-15 13:17:54,141 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:17:54,144 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:17:54,161 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:18:03,602\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:18:07,347 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6067021005.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:18:07,349 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:18:07,351 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29140)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:18:10,231 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:18:10,232 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:18:10,234 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:18:10,236 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29140)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29140)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29135)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29135)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29134)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29134)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29137)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29137)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:18:13,579 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:18:13,627 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:18:13,631 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29140)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29135)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29134)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29137)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:18:17,907 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:18:17,910 | server.py:144 | FL finished in 7.673431977998916\n",
      "INFO flwr 2023-05-15 13:18:17,913 | app.py:202 | app_fit: losses_distributed [(1, 0.37841049438714114)]\n",
      "INFO flwr 2023-05-15 13:18:17,916 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.201465798957118)], 'reward': [(1, 0.816756943200795)], 'global_regret': [(1, 0.38470885575632174)], 'local_regrets': [(1, {0: 0.3948049024597252, 1: 0.41707938687334617, 2: 0.4022022591573324, 3: 0.7567400147038736})]}\n",
      "INFO flwr 2023-05-15 13:18:17,919 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:18:17,923 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1a60d6c80b8e4ded9b9b7b7cddb7af71",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:18:18,170 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:18:29,413\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:18:33,872 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6074036224.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:18:33,876 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:18:33,879 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29158)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:18:37,550 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:18:37,552 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:18:37,554 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:18:37,557 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29158)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29158)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29162)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29162)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29165)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29165)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29163)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29163)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:18:42,397 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:18:42,465 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:18:42,470 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29158)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29163)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29162)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29165)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:18:47,595 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:18:47,598 | server.py:144 | FL finished in 10.040674391999346\n",
      "INFO flwr 2023-05-15 13:18:47,602 | app.py:202 | app_fit: losses_distributed [(1, 0.5736998918000524)]\n",
      "INFO flwr 2023-05-15 13:18:47,605 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2005185638013534)], 'reward': [(1, 0.6139916051654165)], 'global_regret': [(1, 0.5865269586359362)], 'local_regrets': [(1, {0: 0.607436826423459, 1: 0.9431250081041928, 2: 0.5919254173131537, 3: 0.6094969010051162})]}\n",
      "INFO flwr 2023-05-15 13:18:47,608 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:18:47,612 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:18:47,634 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:18:58,037\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:19:01,976 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6079584256.0}\n",
      "INFO flwr 2023-05-15 13:19:01,978 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:19:01,981 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29184)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:19:04,745 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:19:04,746 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:19:04,748 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:19:04,750 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29184)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29184)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29191)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29191)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29188)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29188)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29190)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29190)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:19:08,325 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:19:08,374 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:19:08,377 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29184)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29191)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29188)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29190)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:19:14,242 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:19:14,246 | server.py:144 | FL finished in 9.49568119200012\n",
      "INFO flwr 2023-05-15 13:19:14,251 | app.py:202 | app_fit: losses_distributed [(1, 0.3899150842207239)]\n",
      "INFO flwr 2023-05-15 13:19:14,256 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2005185638013531)], 'reward': [(1, 0.8176422571055718)], 'global_regret': [(1, 0.38287630669578243)], 'local_regrets': [(1, {0: 0.3699406618685654, 1: 0.3641362613812873, 2: 0.38394995266626764, 3: 0.8988180466124868})]}\n",
      "INFO flwr 2023-05-15 13:19:14,267 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:19:14,270 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:19:14,373 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:19:24,432\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:19:28,863 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6067444941.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:19:28,867 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:19:28,869 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29214)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:19:32,098 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:19:32,101 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:19:32,104 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:19:32,106 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29214)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29214)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29209)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29209)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29208)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29208)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29213)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29213)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:19:36,626 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:19:36,691 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:19:36,696 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29214)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29209)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29208)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29213)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:19:42,365 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:19:42,367 | server.py:144 | FL finished in 10.261767448999308\n",
      "INFO flwr 2023-05-15 13:19:42,372 | app.py:202 | app_fit: losses_distributed [(1, 0.8722485024673059)]\n",
      "INFO flwr 2023-05-15 13:19:42,376 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2022028463627872)], 'reward': [(1, 0.34949628801861693)], 'global_regret': [(1, 0.8527065583441693)], 'local_regrets': [(1, {0: 0.8190116535187798, 1: 0.828690860954358, 2: 0.8159991368634197, 3: 1.4824769441783805})]}\n",
      "INFO flwr 2023-05-15 13:19:42,380 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:19:42,384 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:19:42,418 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:19:55,046\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:20:01,113 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6060127437.0}\n",
      "INFO flwr 2023-05-15 13:20:01,129 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:20:01,132 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29244)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:20:08,122 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:20:08,136 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:20:08,139 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:20:08,143 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29244)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29244)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29241)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29241)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29245)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29245)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29243)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29243)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:20:17,994 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:20:18,144 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:20:18,161 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29244)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29241)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29245)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29243)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:20:45,358 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:20:45,361 | server.py:144 | FL finished in 37.219328443999984\n",
      "INFO flwr 2023-05-15 13:20:45,377 | app.py:202 | app_fit: losses_distributed [(1, 0.3244245072259092)]\n",
      "INFO flwr 2023-05-15 13:20:45,392 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4134365470062469)], 'reward': [(1, 1.1241428590024338)], 'global_regret': [(1, 0.28929368800381344)], 'local_regrets': [(1, {0: 0.6888137576819156, 1: 0.37074493154889326, 2: 0.34638510783503196, 3: 0.3489388174835108})]}\n",
      "INFO flwr 2023-05-15 13:20:45,408 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:20:45,426 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:20:45,695 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:21:12,112\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:21:21,252 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6057255732.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:21:21,271 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:21:21,275 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29282)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:21:28,144 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:21:28,146 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:21:28,158 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:21:28,161 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29282)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29282)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29281)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29281)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29277)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29277)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29278)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29278)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:21:34,909 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:21:35,003 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:21:35,010 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29281)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29282)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29277)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29278)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:21:42,589 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:21:42,599 | server.py:144 | FL finished in 14.43831511099961\n",
      "INFO flwr 2023-05-15 13:21:42,603 | app.py:202 | app_fit: losses_distributed [(1, 0.5781249894146571)]\n",
      "INFO flwr 2023-05-15 13:21:42,607 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4134365470062469)], 'reward': [(1, 0.8069597136598008)], 'global_regret': [(1, 0.6064768333464478)], 'local_regrets': [(1, {0: 1.114152551360799, 1: 0.5457885043351263, 2: 0.5573813477504286, 3: 0.5523621398579883})]}\n",
      "INFO flwr 2023-05-15 13:21:42,613 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:21:42,616 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9c11c7633ca14af2b9267ced398e1a3c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:21:43,081 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:21:54,607\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:21:59,117 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6065059840.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:21:59,120 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:21:59,123 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29306)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:22:02,554 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:22:02,557 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:22:02,559 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:22:02,563 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29306)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29306)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29303)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29303)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29304)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29304)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29305)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29305)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:22:06,808 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:22:06,861 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:22:06,866 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29306)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29303)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29304)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29305)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:22:11,679 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:22:11,682 | server.py:144 | FL finished in 9.118608654998752\n",
      "INFO flwr 2023-05-15 13:22:11,686 | app.py:202 | app_fit: losses_distributed [(1, 0.4990634328367538)]\n",
      "INFO flwr 2023-05-15 13:22:11,690 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4092187793413056)], 'reward': [(1, 0.9314230866631511)], 'global_regret': [(1, 0.47779569267815636)], 'local_regrets': [(1, {0: 0.8993589533415794, 1: 0.5134306199975036, 2: 0.5287697793853079, 3: 0.5118789642683373})]}\n",
      "INFO flwr 2023-05-15 13:22:11,693 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:22:11,697 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:22:11,719 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:22:21,681\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:22:26,066 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6077014836.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:22:26,069 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:22:26,072 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29330)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:22:29,087 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:22:29,089 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:22:29,092 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:22:29,094 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29330)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29330)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29329)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29329)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29328)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29328)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29326)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29326)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:22:33,059 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:22:33,112 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:22:33,118 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29330)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29328)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29326)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29329)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:22:38,357 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:22:38,359 | server.py:144 | FL finished in 9.265133869999772\n",
      "INFO flwr 2023-05-15 13:22:38,363 | app.py:202 | app_fit: losses_distributed [(1, 0.25098319116818296)]\n",
      "INFO flwr 2023-05-15 13:22:38,367 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2062656725389511)], 'reward': [(1, 0.9424345097399109)], 'global_regret': [(1, 0.26383116279904306)], 'local_regrets': [(1, {0: 0.28582888613234697, 1: 0.2867367501271772, 2: 0.2696043314095284, 3: 0.6189473826493932})]}\n",
      "INFO flwr 2023-05-15 13:22:38,370 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:22:38,374 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:22:38,399 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:22:48,174\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:22:52,101 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6061130138.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:22:52,104 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:22:52,106 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29357)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:22:55,088 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:22:55,090 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:22:55,092 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:22:55,094 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29357)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29357)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29358)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29358)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29355)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29355)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29353)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29353)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:22:58,365 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:22:58,413 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:22:58,417 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29357)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29358)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29355)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29353)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:23:02,398 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:23:02,400 | server.py:144 | FL finished in 7.305938572000741\n",
      "INFO flwr 2023-05-15 13:23:02,404 | app.py:202 | app_fit: losses_distributed [(1, 0.31555177247945193)]\n",
      "INFO flwr 2023-05-15 13:23:02,406 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2062656725389511)], 'reward': [(1, 0.885889622267471)], 'global_regret': [(1, 0.3203760502714826)], 'local_regrets': [(1, {0: 0.3281094290024229, 1: 0.3121564570693384, 2: 0.7567270432571046, 3: 0.32239874623465536})]}\n",
      "INFO flwr 2023-05-15 13:23:02,410 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:23:02,413 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:23:02,433 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:23:11,411\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:23:15,075 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6079241421.0}\n",
      "INFO flwr 2023-05-15 13:23:15,077 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:23:15,080 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29377)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:23:17,476 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:23:17,478 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:23:17,479 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:23:17,482 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29377)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29377)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29381)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29381)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29378)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29378)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29380)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29380)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:23:20,222 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:23:20,261 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:23:20,264 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29377)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29381)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29378)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29380)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:23:23,497 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:23:23,499 | server.py:144 | FL finished in 6.016884609000044\n",
      "INFO flwr 2023-05-15 13:23:23,502 | app.py:202 | app_fit: losses_distributed [(1, 0.38794419416496795)]\n",
      "INFO flwr 2023-05-15 13:23:23,504 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.201978609021876)], 'reward': [(1, 0.8131136797356442)], 'global_regret': [(1, 0.38886492928623123)], 'local_regrets': [(1, {0: 0.38955813823560487, 1: 0.39228917307230265, 2: 0.390640071165287, 3: 0.8364739798323902})]}\n",
      "INFO flwr 2023-05-15 13:23:23,506 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:23:23,509 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:23:23,526 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:23:33,124\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:23:36,675 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6075525530.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:23:36,678 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:23:36,680 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29399)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:23:39,061 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:23:39,062 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:23:39,064 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:23:39,066 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29399)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29399)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29402)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29402)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29400)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29400)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29397)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29397)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:23:42,039 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:23:42,083 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:23:42,087 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29399)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29402)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29400)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29397)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:23:46,153 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:23:46,155 | server.py:144 | FL finished in 7.089100483999573\n",
      "INFO flwr 2023-05-15 13:23:46,158 | app.py:202 | app_fit: losses_distributed [(1, 0.33066528243497245)]\n",
      "INFO flwr 2023-05-15 13:23:46,161 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4092187793413056)], 'reward': [(1, 1.0629440665221337)], 'global_regret': [(1, 0.34627471281917194)], 'local_regrets': [(1, {0: 0.8333973877809012, 1: 0.31979251414182996, 2: 0.30985784602105876, 3: 0.316797967441813})]}\n",
      "INFO flwr 2023-05-15 13:23:46,163 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:23:46,166 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9625d146ebb142189a3b46163fcb002b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:23:46,425 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:23:58,167\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:24:03,637 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6062295040.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:24:03,642 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:24:03,646 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29428)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:24:08,007 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:24:08,010 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:24:08,016 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:24:08,020 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29428)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29428)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29427)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29427)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29431)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29431)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29425)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29425)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:24:13,171 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:24:13,236 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:24:13,244 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29428)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29427)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29431)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29425)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:24:19,146 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:24:19,149 | server.py:144 | FL finished in 11.129090881999218\n",
      "INFO flwr 2023-05-15 13:24:19,153 | app.py:202 | app_fit: losses_distributed [(1, 0.12257019473631937)]\n",
      "INFO flwr 2023-05-15 13:24:19,156 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2039364563986787)], 'reward': [(1, 1.0819330644773617)], 'global_regret': [(1, 0.12200339192131673)], 'local_regrets': [(1, {0: 0.11999204010695405, 1: 0.5894540582628691, 2: 0.12114959476072458, 3: 0.11686967146044466})]}\n",
      "INFO flwr 2023-05-15 13:24:19,160 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:24:19,166 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:24:19,240 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:24:29,289\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:24:34,129 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'memory': 6112938804.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:24:34,132 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:24:34,136 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29453)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:24:37,478 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:24:37,481 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:24:37,483 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:24:37,486 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29453)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29453)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29455)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29455)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29454)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29454)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29450)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29450)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:24:41,722 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:24:41,783 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:24:41,789 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29453)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29455)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29454)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29450)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:24:46,121 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:24:46,123 | server.py:144 | FL finished in 8.637711360999674\n",
      "INFO flwr 2023-05-15 13:24:46,126 | app.py:202 | app_fit: losses_distributed [(1, 0.18775641568739065)]\n",
      "INFO flwr 2023-05-15 13:24:46,128 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2080660202704134)], 'reward': [(1, 1.0160500574497224)], 'global_regret': [(1, 0.19201596282069194)], 'local_regrets': [(1, {0: 0.1991966457874448, 1: 0.21030179127750762, 2: 0.20630373074243694, 3: 0.5924080805878889})]}\n",
      "INFO flwr 2023-05-15 13:24:46,131 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:24:46,134 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:24:46,162 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:24:57,354\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:25:01,219 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'memory': 6109635789.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:25:01,224 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:25:01,226 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29477)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:25:04,493 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:25:04,495 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:25:04,497 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:25:04,499 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29477)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29477)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29473)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29473)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29474)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29474)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29476)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29476)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:25:08,157 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:25:08,207 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:25:08,213 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29477)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29473)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29474)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29476)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:25:12,627 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:25:12,630 | server.py:144 | FL finished in 8.130936265000855\n",
      "INFO flwr 2023-05-15 13:25:12,634 | app.py:202 | app_fit: losses_distributed [(1, 0.2100126877484156)]\n",
      "INFO flwr 2023-05-15 13:25:12,637 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4035629645468752)], 'reward': [(1, 1.1962405068420896)], 'global_regret': [(1, 0.20732245770478555)], 'local_regrets': [(1, {0: 0.6616273915653902, 1: 0.21401380836305617, 2: 0.21001941647609423, 3: 0.211574720234836})]}\n",
      "INFO flwr 2023-05-15 13:25:12,641 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:25:12,644 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:25:12,672 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:25:22,779\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:25:27,198 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6118158746.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:25:27,201 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:25:27,203 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29503)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:25:30,262 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:25:30,264 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:25:30,266 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:25:30,269 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29503)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29503)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29499)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29499)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29501)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29501)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29500)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29500)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:25:34,103 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:25:34,164 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:25:34,171 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29500)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29499)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29501)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29503)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:25:38,884 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:25:38,887 | server.py:144 | FL finished in 8.61842763399909\n",
      "INFO flwr 2023-05-15 13:25:38,890 | app.py:202 | app_fit: losses_distributed [(1, 0.2370375996076272)]\n",
      "INFO flwr 2023-05-15 13:25:38,895 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4035629645468752)], 'reward': [(1, 1.1895166254555118)], 'global_regret': [(1, 0.2140463390913639)], 'local_regrets': [(1, {0: 0.6301097969453794, 1: 0.25969996495488473, 2: 0.26044218049765994, 3: 0.2550830416782982})]}\n",
      "INFO flwr 2023-05-15 13:25:38,898 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:25:38,903 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:25:38,937 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:25:49,055\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:25:53,192 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6111482676.0}\n",
      "INFO flwr 2023-05-15 13:25:53,196 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:25:53,199 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29527)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:25:56,327 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:25:56,329 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:25:56,331 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:25:56,334 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29527)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29527)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29521)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29521)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29526)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29526)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29520)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29520)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:25:59,900 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:25:59,945 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:25:59,950 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29527)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29521)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29526)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29520)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:26:04,333 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:26:04,335 | server.py:144 | FL finished in 8.001244373999725\n",
      "INFO flwr 2023-05-15 13:26:04,337 | app.py:202 | app_fit: losses_distributed [(1, 0.20900063259007165)]\n",
      "INFO flwr 2023-05-15 13:26:04,340 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2080660202704134)], 'reward': [(1, 1.0062308034289378)], 'global_regret': [(1, 0.20183521684147748)], 'local_regrets': [(1, {0: 0.18749445810047377, 1: 0.1852857388146436, 2: 0.7356189410342274, 3: 0.18478797805665487})]}\n",
      "INFO flwr 2023-05-15 13:26:04,343 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:26:04,348 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dfba7a7c9c314b909d3187192e121b1c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:26:04,645 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:26:14,850\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:26:19,211 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6102672180.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:26:19,213 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:26:19,215 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29548)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:26:22,374 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:26:22,376 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:26:22,378 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:26:22,380 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29548)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29548)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29550)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29550)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29552)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29552)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29551)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29551)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:26:25,995 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:26:26,046 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:26:26,050 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29548)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29551)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29550)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29552)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:26:30,229 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:26:30,231 | server.py:144 | FL finished in 7.851625371000409\n",
      "INFO flwr 2023-05-15 13:26:30,234 | app.py:202 | app_fit: losses_distributed [(1, 0.03674152437389598)]\n",
      "INFO flwr 2023-05-15 13:26:30,236 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4012500027713095)], 'reward': [(1, 1.3761644341903398)], 'global_regret': [(1, 0.025085568580970205)], 'local_regrets': [(1, {0: 0.4619690068461401, 1: 0.046821651195736516, 2: 0.04689554735729567, 3: 0.048464477742127})]}\n",
      "INFO flwr 2023-05-15 13:26:30,239 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:26:30,243 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:26:30,277 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:26:40,503\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:26:44,497 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6095911322.0}\n",
      "INFO flwr 2023-05-15 13:26:44,499 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:26:44,501 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29569)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:26:47,541 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:26:47,543 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:26:47,545 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:26:47,547 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29569)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29569)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29575)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29575)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29573)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29573)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29568)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29568)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:26:51,154 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:26:51,200 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:26:51,204 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29569)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29575)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29573)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29568)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:26:55,614 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:26:55,617 | server.py:144 | FL finished in 8.069526047000181\n",
      "INFO flwr 2023-05-15 13:26:55,622 | app.py:202 | app_fit: losses_distributed [(1, 0.09377123105504087)]\n",
      "INFO flwr 2023-05-15 13:26:55,625 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4012500027713095)], 'reward': [(1, 1.3141088797401415)], 'global_regret': [(1, 0.08714112303117005)], 'local_regrets': [(1, {0: 0.5337214911095737, 1: 0.10189712924551783, 2: 0.09807859281704193, 3: 0.09857229669374373})]}\n",
      "INFO flwr 2023-05-15 13:26:55,628 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:26:55,632 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:26:55,667 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:27:06,028\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:27:10,377 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6093529908.0}\n",
      "INFO flwr 2023-05-15 13:27:10,380 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:27:10,383 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29597)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:27:13,415 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:27:13,417 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:27:13,419 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:27:13,421 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29597)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29597)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29592)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29592)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29596)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29596)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29599)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29599)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:27:16,954 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:27:17,011 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:27:17,016 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29597)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29592)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29596)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29599)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:27:22,220 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:27:22,222 | server.py:144 | FL finished in 8.80183740800021\n",
      "INFO flwr 2023-05-15 13:27:22,224 | app.py:202 | app_fit: losses_distributed [(1, 0.05288779150208683)]\n",
      "INFO flwr 2023-05-15 13:27:22,228 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.208802277668675)], 'reward': [(1, 1.153973670260451)], 'global_regret': [(1, 0.054828607408224296)], 'local_regrets': [(1, {0: 0.05773012532909546, 1: 0.055472418348493396, 2: 0.05900946216731055, 3: 0.4965237458091626})]}\n",
      "INFO flwr 2023-05-15 13:27:22,231 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:27:22,234 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:27:22,270 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:27:32,547\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:27:36,844 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6087122944.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:27:36,847 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:27:36,850 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29616)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:27:40,027 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:27:40,028 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:27:40,031 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:27:40,033 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29616)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29616)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29619)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29619)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29622)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29622)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29623)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29623)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:27:44,100 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:27:44,157 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:27:44,162 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29616)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29619)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29622)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29623)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:27:48,995 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:27:48,997 | server.py:144 | FL finished in 8.964016601001276\n",
      "INFO flwr 2023-05-15 13:27:48,999 | app.py:202 | app_fit: losses_distributed [(1, 0.07287205003959601)]\n",
      "INFO flwr 2023-05-15 13:27:49,003 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.4012500027713095)], 'reward': [(1, 1.3232642460073418)], 'global_regret': [(1, 0.07798575676396707)], 'local_regrets': [(1, {0: 0.5472247791801564, 1: 0.06571421359562533, 2: 0.06782583876324366, 3: 0.0679079542650737})]}\n",
      "INFO flwr 2023-05-15 13:27:49,005 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:27:49,009 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:27:49,093 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:27:59,617\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:28:04,147 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6090094183.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:28:04,150 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:28:04,153 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29644)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:28:07,306 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:28:07,308 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:28:07,310 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:28:07,313 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29644)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29644)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29649)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29649)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29643)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29643)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29646)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29646)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:28:10,908 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:28:10,961 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:28:10,966 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29644)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29646)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29649)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29643)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:28:15,588 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:28:15,591 | server.py:144 | FL finished in 8.278326120000202\n",
      "INFO flwr 2023-05-15 13:28:15,594 | app.py:202 | app_fit: losses_distributed [(1, 0.07587769926117457)]\n",
      "INFO flwr 2023-05-15 13:28:15,597 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2047371237312432)], 'reward': [(1, 1.1315805245539443)], 'global_regret': [(1, 0.07315659917729811)], 'local_regrets': [(1, {0: 0.06696282317409727, 1: 0.07170873467992551, 2: 0.07172713374055967, 3: 0.5502966910958309})]}\n",
      "INFO flwr 2023-05-15 13:28:15,599 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:28:15,602 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "413e65ef1c354ce38a01e99ada471550",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:28:15,906 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:28:25,763\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:28:29,841 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6079949210.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:28:29,848 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:28:29,852 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29667)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:28:33,022 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:28:33,025 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:28:33,027 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:28:33,030 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29667)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29667)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29668)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29668)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29674)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29674)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29672)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29672)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:28:36,598 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:28:36,649 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:28:36,654 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29667)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29668)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29674)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29672)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:28:41,156 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:28:41,158 | server.py:144 | FL finished in 8.128526315000272\n",
      "INFO flwr 2023-05-15 13:28:41,161 | app.py:202 | app_fit: losses_distributed [(1, 0.026319834267434283)]\n",
      "INFO flwr 2023-05-15 13:28:41,163 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2066788533632584)], 'reward': [(1, 1.1787306419054806)], 'global_regret': [(1, 0.027948211457779173)], 'local_regrets': [(1, {0: 0.03072681238739487, 1: 0.47103336838519344, 2: 0.03001398473979287, 3: 0.030689757203070274})]}\n",
      "INFO flwr 2023-05-15 13:28:41,166 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:28:41,170 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:28:41,208 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:28:50,353\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:28:54,771 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6086551552.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:28:54,775 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:28:54,779 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29697)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:28:57,881 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:28:57,883 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:28:57,885 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:28:57,888 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29697)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29697)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29694)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29694)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29691)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29691)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29692)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29692)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:29:01,496 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:29:01,545 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:29:01,550 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29697)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29694)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29691)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29692)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:29:06,349 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:29:06,352 | server.py:144 | FL finished in 8.464289120000103\n",
      "INFO flwr 2023-05-15 13:29:06,357 | app.py:202 | app_fit: losses_distributed [(1, 0.05538386334620759)]\n",
      "INFO flwr 2023-05-15 13:29:06,359 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2051366327581172)], 'reward': [(1, 1.1518434207578427)], 'global_regret': [(1, 0.053293212000275036)], 'local_regrets': [(1, {0: 0.04826702674971154, 1: 0.5323758745261901, 2: 0.04917711597570151, 3: 0.04890002177894167})]}\n",
      "INFO flwr 2023-05-15 13:29:06,362 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:29:06,365 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:29:06,435 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:29:17,238\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:29:21,149 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6078869095.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:29:21,152 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:29:21,154 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29726)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:29:23,722 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:29:23,723 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:29:23,726 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:29:23,729 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29726)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29726)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29727)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29727)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29729)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29729)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29724)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29724)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:29:27,359 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:29:27,408 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:29:27,413 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29726)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29727)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29729)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29724)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:29:31,405 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:29:31,407 | server.py:144 | FL finished in 7.67823103199953\n",
      "INFO flwr 2023-05-15 13:29:31,410 | app.py:202 | app_fit: losses_distributed [(1, 0.07631375422461585)]\n",
      "INFO flwr 2023-05-15 13:29:31,413 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2066788533632584)], 'reward': [(1, 1.1255665497135294)], 'global_regret': [(1, 0.08111230364972973)], 'local_regrets': [(1, {0: 0.09008147713228015, 1: 0.4852137402508749, 2: 0.09088105745084601, 3: 0.09626332771017652})]}\n",
      "INFO flwr 2023-05-15 13:29:31,415 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:29:31,420 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:29:31,530 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:29:40,719\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:29:45,029 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'memory': 6051622912.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:29:45,032 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:29:45,036 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29755)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:29:48,163 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:29:48,165 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:29:48,167 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:29:48,169 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29755)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29755)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29749)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29749)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29750)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29750)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29754)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29754)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:29:51,710 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:29:51,758 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:29:51,763 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29755)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29749)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29750)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29754)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:29:55,819 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:29:55,821 | server.py:144 | FL finished in 7.65201306400013\n",
      "INFO flwr 2023-05-15 13:29:55,824 | app.py:202 | app_fit: losses_distributed [(1, 0.020078154020690808)]\n",
      "INFO flwr 2023-05-15 13:29:55,827 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2091696480667733)], 'reward': [(1, 1.1885391417299185)], 'global_regret': [(1, 0.020630506336854437)], 'local_regrets': [(1, {0: 0.02086600046260732, 1: 0.47305437291636865, 2: 0.020395863282491492, 3: 0.023180965067010163})]}\n",
      "INFO flwr 2023-05-15 13:29:55,830 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:29:55,833 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:29:55,867 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:30:05,848\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:30:10,077 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6067231130.0}\n",
      "INFO flwr 2023-05-15 13:30:10,079 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:30:10,082 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29779)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:30:12,979 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:30:12,981 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:30:12,982 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:30:12,985 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29779)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29779)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29776)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29776)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29774)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29774)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29773)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29773)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:30:16,198 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:30:16,245 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:30:16,251 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29779)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29776)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29774)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29773)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:30:20,630 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:30:20,633 | server.py:144 | FL finished in 7.648690903999523\n",
      "INFO flwr 2023-05-15 13:30:20,636 | app.py:202 | app_fit: losses_distributed [(1, 0.07090227085551355)]\n",
      "INFO flwr 2023-05-15 13:30:20,638 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2051366327581174)], 'reward': [(1, 1.1363064345079015)], 'global_regret': [(1, 0.06883019825021561)], 'local_regrets': [(1, {0: 0.06384029274514329, 1: 0.05929236292534942, 2: 0.05998454754103595, 3: 0.5576764658562399})]}\n",
      "INFO flwr 2023-05-15 13:30:20,641 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:30:20,644 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "07e46d05b627474c91dd150ec6093670",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:30:20,931 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:30:29,726\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:30:33,602 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6061259162.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:30:33,607 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:30:33,609 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29802)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:30:36,467 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:30:36,468 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:30:36,470 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:30:36,473 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29802)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29802)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29797)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29797)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29801)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29801)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29804)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29804)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:30:39,935 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:30:39,979 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:30:39,985 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29802)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29797)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29801)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29804)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:30:43,933 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:30:43,936 | server.py:144 | FL finished in 7.463195438000184\n",
      "INFO flwr 2023-05-15 13:30:43,939 | app.py:202 | app_fit: losses_distributed [(1, 0.04400621066876914)]\n",
      "INFO flwr 2023-05-15 13:30:43,941 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2053334165194598)], 'reward': [(1, 1.1615366576787167)], 'global_regret': [(1, 0.04379675884074351)], 'local_regrets': [(1, {0: 0.042441659921595085, 1: 0.5026604277888107, 2: 0.0445325716991604, 3: 0.04357476891122432})]}\n",
      "INFO flwr 2023-05-15 13:30:43,944 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:30:43,948 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:30:43,984 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:30:52,816\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:30:57,153 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6049908736.0}\n",
      "INFO flwr 2023-05-15 13:30:57,156 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:30:57,159 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29827)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:31:00,375 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:31:00,377 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:31:00,380 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:31:00,382 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29827)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29827)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29825)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29825)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29826)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29826)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29821)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29821)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:31:03,983 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:31:04,032 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:31:04,038 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29827)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29825)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29826)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29821)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:31:08,233 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:31:08,236 | server.py:144 | FL finished in 7.853437244999441\n",
      "INFO flwr 2023-05-15 13:31:08,238 | app.py:202 | app_fit: losses_distributed [(1, 0.03803200803706408)]\n",
      "INFO flwr 2023-05-15 13:31:08,240 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2053334165194598)], 'reward': [(1, 1.1671653666173913)], 'global_regret': [(1, 0.03816804990206851)], 'local_regrets': [(1, {0: 0.03749163592293759, 1: 0.04087998512339161, 2: 0.03975460909976877, 3: 0.4911863876478732})]}\n",
      "INFO flwr 2023-05-15 13:31:08,243 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:31:08,247 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:31:08,285 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:31:18,651\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:31:22,758 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6046966989.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:31:22,761 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:31:22,763 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29844)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:31:25,949 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:31:25,951 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:31:25,953 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:31:25,955 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29844)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29844)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29850)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29850)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29848)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29848)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29845)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29845)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:31:29,520 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:31:29,572 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:31:29,577 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29844)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29850)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29848)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29845)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:31:34,811 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:31:34,814 | server.py:144 | FL finished in 8.859366151998984\n",
      "INFO flwr 2023-05-15 13:31:34,819 | app.py:202 | app_fit: losses_distributed [(1, 0.03557135549429801)]\n",
      "INFO flwr 2023-05-15 13:31:34,822 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2068695836233723)], 'reward': [(1, 1.171374403839963)], 'global_regret': [(1, 0.0354951797834099)], 'local_regrets': [(1, {0: 0.03494431860462421, 1: 0.03665178488431862, 2: 0.4926203801781701, 3: 0.03525352395579428})]}\n",
      "INFO flwr 2023-05-15 13:31:34,826 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:31:34,829 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:31:34,873 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:31:45,602\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:31:49,904 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'memory': 6052463412.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:31:49,908 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:31:49,911 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29872)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:31:53,472 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:31:53,475 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:31:53,477 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:31:53,480 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29872)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29872)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29875)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29875)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29876)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29876)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29870)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29870)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:31:57,626 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:31:57,681 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:31:57,687 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29872)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29875)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29876)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29870)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:32:02,850 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:32:02,852 | server.py:144 | FL finished in 9.37203587499971\n",
      "INFO flwr 2023-05-15 13:32:02,855 | app.py:202 | app_fit: losses_distributed [(1, 0.04404167171752909)]\n",
      "INFO flwr 2023-05-15 13:32:02,857 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2053334165194598)], 'reward': [(1, 1.1589833302640045)], 'global_regret': [(1, 0.04635008625545467)], 'local_regrets': [(1, {0: 0.04994106310562288, 1: 0.48521798363002105, 2: 0.04888925846417811, 3: 0.0493029673160091})]}\n",
      "INFO flwr 2023-05-15 13:32:02,859 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:32:02,867 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:32:02,912 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:32:13,371\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:32:18,175 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6049702298.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:32:18,179 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:32:18,183 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29895)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:32:21,629 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:32:21,631 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:32:21,634 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:32:21,637 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29895)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29895)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29900)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29900)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29894)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29894)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29897)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29897)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:32:25,938 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:32:25,990 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:32:25,995 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29900)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29894)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29895)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29897)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:32:30,489 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:32:30,491 | server.py:144 | FL finished in 8.855248987998493\n",
      "INFO flwr 2023-05-15 13:32:30,496 | app.py:202 | app_fit: losses_distributed [(1, 0.034302378415770544)]\n",
      "INFO flwr 2023-05-15 13:32:30,499 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2053334165194598)], 'reward': [(1, 1.1692655565355192)], 'global_regret': [(1, 0.03606785998394042)], 'local_regrets': [(1, {0: 0.0385923038193363, 1: 0.47524947146056545, 2: 0.04110353276859128, 3: 0.03944879126030361})]}\n",
      "INFO flwr 2023-05-15 13:32:30,502 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:32:30,505 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cc5bfc0a44d94f6dab0a398dc7ea6cd5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:32:30,847 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:32:41,782\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:32:45,923 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6045282304.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:32:45,926 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:32:45,929 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29922)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:32:49,195 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:32:49,196 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:32:49,199 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:32:49,201 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29922)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29922)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29923)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29923)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29919)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29919)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29924)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29924)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:32:52,818 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:32:52,871 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:32:52,876 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29922)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29923)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29919)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29924)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:32:57,443 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:32:57,445 | server.py:144 | FL finished in 8.244426641000246\n",
      "INFO flwr 2023-05-15 13:32:57,448 | app.py:202 | app_fit: losses_distributed [(1, 0.013832441948577657)]\n",
      "INFO flwr 2023-05-15 13:32:57,451 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2096415440900443)], 'reward': [(1, 1.1960777881632236)], 'global_regret': [(1, 0.013563755926819729)], 'local_regrets': [(1, {0: 0.0121877575496981, 1: 0.475298986193703, 2: 0.011780246926573085, 3: 0.013247362770051584})]}\n",
      "INFO flwr 2023-05-15 13:32:57,453 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:32:57,456 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:32:57,490 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:33:06,893\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:33:10,818 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6051106816.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:33:10,820 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:33:10,823 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29941)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:33:13,467 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:33:13,469 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:33:13,470 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:33:13,473 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29941)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29941)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29946)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29946)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29948)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29948)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29945)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29945)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:33:16,702 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:33:16,749 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:33:16,753 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29945)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29946)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29941)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29948)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:33:20,656 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:33:20,659 | server.py:144 | FL finished in 7.186583643999256\n",
      "INFO flwr 2023-05-15 13:33:20,664 | app.py:202 | app_fit: losses_distributed [(1, 0.010856091990931216)]\n",
      "INFO flwr 2023-05-15 13:33:20,667 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2096415440900443)], 'reward': [(1, 1.1987708054512238)], 'global_regret': [(1, 0.010870738638820335)], 'local_regrets': [(1, {0: 0.01005667211963832, 1: 0.011017655724694998, 2: 0.01011173345329111, 3: 0.46942289231181594})]}\n",
      "INFO flwr 2023-05-15 13:33:20,670 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:33:20,675 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:33:20,716 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:33:29,912\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:33:33,810 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6052964762.0}\n",
      "INFO flwr 2023-05-15 13:33:33,813 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:33:33,814 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29968)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:33:36,713 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:33:36,715 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:33:36,717 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:33:36,719 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29968)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29968)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29967)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29967)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29969)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29969)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29970)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29970)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:33:40,503 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:33:40,553 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:33:40,558 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29968)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29967)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29969)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29970)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:33:46,068 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:33:46,070 | server.py:144 | FL finished in 9.351296849999926\n",
      "INFO flwr 2023-05-15 13:33:46,075 | app.py:202 | app_fit: losses_distributed [(1, 0.007084748263045903)]\n",
      "INFO flwr 2023-05-15 13:33:46,078 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2071762457102662)], 'reward': [(1, 1.2006181693022893)], 'global_regret': [(1, 0.006558076407977415)], 'local_regrets': [(1, {0: 0.005112309266417266, 1: 0.47056981594463887, 2: 0.0051468786221063895, 3: 0.004694574864735677})]}\n",
      "INFO flwr 2023-05-15 13:33:46,081 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:33:46,085 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:33:46,124 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:33:57,802\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:34:02,317 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6054321357.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:34:02,321 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:34:02,323 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=29993)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:34:05,514 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:34:05,516 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:34:05,518 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:34:05,520 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=29993)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29993)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29996)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29996)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29995)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29995)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29997)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=29997)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:34:09,325 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:34:09,376 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:34:09,380 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29993)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29996)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29997)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=29995)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:34:13,881 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:34:13,883 | server.py:144 | FL finished in 8.363381258999652\n",
      "INFO flwr 2023-05-15 13:34:13,887 | app.py:202 | app_fit: losses_distributed [(1, 0.015604162987010244)]\n",
      "INFO flwr 2023-05-15 13:34:13,890 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2096415440900443)], 'reward': [(1, 1.1943917424248536)], 'global_regret': [(1, 0.015249801665189525)], 'local_regrets': [(1, {0: 0.01370388401753765, 1: 0.015052666470822125, 2: 0.015161488830514741, 3: 0.47568319827488165})]}\n",
      "INFO flwr 2023-05-15 13:34:13,893 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:34:13,897 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:34:13,936 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:34:24,060\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:34:28,035 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6038381364.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:34:28,038 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:34:28,040 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30019)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:34:31,017 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:34:31,019 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:34:31,021 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:34:31,024 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30019)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30019)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30016)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30016)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30020)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30020)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30015)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30015)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:34:34,616 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:34:34,670 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:34:34,675 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30019)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30015)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30016)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30020)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:34:38,582 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:34:38,584 | server.py:144 | FL finished in 7.560255528998823\n",
      "INFO flwr 2023-05-15 13:34:38,587 | app.py:202 | app_fit: losses_distributed [(1, 0.01820816563818339)]\n",
      "INFO flwr 2023-05-15 13:34:38,589 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3986134368682366)], 'reward': [(1, 1.379516211884195)], 'global_regret': [(1, 0.01909722498404091)], 'local_regrets': [(1, {0: 0.4802330671565899, 1: 0.015883343117741963, 2: 0.016381969698022705, 3: 0.01751886822609359})]}\n",
      "INFO flwr 2023-05-15 13:34:38,592 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:34:38,595 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d2c27f69b62246ad99d25071cac99492",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:34:38,927 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:34:49,122\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:34:53,442 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6044441805.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:34:53,445 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:34:53,447 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30042)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:34:56,719 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:34:56,721 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:34:56,724 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:34:56,726 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30042)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30042)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30044)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30044)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30045)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30045)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30043)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30043)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:35:00,526 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:35:00,576 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:35:00,581 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30042)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30044)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30045)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30043)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:35:04,964 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:35:04,967 | server.py:144 | FL finished in 8.241883906001021\n",
      "INFO flwr 2023-05-15 13:35:04,971 | app.py:202 | app_fit: losses_distributed [(1, 0.005835794908798537)]\n",
      "INFO flwr 2023-05-15 13:35:04,974 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2057682375053655)], 'reward': [(1, 1.199859271652699)], 'global_regret': [(1, 0.005908965852666655)], 'local_regrets': [(1, {0: 0.0051109540515556695, 1: 0.4644882561112404, 2: 0.005124196788625043, 3: 0.005804358329487303})]}\n",
      "INFO flwr 2023-05-15 13:35:04,977 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:35:04,981 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:35:05,030 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:35:14,909\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:35:18,903 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6053996954.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:35:18,906 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:35:18,908 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30068)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:35:21,829 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:35:21,831 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:35:21,833 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:35:21,836 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30068)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30068)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30065)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30065)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30064)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30064)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30069)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30069)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:35:25,601 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:35:25,645 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:35:25,649 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30068)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30065)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30064)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30069)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:35:29,889 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:35:29,891 | server.py:144 | FL finished in 8.055705581000439\n",
      "INFO flwr 2023-05-15 13:35:29,895 | app.py:202 | app_fit: losses_distributed [(1, 0.004831258190524558)]\n",
      "INFO flwr 2023-05-15 13:35:29,897 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.398271329046525)], 'reward': [(1, 1.3942111117031966)], 'global_regret': [(1, 0.004060217343327527)], 'local_regrets': [(1, {0: 0.46189809053117814, 1: 0.004562028146389352, 2: 0.005066264535310838, 3: 0.004983235194934481})]}\n",
      "INFO flwr 2023-05-15 13:35:29,900 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:35:29,905 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:35:30,058 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:35:40,361\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:35:44,433 | app.py:179 | Flower VCE: Ray initialized with resources: {'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6057897165.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:35:44,436 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:35:44,438 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30093)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:35:47,781 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:35:47,783 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:35:47,785 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:35:47,787 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30093)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30093)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30089)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30089)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30091)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30091)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30088)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30088)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:35:51,571 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:35:51,618 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:35:51,622 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30093)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30089)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30091)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30088)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:35:56,065 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:35:56,067 | server.py:144 | FL finished in 8.280260912000813\n",
      "INFO flwr 2023-05-15 13:35:56,072 | app.py:202 | app_fit: losses_distributed [(1, 0.010579202808370297)]\n",
      "INFO flwr 2023-05-15 13:35:56,075 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2072910285595757)], 'reward': [(1, 1.1969115943097812)], 'global_regret': [(1, 0.010379434249794239)], 'local_regrets': [(1, {0: 0.009580586548258736, 1: 0.008823536481833434, 2: 0.4708811617086823, 3: 0.010216112140421679})]}\n",
      "INFO flwr 2023-05-15 13:35:56,079 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:35:56,082 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:35:56,136 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:36:05,880\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:36:10,104 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6052389684.0}\n",
      "INFO flwr 2023-05-15 13:36:10,108 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:36:10,111 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30117)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:36:13,428 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:36:13,430 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:36:13,432 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:36:13,434 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30117)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30117)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30112)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30112)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30116)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30116)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30113)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30113)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:36:17,375 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:36:17,421 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:36:17,427 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30117)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30112)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30116)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30113)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:36:21,825 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:36:21,827 | server.py:144 | FL finished in 8.393944797999211\n",
      "INFO flwr 2023-05-15 13:36:21,831 | app.py:202 | app_fit: losses_distributed [(1, 0.002816470001053226)]\n",
      "INFO flwr 2023-05-15 13:36:21,834 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2072910285595757)], 'reward': [(1, 1.2042179735970313)], 'global_regret': [(1, 0.003073054962544775)], 'local_regrets': [(1, {0: 0.003182547281813694, 1: 0.002391981168577595, 2: 0.4600780070992916, 3: 0.0027979301002445606})]}\n",
      "INFO flwr 2023-05-15 13:36:21,837 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:36:21,840 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:36:21,891 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:36:31,597\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:36:35,860 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6059670324.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:36:35,863 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:36:35,865 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30140)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:36:39,231 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:36:39,234 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:36:39,236 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:36:39,238 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30140)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30140)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30138)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30138)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30137)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30137)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30135)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30135)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:36:42,966 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:36:43,008 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:36:43,012 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30140)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30138)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30137)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30135)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:36:47,821 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:36:47,823 | server.py:144 | FL finished in 8.585321852000561\n",
      "INFO flwr 2023-05-15 13:36:47,828 | app.py:202 | app_fit: losses_distributed [(1, 0.006088748544286666)]\n",
      "INFO flwr 2023-05-15 13:36:47,831 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2057682375053655)], 'reward': [(1, 1.1993374345528478)], 'global_regret': [(1, 0.00643080295251798)], 'local_regrets': [(1, {0: 0.006167985032627517, 1: 0.005208798991771063, 2: 0.4637246359086078, 3: 0.006438159889854787})]}\n",
      "INFO flwr 2023-05-15 13:36:47,834 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:36:47,837 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2ba10c4b83e041f9babf6f0ab1235698",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:36:48,223 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:36:58,265\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:37:02,532 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6052599808.0}\n",
      "INFO flwr 2023-05-15 13:37:02,535 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:37:02,537 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30165)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:37:05,373 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:37:05,375 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:37:05,377 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:37:05,379 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30165)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30165)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30161)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30161)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30163)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30163)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30164)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30164)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:37:09,007 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:37:09,057 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:37:09,061 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30165)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30161)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30163)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30164)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:37:13,117 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:37:13,119 | server.py:144 | FL finished in 7.74042238400034\n",
      "INFO flwr 2023-05-15 13:37:13,123 | app.py:202 | app_fit: losses_distributed [(1, 0.0038080778046788127)]\n",
      "INFO flwr 2023-05-15 13:37:13,125 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2073420295535615)], 'reward': [(1, 1.2032358118116433)], 'global_regret': [(1, 0.004106217741918102)], 'local_regrets': [(1, {0: 0.004299371084141393, 1: 0.4605545781979304, 2: 0.003681121678597834, 3: 0.00388182590376056})]}\n",
      "INFO flwr 2023-05-15 13:37:13,128 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:37:13,130 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:37:13,232 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:37:22,916\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:37:26,682 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6049440564.0, 'object_store_memory': 2147483648.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:37:26,685 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:37:26,687 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30182)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:37:29,358 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:37:29,360 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:37:29,362 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:37:29,365 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30182)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30182)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30186)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30186)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30183)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30183)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30188)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30188)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:37:33,119 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:37:33,170 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:37:33,177 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30182)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30188)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30186)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30183)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:37:37,637 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:37:37,640 | server.py:144 | FL finished in 8.275845361000393\n",
      "INFO flwr 2023-05-15 13:37:37,646 | app.py:202 | app_fit: losses_distributed [(1, 0.0042176264684784795)]\n",
      "INFO flwr 2023-05-15 13:37:37,649 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2058208571967703)], 'reward': [(1, 1.2015632520041937)], 'global_regret': [(1, 0.004257605192576435)], 'local_regrets': [(1, {0: 0.0033936537992169434, 1: 0.0032678277339834596, 2: 0.46424917841360314, 3: 0.0031444315728248336})]}\n",
      "INFO flwr 2023-05-15 13:37:37,652 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:37:37,660 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:37:37,794 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:37:48,316\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:37:52,607 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'memory': 6045820519.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:37:52,610 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:37:52,613 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30211)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:37:55,851 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:37:55,853 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:37:55,855 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:37:55,857 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30211)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30211)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30212)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30212)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30207)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30207)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30209)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30209)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:37:59,603 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:37:59,650 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:37:59,654 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30211)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30207)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30212)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30209)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:38:04,569 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:38:04,572 | server.py:144 | FL finished in 8.714711569999054\n",
      "INFO flwr 2023-05-15 13:38:04,577 | app.py:202 | app_fit: losses_distributed [(1, 0.0030157490624849958)]\n",
      "INFO flwr 2023-05-15 13:38:04,581 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3981193216772831)], 'reward': [(1, 1.3945678439809461)], 'global_regret': [(1, 0.00355147769633667)], 'local_regrets': [(1, {0: 0.4639920896453544, 1: 0.00247079775949637, 2: 0.0014175768700464327, 3: 0.0013671176207573751})]}\n",
      "INFO flwr 2023-05-15 13:38:04,584 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:38:04,593 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:38:04,661 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:38:15,160\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:38:19,355 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6051416474.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:38:19,358 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:38:19,360 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30232)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:38:22,566 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:38:22,569 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:38:22,571 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:38:22,574 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30232)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30232)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30236)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30236)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30234)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30234)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30235)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30235)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:38:26,541 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:38:26,588 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:38:26,592 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30232)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30236)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30234)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30235)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:38:30,982 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:38:30,984 | server.py:144 | FL finished in 8.410813336000501\n",
      "INFO flwr 2023-05-15 13:38:30,988 | app.py:202 | app_fit: losses_distributed [(1, 0.00493634907480462)]\n",
      "INFO flwr 2023-05-15 13:38:30,991 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2058208571967701)], 'reward': [(1, 1.2008803550908034)], 'global_regret': [(1, 0.004940502105967419)], 'local_regrets': [(1, {0: 0.0040051281535188376, 1: 0.003970769988763354, 2: 0.4646045473511156, 3: 0.004349536451534985})]}\n",
      "INFO flwr 2023-05-15 13:38:30,994 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:38:30,998 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:38:31,058 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:38:41,432\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:38:45,546 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'memory': 6052721460.0, 'node:127.0.0.1': 1.0}\n",
      "INFO flwr 2023-05-15 13:38:45,550 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:38:45,553 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30257)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:38:48,779 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:38:48,781 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:38:48,784 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:38:48,786 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30257)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30257)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30256)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30256)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30259)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30259)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30254)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30254)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:38:52,630 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:38:52,682 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:38:52,687 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30257)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30254)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30256)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30259)\u001b[0m [Client 1] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:38:57,501 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:38:57,504 | server.py:144 | FL finished in 8.718266345000302\n",
      "INFO flwr 2023-05-15 13:38:57,509 | app.py:202 | app_fit: losses_distributed [(1, 0.004406521120598903)]\n",
      "INFO flwr 2023-05-15 13:38:57,511 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.2058208571967703)], 'reward': [(1, 1.2012606146011657)], 'global_regret': [(1, 0.004560242595605277)], 'local_regrets': [(1, {0: 0.003923050203458017, 1: 0.003928043433529977, 2: 0.4631595193374328, 3: 0.0038000571536897197})]}\n",
      "INFO flwr 2023-05-15 13:38:57,514 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:38:57,518 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a9b28ff3c83d4668baab0023a7fb3787",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:38:57,924 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:39:08,157\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:39:12,218 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'memory': 6050214708.0, 'node:127.0.0.1': 1.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:39:12,224 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:39:12,226 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30284)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:39:15,707 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:39:15,709 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:39:15,711 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:39:15,714 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30284)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30284)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30280)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30280)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30285)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30285)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30286)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30286)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:39:19,704 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:39:19,751 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:39:19,755 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30284)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30280)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30285)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30286)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:39:24,410 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:39:24,412 | server.py:144 | FL finished in 8.698719646001337\n",
      "INFO flwr 2023-05-15 13:39:24,417 | app.py:202 | app_fit: losses_distributed [(1, 0.005104462921784191)]\n",
      "INFO flwr 2023-05-15 13:39:24,421 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.205837310391766)], 'reward': [(1, 1.2011242178068726)], 'global_regret': [(1, 0.00471309258489367)], 'local_regrets': [(1, {0: 0.002988808235822076, 1: 0.0033656467913767904, 2: 0.46768149783666885, 3: 0.0035664844689840473})]}\n",
      "INFO flwr 2023-05-15 13:39:24,425 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:39:24,429 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:39:24,732 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:39:35,023\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:39:39,503 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0, 'memory': 6042108314.0, 'CPU': 8.0}\n",
      "INFO flwr 2023-05-15 13:39:39,507 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:39:39,510 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30310)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:39:43,212 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:39:43,215 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:39:43,217 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:39:43,219 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30310)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30310)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30307)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30307)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30308)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30308)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30305)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30305)\u001b[0m [Client 3] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:39:47,604 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:39:47,659 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:39:47,664 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30310)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30307)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30308)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30305)\u001b[0m [Client 3] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:39:52,412 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:39:52,414 | server.py:144 | FL finished in 9.195071062000352\n",
      "INFO flwr 2023-05-15 13:39:52,419 | app.py:202 | app_fit: losses_distributed [(1, 0.005188609087728361)]\n",
      "INFO flwr 2023-05-15 13:39:52,423 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.205837310391766)], 'reward': [(1, 1.2008192261083726)], 'global_regret': [(1, 0.005018084283393349)], 'local_regrets': [(1, {0: 0.0037343004574782995, 1: 0.004926329433607267, 2: 0.46501090939640116, 3: 0.004267482709141625})]}\n",
      "INFO flwr 2023-05-15 13:39:52,426 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:39:52,430 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:39:52,515 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:40:03,113\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:40:07,195 | app.py:179 | Flower VCE: Ray initialized with resources: {'memory': 6044792013.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'object_store_memory': 2147483648.0}\n",
      "INFO flwr 2023-05-15 13:40:07,199 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:40:07,205 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30330)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:40:10,636 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:40:10,638 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:40:10,641 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:40:10,645 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30330)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30330)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30328)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30328)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30327)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30327)\u001b[0m [Client 2] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30326)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30326)\u001b[0m [Client 1] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:40:14,457 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:40:14,503 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:40:14,507 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30330)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30327)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30328)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30326)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:40:18,649 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:40:18,650 | server.py:144 | FL finished in 8.005856195999513\n",
      "INFO flwr 2023-05-15 13:40:18,655 | app.py:202 | app_fit: losses_distributed [(1, 0.0009102739076128465)]\n",
      "INFO flwr 2023-05-15 13:40:18,658 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.205837310391766)], 'reward': [(1, 1.204723774837168)], 'global_regret': [(1, 0.0011135355545981922)], 'local_regrets': [(1, {0: 0.0005753096100229367, 1: 0.4587748461138388, 2: 0.0006718056415713102, 3: 0.0008037199107333167})]}\n",
      "INFO flwr 2023-05-15 13:40:18,661 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:40:18,665 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:40:18,835 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:40:28,400\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:40:32,449 | app.py:179 | Flower VCE: Ray initialized with resources: {'node:127.0.0.1': 1.0, 'CPU': 8.0, 'object_store_memory': 2147483648.0, 'memory': 6044146893.0}\n",
      "INFO flwr 2023-05-15 13:40:32,452 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:40:32,454 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30353)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:40:35,393 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:40:35,395 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:40:35,397 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:40:35,400 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30353)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30353)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30356)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30356)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30354)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30354)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30355)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30355)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:40:38,864 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:40:38,910 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:40:38,914 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30353)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30356)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30354)\u001b[0m [Client 2] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30355)\u001b[0m [Client 0] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:40:43,234 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:40:43,237 | server.py:144 | FL finished in 7.837302988998999\n",
      "INFO flwr 2023-05-15 13:40:43,240 | app.py:202 | app_fit: losses_distributed [(1, 0.0040322413865993886)]\n",
      "INFO flwr 2023-05-15 13:40:43,242 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.205837310391766)], 'reward': [(1, 1.2018771030607813)], 'global_regret': [(1, 0.003960207330984365)], 'local_regrets': [(1, {0: 0.0028728740550768377, 1: 0.0031573051468796595, 2: 0.4646818080280799, 3: 0.0026015639620756564})]}\n",
      "INFO flwr 2023-05-15 13:40:43,246 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:40:43,249 | app.py:205 | app_fit: metrics_centralized {}\n",
      "INFO flwr 2023-05-15 13:40:43,362 | app.py:145 | Starting Flower simulation, config: ServerConfig(num_rounds=1, round_timeout=None)\n",
      "2023-05-15 13:40:52,140\tINFO worker.py:1529 -- Started a local Ray instance. View the dashboard at \u001b[1m\u001b[32m127.0.0.1:8265 \u001b[39m\u001b[22m\n",
      "INFO flwr 2023-05-15 13:40:56,278 | app.py:179 | Flower VCE: Ray initialized with resources: {'object_store_memory': 2147483648.0, 'CPU': 8.0, 'node:127.0.0.1': 1.0, 'memory': 6050133607.0}\n",
      "INFO flwr 2023-05-15 13:40:56,281 | server.py:86 | Initializing global parameters\n",
      "INFO flwr 2023-05-15 13:40:56,284 | server.py:270 | Requesting initial parameters from one random client\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_get_parameters pid=30376)\u001b[0m [Client 0] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO flwr 2023-05-15 13:40:59,291 | server.py:274 | Received initial parameters from one random client\n",
      "INFO flwr 2023-05-15 13:40:59,293 | server.py:88 | Evaluating initial parameters\n",
      "INFO flwr 2023-05-15 13:40:59,295 | server.py:101 | FL starting\n",
      "DEBUG flwr 2023-05-15 13:40:59,296 | server.py:215 | fit_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_fit pid=30376)\u001b[0m Client 0, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30376)\u001b[0m [Client 0] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30379)\u001b[0m Client 1, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30379)\u001b[0m [Client 1] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30377)\u001b[0m Client 3, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30377)\u001b[0m [Client 3] get_parameters\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30381)\u001b[0m Client 2, training finished for round 1\n",
      "\u001b[2m\u001b[36m(launch_and_fit pid=30381)\u001b[0m [Client 2] get_parameters\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:41:03,218 | server.py:229 | fit_round 1 received 4 results and 0 failures\n",
      "WARNING flwr 2023-05-15 13:41:03,266 | fedavg.py:242 | No fit_metrics_aggregation_fn provided\n",
      "DEBUG flwr 2023-05-15 13:41:03,271 | server.py:165 | evaluate_round 1: strategy sampled 4 clients (out of 4)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30376)\u001b[0m [Client 0] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30379)\u001b[0m [Client 3] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30377)\u001b[0m [Client 1] evaluate, config: {}\n",
      "\u001b[2m\u001b[36m(launch_and_evaluate pid=30381)\u001b[0m [Client 2] evaluate, config: {}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG flwr 2023-05-15 13:41:07,328 | server.py:179 | evaluate_round 1 received 4 results and 0 failures\n",
      "INFO flwr 2023-05-15 13:41:07,330 | server.py:144 | FL finished in 8.034274273999472\n",
      "INFO flwr 2023-05-15 13:41:07,334 | app.py:202 | app_fit: losses_distributed [(1, 0.0024931967994587683)]\n",
      "INFO flwr 2023-05-15 13:41:07,337 | app.py:203 | app_fit: metrics_distributed {'opt_reward': [(1, 1.3980717918111791)], 'reward': [(1, 1.3962205314795586)], 'global_regret': [(1, 0.001851260331620429)], 'local_regrets': [(1, {0: 0.45994342447082626, 1: 0.0021809310033050183, 2: 0.0025360951053947, 3: 0.0024969222640237937})]}\n",
      "INFO flwr 2023-05-15 13:41:07,339 | app.py:204 | app_fit: losses_centralized []\n",
      "INFO flwr 2023-05-15 13:41:07,342 | app.py:205 | app_fit: metrics_centralized {}\n"
     ]
    }
   ],
   "source": [
    "client_0_sample_size_fn = lambda n: int(np.log(n))\n",
    "sample_size_fns = {0: client_0_sample_size_fn,\n",
    "                   1: lambda n: int((n-client_0_sample_size_fn(n))//(NUM_CLIENTS-1)),\n",
    "                   2: lambda n: int((n-client_0_sample_size_fn(n))//(NUM_CLIENTS-1)),\n",
    "                   3: lambda n: int((n-client_0_sample_size_fn(n))//(NUM_CLIENTS-1))}\n",
    "\n",
    "global_regrets_w, global_regrets_std_w, fed_local_regrets_w, fed_local_regrets_std_w = run_federated_training_experiments_v2(data, aux, sample_size_fns, num_iters=5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "b5d3e595-9361-43e4-abc5-9d002edb6468",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "client_id = 2\n",
    "\n",
    "# Apply moving average smoothing\n",
    "window_size = 2\n",
    "local_regrets_smooth = np.convolve(local_regrets[client_id], np.ones(window_size) / window_size, mode='same')\n",
    "local_regrets_std_smooth = np.convolve(local_regrets_std[client_id], np.ones(window_size) / window_size, mode='same')\n",
    "\n",
    "global_regrets_smooth = np.convolve(global_regrets_w, np.ones(window_size) / window_size, mode='same')\n",
    "global_regrets_std_smooth = np.convolve(global_regrets_std_w, np.ones(window_size) / window_size, mode='same')\n",
    "\n",
    "fed_local_regrets_smooth = np.convolve(fed_local_regrets_w[client_id], np.ones(window_size) / window_size, mode='same')\n",
    "# window_size=4\n",
    "fed_local_regrets_std_smooth = np.convolve(fed_local_regrets_std_w[client_id], np.ones(window_size) / window_size, mode='same')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "54c5c95c-69a7-4a09-a7e6-87e44c7c124c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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BaewcOFpLY655JIrWLLkSioqylm3bi2vvfYKn/70Z3LWBre7aeJHONy5df3SgU9RlDYD37ZtduDTNI3x49uu2E2ZMo3vfe9H7N69iy996Qts3rwJwzDQtM6Nmg8G8wA7OPYnEvgcZm9VKBPyTJmlK4QYRBRFwav1fBaoaFt24GurClZUVMT119/ED35g75v717/+X04DX2FhUzduKFTfqXPSgW/UqNEEAi2rgvF4jP377eEA48dP6NRs4gkTJlJcXEJdXS379+9j/PgJnWpLesJIf1qSBSTwOY+S3aUrY/iEEELkTnaX7pQpbS/Jctppn6ag4H9oaKhn48Z/UV5+kFGjRrd77bq6Op566v94++03OXBgH4ZhUFo6nLlz5/OFL1zG2LHjABg5clTmnM7szVtRUU5jo734c9vduds7nNTRmsmTp7Bu3Vp27tze6cAXi9k9cX6/v9Pv4wT9osNww4YNzJgxg7Vr13bq+Gg0ys9//nPOOussTjjhBObPn891113Hhg0bermluWXKThtCCCFypLa2hupqe9xZaelwioqK2jzW5XJx6qkLM5+vWvVqu9d+7713ueKKi3jkkYc5cqSO+fMXMHfuScTjcZ555i/NJjiMHDkqU6Xbu3dPh+3evn1b5nFbEzayx+9NmtS5GbpHjhzJVA6zxwh2pKamGoChQ0s7fY4TOL7Ct2fPHm666SZMs3PVLsuyuOmmm3jrrbf4j//4D6666ipqa2v505/+xBVXXMHDDz/MKaec0sut7j4FUCwLS1Fk4WUhhBA5k96BAtqf1JB2yimfYOXK5wFYs2YVl19+ZavHbd68idtu+yaqqvK97/2Iz3zms5nuTsuyWLPmDY47rmm3C1VVmTHjON5/fx2HDlVRXX243cWXd+zIDnytV++yj+nM1wbw85//D3V1tS3Ob080Gs2ck65Y9heOrvC98sorfOELX+jSTJgXX3yRt956i+uvv557772Xyy+/nJtvvpm//OUv+Hw+7rzzzl5scc8F9Sj/b3c1i6tDsiyLEEKInGk+fm9aO0faFiw4BbfbDcCWLZszla1siUSCH/3ou8Tjcb7//f/mrLMWNxvbpigKCxee1qKauGBBU+Fly5b217NrPkO39TCXXSkcM2Zsu9cDWL16Fa+++ndKS4cDsHPnjg7PgeaVxFxt2XasODbwXXfdddx8880MGzaMc845p9PnvfXWWwBcdtllzZ4fOXIkJ598Mjt27KC2tjanbc2luUd24zctFh6J2suyCCGEEDmQnsUKnQt8gUCQ2bPnAPZ2aG++ubrFMStXPkd5+UFOP/3MZl3AHVm48PTM4/Xr17V7bLpLNy8vr9n4v2zpHUGATAWuLQ0N9dxzz0/weLzcfffPcbvdHDpURUNDxxNIshdbnjfv5A6PdxLHBr5du3Zxyy238PTTTzN+/PhOn7d06VL++te/trpQZE2NvdhkZ6de94VmW6t1shtbCCGE6Eh2l272FmHt+fjHP5l5vHr1qhavv/HG6wCcd94FXWpLWdkYZs6cDcCrr76CruutHhcON1JZae/MMWlS25MxiopKMo+//vUbufbaK9scl3fvvT+jpqaGa6+9nilTpjJunD1ZozPj+N57713Ani08ffqMDo93EseO4Vu5cmW3NmkuLi6muLi4xfPvv/8+//rXv5g+fXqzKeHd4XL1Xk7Orukpau++l2ifpqnNPoq+JffDWTpzP0yzfy1b0V+le1AVBdrqGKqvP0JVVSVgLxzcVqXsaJ/4xCf55S/vAexKXDjcmFmHDpqqb93p3rzwwovZtGkDR47U8e67b3HqqZ9qccyOHTsyvV3tzb5dsuSr1NXVZLp2VVVtdZ/et95aw9/+9hInnDCLSy/9ImCP+duxYxs7dmxn7tyT2nyPhoYGPvjgfQAWLz63zeM6cz+yaZpyTH7XOzbwdSfstaWqqopbb70VgK997Ws9upaqKhQXd25l8O7IHvvg8Wm9+l6icwoK+tfU+4FO7oeztHc/YjGN6mr1mP1CG+zaC99DhpTw7rvru3zNcePGtnteQ0M9qqoSDAa6/MfYokWf4aGH7qeiopyXXnqB0047vcUx8+bN7VS7TzxxNn/845PtHhMKhfjZz36M1+vj//2/H+Lx2BFo2rRpvPTSC+zatb3df6dvvPEPkskkgUCQiy++pMN/0x3972GaCqqqUlgYwOfztXtsLjg28OXKgQMHuPrqqzl48CDXXHMNZ555Zo+uZ5oWDQ2RHLWuletn/TkQjsSpq+vcKuQi9zRNpaDAT0NDFMOQ7vW+JvfDWTpzPxKJOKZpYhgWui73rLcoin0/DMPsVEUpl4LBPEKhBnbv3tPpdeyaqFx99XX893//gNWrV7F16zYmTZrcK+0E+PnPf8bhw4f52te+wahRYzL/JidOtCuH27dvb/ff6V//+hcALrroEoLB/DaP7ez9MAwL0zSpr48QjRpd+loKCvxdDtgDOvBt3LiRG2+8kcOHD3P11VezdOnSnFy3V39wZfWAGKYhPyQdwDBMuQ8OIvfDWdq7H4YhE8+OhXSo6It5fvPmzWfVqle5//57+cEPfkwgEMi8VlVVyb59e5g//2Ntnn/WWYt54ok/smPHNlaseJAf//invdLOd955i5Urn2fWrBO5+OLmkzrTE1h2797V5hZr69atZceObQQCQS699Ip236ur9+NY/UE0YGvs//jHP7jyyiuprq5m6dKlLFu2rK+b1CnZ/z5kazUhhBBOdt11N1JQUMjbb7/JF77wOb71rf/ku99dype/fDkXX3wemzZtbPd8VVX55jeXoSgKq1e/3mzpmFwJhxv56U9/jM/n4zvf+X5ma7S0/Px8RowYSSIRZ//+fa1e47e/fRCAa6+9gYKCns0D6CsDssL3t7/9jW984xtomsYvfvEL/uM//qOvm9QtlimBTwghhHONHTuO3/72cR59dAXr1q3ln/98D5/PR2npcC644CLOOmtxh9eYOXM2a9a0vzRLT9x33y84dKiKr3/9W5SVjWn1mClTplJZWcGOHdtadE2vWbOKTZs2Mm/efC6++NJea2dvG3CB76OPPuLWW2/F5XLx8MMPs2DBgr5uUreZspeuEEIIhxsxYiTLln23r5vRpmXLvtth+37yk3tafT4ej/PLX/6cYDDIbbd9v9nEyv6mXwe+/fv3s379esaOHcucOfbikD/96U+Jx+OcdtppVFZW8uyzz7Y4b9GiRc3GGTiJlfVvSQKfEEII0Xe8Xi9PPtkyR/RH/TrwrVu3jttuu40LLriAOXPmoOs6a9euBWDVqlWsWrWq1fNeffVV5wa+rMeG7LQhhBBCiBzoF4Hva1/7Wqvr51144YVceOGFmc9dLhebN7e/J1//IhU+IYQQQvTcgJ2l219l1/R02VpNCCGEEDkggc9pmq3DJ4FPCCGEED0ngc9xmmp8lkzaEEIIIUQOSOBzMEPW4RNCCCFEDkjgc5jms3S7treeEEIIIURrJPA5mIzhE0IIIUQuSOBzGCtrFW/DkAqfEEIIIXpOAp/DWFmdurqh92FLhBBCCDFQSOBzmOzNNUxTKnxCCCGE6DkJfA6TvZeuJWP4hBBCCJEDEvicJrvCJ126QgghhMgBCXwOkz2Gz5RJG0IIIYTIAQl8DpO9Dp8p6/AJIYQQIgck8DmYJZM2hBBCCJEDEvgcJ6tLVyZtCCGEECIHJPA5jJK1LotU+IQQQgiRC66+boA4WnbgkwqfEEII0R7Lsvjzn/9AJBJm8uSpfOpTp/d1kxxJAp/DZFf4ZOFlIYQQon1PPfUkv/71LwDweDz89rd/YPz4CX3bKAeSLl0nkwqfEEII0aaKinJ+85v7ADjxxLkkEgl+/OMfyl70rZDA5zCKdOkKIYQQHbIsi7vuuoNoNMKll36R5cvvY+rU6Xz44Wb+/OfH+7p5jiOBz2GaTdqQdfiEEEKIVj3zzF95//11HH/8TG644WY8Hg933HEXwWCQFSseYu/ePX3dREeRwOdgUuETQgghWqqsrOD++39JQUEhP/zhT3C57CkJo0eXsWzZ90gk4tK1exSZtOEwSvPNdPuuIUIIIcQxsmnTBm688VoURWHFiseZMmVqu8ePGDGSV15Z3eprZ5xxJmec8c+ctu/tt99k6dKv43a7efTRPzN27LicXv9YkMDnMM1m6SIVPiGEELlnWRaf/ezpNDY2tvq6x+OluLiY6dNn8JnPLO7VpU4Mw+Cee+7GsizOOmtxh2GvL3z846dy4olz+de/1vOLX/yU5cvv6+smdZl06TqYYlodHySEEEJ00cGDB9oMewCJRJyqqkreeON1br/9Vm699b+Ix2O90paXX36RHTu2oaoqV155da+8Ry58+cvXAvDee++ybt3aPm5N10mFz2GazdKVSRtCCCF6wdatH2Uez5kzj4svvizzuWHoVFZWsnr162zatAGAd955i3vvvYelS2/PaTt0XeeRRx4GYOHC0xzdVXrSSSczbdoMtm79Nw8//ADz5y/o6yZ1iVT4HCa7S1fW4RNCCNEbtm79d+bxxz72cRYuPC3z3+mnn8lll32RBx5YwUUXXZI57sUXn6OhoSGn7Xj11b9TWVkBwPnnX5TTa/eGz33uQgA+/HAzGzZ80Met6RoJfI6TXeGTwCeEECL3tm1rqvBNmzajzeOuv/5mVNWOCoZhNAuKufDUU08CUFo6nHnz5uf02r3hzDM/g8fjAeCpp/6vj1vTNf2iS3fDhg1ceuml/O53v2PBgs6VUJ9++mkeffRR9uzZQ15eHosWLeLrX/86hYWFvdzanlGyh+1J4BNCCNELtm/fmnk8der0No/z+/0MG1ZKVVUlAJFIOGdt2LdvD1u2bAJg4cLTURSlzWNXrXqV7353Wbffa+HC0/nxj3/a7fPTAoEg8+cv4K231rBmzWoaGxvJy8vr8XWPBcdX+Pbs2cNNN92E2YXuzQcffJBvf/vbFBUVceutt3Luuefy5JNPcuWVVxKL9c6g01xptiyLBD4hhBA5VlFRTn19PQCjRo2moKCgzWMNwyAUCmU+HzJkaM7a8cYbr2cez5kzt91jN278V4/ea+bM2T06P9ucOfMAe2LLu+++lbPr9jZHV/heeeUVbr/99sw/zM6orKzkV7/6FQsXLuTBBx/MlKKPP/54vvnNb/L73/+eJUuW9FaTe6zZ3zcyhk8IIUSOdbY7F2Dt2ncyVb28vPx2q4Fd9d5772YeH3/8zHaPPeOMRZx44jz++MfH2Lx5IwBLl95OUVFxi2MffXRFpuv5O9/5Pnl5+Rx//Ak5a3d2W9eufYczzzwrZ9fuTY4NfNdddx1vvPEGkydP5pOf/CQvvPBCp857/vnnSSaTfPnLX86EPYBzzjmH5cuX89RTTzk88GVX+GRZFiGEELmVPUN32rS2A1xlZQX33HNX5vNLL70iM36tp0zT5KOPPgTs8XtDhw5r9/gTTpgFwMMP3w+Az+fjnHM+1+z3fNqvfrUcgPz8AhYvPjcn7c02bdoM3G43yWQy0yXdHzg28O3atYtbbrmFr3zlKzz44IOdPm/DBnsK+ezZLcu3M2fO5OWXXyYUCpGfn5+ztuaSjOETQgxWlmWBnujrZhx7Lk+749dyrb3Al0gkqKgoZ/XqVfzxj48RCtmzcufPX8AXv/jlnLWhvPwg0WgUgHHjxnfqnHg8zr59ewGYOHFyq2EvFApRUVEOwOTJU3LT2KN4PB5GjhzFvn172b9/H/F4HK/X2yvvlUuODXwrV67s1l8SlZWVFBQUtDqIcsSIEQAcPHiQ6dO7X5Z2uXpv6GOzCh9Wr76XaJ+mqc0+ir4l98NZOnM/TLPzIcayLCLP/Tdm1Y4et62/0YZPwX/ed7od+tKnKUrnOoayJ2x84xs3t3usx+Phwgu/wHXX3ZjZrzYX0qEMaHcMYbbdu3dl9sZtK8xlf22TJ/fejh3pCaCWZVFVVdls/cCu3g9NU47J73rHBr7ulo1DoRCBQKDV13w+HwCRSKTb7VJVheLiYLfP74jS7LHVq+8lOqegwN/XTRBZ5H44S3v3IxbTqK5WO/ULzbKsY1rlchTFLiT09OvvzB9Dhw5VUVtb06nrHXfc8fz4x//DiBEjOzx23759fOEL5+P1+pg2bTq33fZdJkyY2Obx4XDTRJDCwqJOBZ5du7ZnHk+dOq3Vc7ID37RpU9u8blfbe7SCgqYVPyKRUKvv09H9ME0FVVUpLAxk8klvcmzg6wmrg0itaVq3r22aFg0N3Q+MHcpqu2Ua1NXlbgq86BpNUyko8NPQEMUwpHu9r8n9cJbO3I9EIo5pmhiGha53fM/8535n0HbpGoYFdG/ctqLY98MwzA4rSh9++GHm8bx58/n855sWVg6HG9m3by/PP/80R44c4cMPt/Df//0jli+/r8MwGg6HOeusxXzwwfts3PgvfvrTu/jlL3/T5vGxWDzz2O8PdOrfx7ZtTWFu4sTJrZ6T3V09ceKUNq/b1fYeLRBoKsZEIrFm79PZ+2EYFqZpUl8fIRrt2s5aBQX+Lvd2DLjAFwwGqaura/W19HiBnq6Z05l/mN3VrMJnde6HpOhdhmHKfXAQuR/O0t79sENM5ymKAm7nj4VymnSo6Ez3YXYgWrDgFBYuPK3FMZdccgVLllxJRUU569at5bXXXuHTn/5Mu9edMmUa3/vej9i9exdf+tIX2Lx5E4ZhtFlgcbubevHC4c4VNnbssCt8iqK02aWbDoWapjF+fNsVu66292jZbfZ4mv+b7cr9ADr9B1FPDbjBMGVlZdTX17fabVtZWYmqqgwfPrwPWtY5sg6fEEKI3pId+KZMaX2MW1FREddff1Pm87/+tfM7SkyYMJHi4hISiTj79+9r87jsTRBCoc4tvZYOfKNGjW5WYUuLx2Ps329P6hg/fkKnhoZ1tr1Hy25zZ8cg9rUBF/hmzbKnbm/cuLHFa5s2bWLKlCmOXhU7O/ApsiyLEEKIHMpeg2/KlLYnL5522qcz49Q2bvwX5eUHO/0e6erbzp3b2zxm5MhRmced2Z+3oqKcxsZQs+sfbfv27R1O6uhue4+WXh9YUZROjXF0ggEX+D772c/idrv53//932Zj+V544QXKy8u58MIL+7B1HTt6WZbBOoZZCCFEbtXW1lBdfRiw174rKipq81iXy8Wppy7MfL5q1audeo8jR45kKnHpj60ZOXJUpkq3d++eDq+7ffu2zOO2Zt9mT9iYNKlzM3Q7295s6aVrAMaOHZeztQl7W78OfPv37+fZZ5/lgw8+yDw3evRobrjhBtasWcPVV1/N//3f/3H33Xfz7W9/m5kzZ3LppZf2YYs7dvQYPiGEECIX0rtPQNvdudlOOeUTmcdr1qzq1Hv8/Of/Q11dLQA7dmxr8zhVVZkx4zjAnjmcDqJtyb5WW9W77GM68/V1pb3Ztm37iGQyCXS8Q4iT9OvAt27dOpYuXcoTTzzR7Pmbb76ZH/zgBxw6dIgf/ehHvPTSS1xyySWsWLHimEx97omj1+ETQgghcqH5+L1pHR6/YMEpuN1uALZs2UxNTXW7x69evYpXX/07paX2OPmdO9tfU3HBglMyj7ds2dzusdnVt7YqfNmVwjFjxrZ7Peh6e9PSW7sBnHzyxzp1jhP0i8D3ta99ja1bt7JgwYJmz1944YVs3bqVu+66q8U5l112GS+++CKbN29m1apVfO9732s2SNSpjq7wSZeuEEKIXMhe1qQzgS8QCDJ79hzA3grtzTdXt3lsQ0M999zzEzweL3ff/XPcbjeHDlXR0ND2hIyFC0/PPF6/fl27bUl36ebl5TUb/5ctvSsIkKna5bK9aRs22L2KHo+Xj33sEx0c7Rw9Cnz33Xcf//jHPzo87sknn+S2227ryVsNGtnduIrM0hVCCJEj2V26U6d2HPgAPv7xT2Yer169qs3j7r33Z9TU1HDttdczZcpUxo2bALQ/Lq6sbAwzZ9rboL766ivout7qceFwI5WV9pi5SZPanoxRVFSSefz1r9/Itdde2eb7d6e9YG/csHbtuwB88pMLHT0J9Gg9Dnx///vfOzzujTfeYOXKlT15q0GjWUFPxvAJIYTIgfr6I1RVVQKQl5ffZpXsaJ/4RFPgW79+HeFwY4tj3nprDX/720uccMIsLr30i0DTGLqOAtSFF14MwJEjdbz77lutHrNjx47MJMz2Zt8uWfJVJk6clFlLT1XVVvfp7Ul7X3vt7yQS9qLRF1xwcbvHOk2XFl5+6KGHMosXp3300Ufce++9bZ4TCoVYs2YNwaBsEdYZR2+tJoQQQvRUYWERb775zy6fN3p0WbvnhUIhfvrTH+P1evnOd76Pqtp1pClTpvLSSx1PhDj99DN56KH7qagoZ+XKFzj11E+1OGb27BM71fYTTpjJY4890e4xPW3vs88+BcCMGcdz4olzO2yTk3Qp8CWTSR544AEURcnse7h9+3a2bet4Zsvll1/e7UYOJs1n5lrYEVCCnxBCCOf51a+WU119mK997RuMHTsu83x6YkVHEyFcLhdXX30d//3fP2DNmlXs3LmDSZMmO7K969f/k3//296a7rrrvtprbewtXQp8S5YsAey9ai3L4te//jXTpk1j0aJFbZ7j9XoZP348Z555Zs9aOkjIsixCCCH6g3feeYuVK59n1qwTufjiy5q9lp4Usnv3rg63LDvrrMU88cQf2bFjGytWPMiPf/xTR7b3d7/7X8CemTt/fv+ZnZvWpcDn8Xi46aam7VaefvppTjnlFG6++eacN2ywkp02hBBCOF043MhPf/pjfD5fs67RtPz8fEaMGEllZQX79+9j/PgJbV5LVVW++c1l3Hjjtaxe/Tpbt37EtGlt7wLSF+195503Wb/+n7jdbr7+9Vtz2rZjpUuB72ivvfZartohUmQMnxBCCKe7775fcOhQFV//+rcoKxvT6jFTpkylsrKCHTu2tRv4AGbOnM2aNe0vzdITPW3vKaec2q0xkE6iWFbPy0h1dXX85S9/4b333qOyspJTTz2VZcuW8Zvf/IapU6dyxhln5KKtjmAYJrW14V67/r9/t4SyhL2C9+qioZx76T2YpgS/vuByqRQXB6mrC6PrskROX5P74SyduR/JZIKamgqGDBmJ290/tp/qr1wuVb4vHKQz96Mn3x8lJUE0rWsLrfSowgewZs0avvWtb9HQ0JCZyDFjxgwAXn75Ze69916uuuoqvv3tb/f0rQaF5l268s0rhBBCiJ7r0Tp827dv5+abbyYSiXD55Zfz4IMPkl0wvPjii8nPz+fRRx+V7t9OUo56rMhWG0IIIYTooR5V+B544AESiQQPPPAAp512WovXr7jiCmbOnMkll1zC448/PqC6dnuLzNIVQgghRK71qMK3du1aZs2a1WrYS5s1axZz585l+/b2V68WNiUr48mkDSGEEELkQo8CX0NDA8OHD+/wuKKiIurrO96QWMiyLEIIIYTIvR4FvtLSUrZu3drhcVu3bqW0tLQnbzVoZN8QqfAJIYQQIhd6FPg+9alPsW/fPn73u9+1eczvfvc7Dhw4wCc/+ck2jxFNZB0+IYQQQuRajyZt3HDDDbz00kvcfffdrF27lo99zN5q5NChQ/zlL39h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",
      "text/plain": [
       "<Figure size 707.107x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = ss_range\n",
    "\n",
    "c=5\n",
    "plt.rcParams['figure.figsize'] = [c*np.sqrt(2), c*1]\n",
    "\n",
    "sns.set_theme()\n",
    "cp = sns.color_palette()\n",
    "custom_color_order = [cp[0], cp[2], cp[1]]\n",
    "sns.set_palette(custom_color_order)\n",
    "\n",
    "plt.plot(x, local_regrets_smooth, label=r'$R_c(\\hat{\\pi}_c$)')\n",
    "plt.fill_between(x, local_regrets_smooth - local_regrets_std_smooth, local_regrets_smooth + local_regrets_std_smooth, alpha=0.2)\n",
    "\n",
    "plt.plot(x, fed_local_regrets_smooth, label=r'$R_c(\\hat{\\pi}_\\lambda$)')\n",
    "plt.fill_between(x, np.clip(fed_local_regrets_smooth - fed_local_regrets_std_smooth, 0, None), fed_local_regrets_smooth + fed_local_regrets_std_smooth, alpha=0.2)\n",
    "\n",
    "plt.plot(x, global_regrets_smooth, label=r'$R_\\lambda(\\hat{\\pi}_\\lambda)$')\n",
    "plt.fill_between(x, global_regrets_smooth - global_regrets_std_smooth, global_regrets_smooth + global_regrets_std_smooth, alpha=0.2)\n",
    "\n",
    "plt.xlabel('Total Sample Size', fontsize=16)\n",
    "plt.ylabel('Regret', fontsize=16)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "# plt.title(r'Heterogeneous Clients, Empirical Mixture $\\lambda=\\bar{n}$', loc=\"left\")\n",
    "plt.legend(fontsize=22)\n",
    "# plt.show()\n",
    "\n",
    "# plt.savefig('./data/heterogeneous-client2-exp2_real.png', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3dbd19ae-3ce1-40d1-a9a1-63ea0423e59f",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
