{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# %%\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "from munch import Munch\n",
    "import torch\n",
    "from torch import nn, softmax\n",
    "from torch.utils.data import DataLoader, ConcatDataset\n",
    "\n",
    "from fedlab.utils import functional as F\n",
    "from fedlab.utils.aggregator import Aggregators\n",
    "from fedlab.utils.serialization import SerializationTool\n",
    "from fedlab.utils.functional import evaluate, get_best_gpu\n",
    "\n",
    "from fedlab.contrib.algorithm.basic_server import SyncServerHandler\n",
    "from fedlab.contrib.algorithm.basic_client import SGDSerialClientTrainer\n",
    "\n",
    "from fedlab.utils.functional import evaluate, setup_seed\n",
    "from fedlab.contrib.algorithm.basic_server import SyncServerHandler\n",
    "\n",
    "from synthetic_dataset import SyntheticDataset\n",
    "\n",
    "from sampler import KVibSampler, UniformSampler\n",
    "from model import LinearReg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def solver(weights, k, n):\n",
    "    norms = np.sqrt(weights)\n",
    "    idx = np.argsort(norms)\n",
    "    probs = np.zeros(len(norms))\n",
    "    l = 0\n",
    "    for l, id in enumerate(idx):\n",
    "        l = l + 1\n",
    "        if k + l - n > sum(norms[idx[0:l]]) / norms[id]:\n",
    "            l -= 1\n",
    "            break\n",
    "\n",
    "    m = sum(norms[idx[0:l]])\n",
    "    for i in range(len(idx)):\n",
    "        if i <= l:\n",
    "            probs[idx[i]] = (k + l - n) * norms[idx[i]] / m\n",
    "        else:\n",
    "            probs[idx[i]] = 1\n",
    "    return np.array(probs)\n",
    "\n",
    "class SamplerServer(SyncServerHandler):\n",
    "    def setup_optim(self, sampler, weights):\n",
    "        self.n = self.num_clients\n",
    "        self.num_to_sample = int(self.sample_ratio * self.n)\n",
    "        self.round_clients = int(self.sample_ratio * self.n)\n",
    "        self.sampler = sampler\n",
    "        self.weights = weights\n",
    "\n",
    "    @property\n",
    "    def num_clients_per_round(self):\n",
    "        return self.round_clients\n",
    "\n",
    "    def sample_clients(self, random=False):\n",
    "        clients = self.sampler.sample(self.num_to_sample)\n",
    "        self.round_clients = len(clients)\n",
    "        assert self.num_clients_per_round == len(clients)\n",
    "        return clients\n",
    "\n",
    "    def global_update(self, buffer):\n",
    "        gradient_list = [torch.sub(self.model_parameters, ele[0]) for ele in buffer]\n",
    "        norms = np.array([torch.norm(grad, p=2, dim=0).item() for grad in gradient_list])\n",
    "        \n",
    "        if self.sampler.name in ['uniform']:\n",
    "            indices, _ = self.sampler.last_sampled\n",
    "            weights = self.weights[indices]\n",
    "        elif self.sampler.name in ['kvib']:\n",
    "            indices, probs = self.sampler.last_sampled\n",
    "            weights = self.weights[indices]\n",
    "            self.sampler.update(weights * norms)\n",
    "        else:\n",
    "            assert False\n",
    "\n",
    "        if self.sampler.name in [\"uniform\"]:\n",
    "            estimates = Aggregators.fedavg_aggregate(gradient_list, weights) # fedavg\n",
    "        elif self.sampler.name in [\"kvib\"]:\n",
    "            ws = weights / probs\n",
    "            estimates = sum([w * grad for grad, w in zip(gradient_list, ws)])\n",
    "        else:\n",
    "            assert False\n",
    "\n",
    "        serialized_parameters = self.model_parameters - estimates\n",
    "        SerializationTool.deserialize_model(self._model, serialized_parameters)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# K-Vib sampler on Synthetic dataset\n",
    "\n",
    "config = {\n",
    "    \"num_clients\": 100,\n",
    "    \"com_round\": 500,\n",
    "    \"sample_ratio\": 0.1,\n",
    "    \"theta\": 0.3,\n",
    "    \"reg\": 0.001,\n",
    "    \"batch_size\": 64,\n",
    "    \"epochs\": 1,\n",
    "    \"lr\": 0.01,\n",
    "    \"alpha\": 0.1,\n",
    "    \"preprocess\": 1,\n",
    "    \"seed\": 42,\n",
    "    \"sampler\": \"kvib\",\n",
    "    \"dataset\": \"synthetic\",\n",
    "    \"solver\": \"fedavg\",\n",
    "    \"k\": 10\n",
    "}\n",
    "\n",
    "args = Munch(config)\n",
    "\n",
    "model = LinearReg(60, 10)\n",
    "synthetic_path = \"./synthetic/data_num{}\".format(args.num_clients)\n",
    "dataset = SyntheticDataset(synthetic_path, synthetic_path + \"/feddata/\", True)\n",
    "\n",
    "test_data = ConcatDataset([dataset.get_dataset(i, \"test\") for i in range(args.num_clients)])\n",
    "test_loader = DataLoader(test_data, batch_size=1024)\n",
    "\n",
    "\n",
    "trainer = SGDSerialClientTrainer(model, args.num_clients, cuda=True)\n",
    "trainer.setup_optim(args.epochs, args.batch_size, args.lr)\n",
    "trainer.setup_dataset(dataset)\n",
    "\n",
    "# server-sampler\n",
    "sampler = KVibSampler(args.num_clients, args.k, args.reg, args.com_round)\n",
    "handler = SamplerServer(model=model,\n",
    "                        global_round=args.com_round,\n",
    "                        sample_ratio=args.sample_ratio)\n",
    "    \n",
    "handler.num_clients = trainer.num_clients\n",
    "weights = np.array([len(dataset.get_dataset(i)) for i in range(args.num_clients)]) # fedavg lambda  \n",
    "weights = weights/weights.sum()\n",
    "handler.setup_optim(sampler, weights)\n",
    "\n",
    "variances_kvib = []\n",
    "regrets_kvib = []\n",
    "losses_kvib = []\n",
    "\n",
    "# regret\n",
    "dyrgt = 0\n",
    "t = 0\n",
    "while handler.if_stop is False:\n",
    "    print(\"Running Communication Round {}/{}\".format(t, args.com_round))\n",
    "    # server side\n",
    "    all_clients = np.arange(args.num_clients)\n",
    "\n",
    "    broadcast = handler.downlink_package\n",
    "\n",
    "    # client side\n",
    "    trainer.local_process(broadcast, all_clients)\n",
    "    full_info = trainer.uplink_package\n",
    "    \n",
    "    grad_list = [torch.sub(handler.model_parameters, ele[0]) for ele in full_info]\n",
    "    norms = np.array([torch.norm(grad, p=2, dim=0).item() for grad in grad_list])*weights\n",
    "\n",
    "    sampled_clients = handler.sample_clients()\n",
    "    uploads = [full_info[i] for i in sampled_clients]\n",
    "    \n",
    "    indices, p = handler.sampler.last_sampled\n",
    "    full_gradient = Aggregators.fedavg_aggregate(grad_list, weights)\n",
    "\n",
    "    print(\"sampled {}\".format(str(indices)))\n",
    "\n",
    "    # sampling variance\n",
    "    part_grads = [grad_list[i] for i in indices]\n",
    "    part_weights = weights[indices]/p\n",
    "    estimates = sum([w*grad for grad, w in zip(part_grads, part_weights)])\n",
    "\n",
    "    if args.sampler in [\"uniform\"]:\n",
    "        estimates = estimates/len(part_weights)\n",
    "\n",
    "    # variance\n",
    "    vt = np.abs(torch.norm(estimates, p=2, dim=0) - torch.norm(full_gradient, p=2, dim=0))\n",
    "\n",
    "    # regret \n",
    "    # print(p)\n",
    "    if args.sampler in [\"uniform\"]:\n",
    "        optimal_p = np.sqrt(norms)/np.sqrt(norms).sum()\n",
    "        optimal = (norms/optimal_p).sum()/len(norms)\n",
    "        sampler_values = (norms[indices]/p).sum()/len(indices)\n",
    "    else:\n",
    "        ### optimal independent k\n",
    "        optimal_p = solver(norms, args.k, args.num_clients)\n",
    "        optimal = (norms/optimal_p).sum()\n",
    "        sampler_values = (norms[indices]/p).sum()\n",
    "    \n",
    "    dyrgt += np.abs(sampler_values - optimal)/optimal\n",
    "    \n",
    "    for pack in uploads:\n",
    "        handler.load(pack)\n",
    "\n",
    "    t += 1\n",
    "    tloss, _ = evaluate(handler._model, nn.CrossEntropyLoss(), test_loader)\n",
    "\n",
    "    variances_kvib.append(vt)\n",
    "    regrets_kvib.append(dyrgt)\n",
    "    losses_kvib.append(tloss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Uniform sampler on Synthetic dataset\n",
    "\n",
    "config = {\n",
    "    \"num_clients\": 100,\n",
    "    \"com_round\": 500,\n",
    "    \"sample_ratio\": 0.1,\n",
    "    \"batch_size\": 64,\n",
    "    \"epochs\": 1,\n",
    "    \"lr\": 0.01,\n",
    "    \"preprocess\": 1,\n",
    "    \"seed\": 42,\n",
    "    \"sampler\": \"uniform\",\n",
    "    \"dataset\": \"synthetic\",\n",
    "    \"solver\": \"fedavg\",\n",
    "    \"k\": 10\n",
    "}\n",
    "\n",
    "args = Munch(config)\n",
    "\n",
    "model = LinearReg(60, 10)\n",
    "synthetic_path = \"./synthetic/data_num{}\".format(args.num_clients)\n",
    "dataset = SyntheticDataset(synthetic_path, synthetic_path + \"/feddata/\", True)\n",
    "\n",
    "test_data = ConcatDataset([dataset.get_dataset(i, \"test\") for i in range(args.num_clients)])\n",
    "test_loader = DataLoader(test_data, batch_size=1024)\n",
    "\n",
    "probs = np.ones(args.num_clients)/args.num_clients\n",
    "sampler = UniformSampler(args.num_clients, probs)\n",
    "trainer = SGDSerialClientTrainer(model, args.num_clients, cuda=True)\n",
    "trainer.setup_optim(args.epochs, args.batch_size, args.lr)\n",
    "trainer.setup_dataset(dataset)\n",
    "\n",
    "# server-sampler\n",
    "handler = SamplerServer(model=model,\n",
    "                        global_round=args.com_round,\n",
    "                        sample_ratio=args.sample_ratio)\n",
    "    \n",
    "handler.num_clients = trainer.num_clients\n",
    "weights = np.array([len(dataset.get_dataset(i)) for i in range(args.num_clients)]) # fedavg lambda  \n",
    "weights = weights/weights.sum()\n",
    "handler.setup_optim(sampler, weights)\n",
    "\n",
    "variances_uni = []\n",
    "regrets_uni = []\n",
    "losses_uni = []\n",
    "\n",
    "# regret\n",
    "dyrgt = 0\n",
    "t = 0\n",
    "while handler.if_stop is False:\n",
    "    print(\"Running Communication Round {}/{}\".format(t, args.com_round))\n",
    "    # server side\n",
    "    all_clients = np.arange(args.num_clients)\n",
    "\n",
    "    broadcast = handler.downlink_package\n",
    "\n",
    "    # client side\n",
    "    trainer.local_process(broadcast, all_clients)\n",
    "    full_info = trainer.uplink_package\n",
    "    \n",
    "    grad_list = [torch.sub(handler.model_parameters, ele[0]) for ele in full_info]\n",
    "    norms = np.array([torch.norm(grad, p=2, dim=0).item() for grad in grad_list])*weights\n",
    "\n",
    "    sampled_clients = handler.sample_clients()\n",
    "    uploads = [full_info[i] for i in sampled_clients]\n",
    "    \n",
    "    indices, p = handler.sampler.last_sampled\n",
    "    full_gradient = Aggregators.fedavg_aggregate(grad_list, weights)\n",
    "\n",
    "    print(\"sampled {}\".format(str(indices)))\n",
    "\n",
    "    # sampling variance\n",
    "    part_grads = [grad_list[i] for i in indices]\n",
    "    part_weights = weights[indices]/p\n",
    "    estimates = sum([w*grad for grad, w in zip(part_grads, part_weights)])\n",
    "\n",
    "    if args.sampler in [\"uniform\"]:\n",
    "        estimates = estimates/len(part_weights)\n",
    "\n",
    "    # variance\n",
    "    vt = np.abs(torch.norm(estimates, p=2, dim=0) - torch.norm(full_gradient, p=2, dim=0))\n",
    "\n",
    "    # regret \n",
    "    if args.sampler in [\"uniform\"]:\n",
    "        optimal_p = np.sqrt(norms)/np.sqrt(norms).sum()\n",
    "        optimal = (norms/optimal_p).sum()/len(norms)\n",
    "        sampler_values = (norms[indices]/p).sum()/len(indices)\n",
    "    else:\n",
    "        ### optimal independent k\n",
    "        optimal_p = solver(norms, args.k, args.num_clients)\n",
    "        optimal = (norms/optimal_p).sum()\n",
    "        sampler_values = (norms[indices]/p).sum()\n",
    "    \n",
    "    dyrgt += np.abs(sampler_values - optimal)/optimal\n",
    "    \n",
    "    for pack in uploads:\n",
    "        handler.load(pack)\n",
    "\n",
    "    t += 1\n",
    "    tloss, _ = evaluate(handler._model, nn.CrossEntropyLoss(), test_loader)\n",
    "\n",
    "    variances_uni.append(vt)\n",
    "    regrets_uni.append(dyrgt)\n",
    "    losses_uni.append(tloss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 984x336 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(12.3, 4.2), dpi=80)\n",
    "ax = plt.subplot(1, 3, 1)\n",
    "ax.set_xlabel(\"Communication Round\", fontsize=12)\n",
    "ax.set_ylabel(r\"Dynamic Regret\", fontsize=12)\n",
    "ax.set_title(\"Synthetic, K=10\", fontsize=12)\n",
    "ax.grid()\n",
    "ax.plot(np.arange(len(regrets_kvib)), regrets_kvib, label=\"K-Vib\")\n",
    "ax.plot(np.arange(len(regrets_uni)), regrets_uni, label=\"Uniform\")\n",
    "ax.legend()\n",
    "\n",
    "ax2 = plt.subplot(1, 3, 2)\n",
    "ax2.set_ylim(0, 0.3)\n",
    "ax2.set_xlabel(\"Communication Round\", fontsize=12)\n",
    "ax2.set_ylabel(\"Variance\", fontsize=12)\n",
    "ax2.set_title(\"Synthetic, K=10\", fontsize=12)\n",
    "ax2.grid()\n",
    "ax2.plot(np.arange(len(variances_kvib)), variances_kvib, label=\"K-Vib\")\n",
    "ax2.plot(np.arange(len(variances_uni)), variances_uni, label=\"Uniform\")\n",
    "ax2.legend()\n",
    "\n",
    "ax3 = plt.subplot(1, 3, 3)\n",
    "ax3.set_xlabel(\"Communication Round\", fontsize=12)\n",
    "ax3.set_ylabel(\"Test Loss\", fontsize=12)\n",
    "ax3.set_title(\"Synthetic, K=10\", fontsize=12)\n",
    "ax3.grid()\n",
    "ax3.plot(np.arange(len(losses_kvib)), losses_kvib, label=\"K-Vib\")\n",
    "ax3.plot(np.arange(len(losses_uni)), losses_uni, label=\"Uniform\")\n",
    "ax3.legend()\n",
    "plt.tight_layout()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fedlab13",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.0"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
