{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "En3ngOY0qLmR",
        "outputId": "9b0942eb-6b0a-4811-fdfe-45c2bc1033e8"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Using gymnasium, Torch 2.8.0+cu126, Device cpu\n"
          ]
        }
      ],
      "source": [
        "import math, random, time, os, glob\n",
        "import numpy as np\n",
        "import torch, torch.nn as nn, torch.nn.functional as F\n",
        "import gymnasium as gym\n",
        "from gymnasium.wrappers import TimeLimit\n",
        "import matplotlib.pyplot as plt\n",
        "import concurrent.futures\n",
        "\n",
        "if torch.backends.mps.is_available():\n",
        "    device = torch.device(\"mps\")\n",
        "elif torch.cuda.is_available():\n",
        "    device = torch.device(\"cuda\")\n",
        "else:\n",
        "    device = torch.device(\"cpu\")\n",
        "print(f\"Using gymnasium, Torch {torch.__version__}, Device {device}\")\n",
        "\n",
        "SEED = 42\n",
        "np.random.seed(SEED); random.seed(SEED); torch.manual_seed(SEED)\n",
        "DEG = math.pi / 180.0\n",
        "OBS_DIM = gym.make(\"CartPole-v1\").observation_space.shape[0]\n",
        "ACT_DIM = gym.make(\"CartPole-v1\").action_space.n\n",
        "\n",
        "\n",
        "# ---------------- Constrained Cartpole ----------------\n",
        "\n",
        "class CartPoleConstrained(gym.Env):\n",
        "    FORBIDDEN = [(-2.4,-2.2), (-1.3,-1.1), (-0.1,0.1), (1.1,1.3), (2.2,2.4)]\n",
        "    ANGLE_LIMIT = 6 * DEG\n",
        "\n",
        "    def __init__(self, render_mode=None):\n",
        "        self.render_mode = render_mode\n",
        "        try:\n",
        "            self.env = gym.make(\"CartPole-v1\", render_mode=render_mode)\n",
        "        except TypeError:\n",
        "            self.env = gym.make(\"CartPole-v1\")\n",
        "        inner = self.env.env if hasattr(self.env, \"env\") else self.env\n",
        "        self.env = TimeLimit(inner, max_episode_steps=200)\n",
        "        self.observation_space = self.env.observation_space\n",
        "        self.action_space      = self.env.action_space\n",
        "\n",
        "    def reset(self, **kw):\n",
        "        return self.env.reset(seed=kw.get(\"seed\", None))\n",
        "\n",
        "    def step(self, a):\n",
        "        obs, r, term, trunc, info = self.env.step(int(a))\n",
        "        x, xdot, th, thdot = obs\n",
        "        info = dict(info) if info else {}\n",
        "        info[\"costs\"] = float(any(l <= x <= r for (l, r) in self.FORBIDDEN) or abs(th) > self.ANGLE_LIMIT)\n",
        "        return obs, float(r), bool(term), bool(trunc), info\n",
        "\n",
        "    def render(self):\n",
        "        return self.env.render()\n",
        "\n",
        "    def close(self):\n",
        "        self.env.close()\n",
        "\n",
        "def make_env(seed=None, render_mode=None):\n",
        "    env = CartPoleConstrained(render_mode=render_mode)\n",
        "    if seed is not None:\n",
        "        try: env.reset(seed=seed)\n",
        "        except: env.reset()\n",
        "    return env\n",
        "\n",
        "# ---------------- GAE ----------------\n",
        "\n",
        "def gae(rews, vals, dones, gamma=1, lam=0.97):\n",
        "    T = len(rews); adv = np.zeros(T, np.float32); last = 0.0\n",
        "    for t in reversed(range(T)):\n",
        "        nxt = 0.0 if t == T-1 else vals[t+1]\n",
        "        nn  = 1.0 - dones[t]\n",
        "        delta = rews[t] + gamma * nxt * nn - vals[t]\n",
        "        last = delta + gamma * lam * nn * last\n",
        "        adv[t] = last\n",
        "    return adv, adv + vals\n",
        "\n",
        "# ---------------- Policy / Value nets ----------------\n",
        "class Policy(nn.Module):\n",
        "    def __init__(self, obs=OBS_DIM, act=ACT_DIM, hid=(128,128)):\n",
        "        super().__init__()\n",
        "        self.net = nn.Sequential(\n",
        "            nn.Linear(obs,hid[0]), nn.Tanh(),\n",
        "            nn.Linear(hid[0],hid[1]), nn.Tanh(),\n",
        "            nn.Linear(hid[1],act)\n",
        "        )\n",
        "    def forward(self,x): return self.net(x)\n",
        "\n",
        "class Value(nn.Module):\n",
        "    def __init__(self, obs=OBS_DIM, hid=(128,128)):\n",
        "        super().__init__()\n",
        "        self.v = nn.Sequential(\n",
        "            nn.Linear(obs,hid[0]), nn.Tanh(),\n",
        "            nn.Linear(hid[0],hid[1]), nn.Tanh(),\n",
        "            nn.Linear(hid[1],1)\n",
        "        )\n",
        "    def forward(self,x): return self.v(x).squeeze(-1)\n",
        "\n",
        "# ---------------- TRPO utilities ----------------\n",
        "def flat_params(m): return torch.cat([p.data.view(-1) for p in m.parameters()])\n",
        "\n",
        "def set_params(m, flat):\n",
        "    i=0\n",
        "    for p in m.parameters():\n",
        "        n=p.numel()\n",
        "        p.data = flat[i:i+n].view_as(p).data.clone()\n",
        "        i+=n\n",
        "\n",
        "def flat_grad(y, m, retain=False, create=False):\n",
        "    grads = torch.autograd.grad(\n",
        "        y, [p for p in m.parameters() if p.requires_grad],\n",
        "        retain_graph=retain, create_graph=create, allow_unused=True\n",
        "    )\n",
        "    return torch.cat([g.contiguous().view(-1) if g is not None else torch.zeros_like(p.view(-1)) for p, g in zip([p for p in m.parameters() if p.requires_grad], grads)])\n",
        "\n",
        "\n",
        "def kl_mean(policy, obs, old_logits):\n",
        "    new_logits = policy(obs)\n",
        "    p = torch.distributions.Categorical(logits=old_logits)\n",
        "    q = torch.distributions.Categorical(logits=new_logits)\n",
        "    return torch.distributions.kl.kl_divergence(p,q).mean()\n",
        "\n",
        "\n",
        "def fisher_vector_product_hvp(policy, obs, old_logits, v, damping=0.1):\n",
        "    v = v.to(device)\n",
        "\n",
        "    # Calculate KL divergence\n",
        "    new_logits = policy(obs)\n",
        "    p = torch.distributions.Categorical(logits=new_logits)\n",
        "    q = torch.distributions.Categorical(logits=old_logits)\n",
        "    kl = torch.distributions.kl.kl_divergence(p,q).mean()\n",
        "\n",
        "    # Calculate the gradient of the KL divergence w.r.t. policy parameters\n",
        "    kl_grad = flat_grad(kl, policy, retain=True, create=True)\n",
        "\n",
        "    # Calculate the Hessian-vector product (Fisher-vector product)\n",
        "    kl_v_product = torch.dot(kl_grad, v)\n",
        "    hvp = flat_grad(kl_v_product, policy, retain=False, create=False)\n",
        "\n",
        "    # Add damping\n",
        "    return hvp + damping * v\n",
        "\n",
        "def conjgrad(Avp, b, iters=10, tol=1e-10):\n",
        "    x = torch.zeros_like(b)\n",
        "    r = b.clone()\n",
        "    p = r.clone()\n",
        "    rr = torch.dot(r,r)\n",
        "    for _ in range(iters):\n",
        "        Ap = Avp(p)\n",
        "        denom = torch.dot(p,Ap) + 1e-8\n",
        "        alpha = rr / denom\n",
        "        x = x + alpha * p\n",
        "        r = r - alpha * Ap\n",
        "        rr_new = torch.dot(r,r)\n",
        "        if rr_new < tol: break\n",
        "        beta = rr_new/(rr+1e-8)\n",
        "        p = r + beta * p\n",
        "        rr = rr_new\n",
        "    return x\n",
        "\n",
        "@torch.no_grad()\n",
        "def linesearch(policy, loss_fn, params, step, expected, max_bt=10, accept=0.1):\n",
        "    f0 = float(loss_fn())\n",
        "    if not torch.isfinite(torch.tensor(f0)):\n",
        "        return False, params\n",
        "    for frac in 0.5**np.arange(max_bt):\n",
        "        cand = params + frac*step\n",
        "        set_params(policy, cand)\n",
        "        f1 = float(loss_fn())\n",
        "        denom = (expected*frac + 1e-8)\n",
        "        ratio = (f0 - f1) / denom\n",
        "        # surrogate objective improved and improvement is above reasonable fraction of expected improvement\n",
        "        if (f1 < f0) and (ratio > accept):\n",
        "            return True, cand\n",
        "    return False, params\n",
        "\n",
        "\n",
        "# ---------------- CRPO utilities ----------------\n",
        "def evaluate(batch_R, batch_C, batch_D, gamma=1):\n",
        "    \"\"\"Average per-episode discounted sums for return and each cost.\"\"\"\n",
        "    epR, epC = [], []\n",
        "    r=c=0.0; powg=1.0\n",
        "    T = len(batch_R)\n",
        "    for t in range(T):\n",
        "        r  += batch_R[t]    * powg\n",
        "        c  += batch_C[t]    * powg\n",
        "        done = batch_D[t] > 0.5\n",
        "        powg *= gamma\n",
        "        if done or t == T-1:\n",
        "            epR.append(r); epC.append(c)\n",
        "            r=c=0.0; powg=1.0\n",
        "    return float(np.mean(epR)), float(np.mean(epC))\n",
        "\n",
        "def uniform_quantize(tensor, num_bits):\n",
        "    if num_bits <= 0:\n",
        "        return torch.zeros_like(tensor)\n",
        "    if num_bits >= 32: # float32 is the base precision\n",
        "        return tensor\n",
        "\n",
        "    max_val = tensor.abs().max()\n",
        "    if max_val == 0:\n",
        "        return torch.zeros_like(tensor)\n",
        "\n",
        "    # Determine the number of quantization levels\n",
        "    num_levels = 2**num_bits\n",
        "\n",
        "    # Calculate the step size between quantization levels\n",
        "    step_size = 2 * max_val / num_levels\n",
        "\n",
        "    # Quantize the tensor\n",
        "    quantized_tensor = torch.round(tensor / step_size) * step_size\n",
        "\n",
        "    return quantized_tensor\n",
        "\n",
        "# ---------------- worker utilities ----------------\n",
        "def worker_collect_data(client_state_dict, env, client_env_seed, steps, gamma):\n",
        "    policy = Policy()\n",
        "    policy.load_state_dict(client_state_dict['policy'])\n",
        "    policy = policy.to('cpu')\n",
        "\n",
        "    if client_env_seed is not None:\n",
        "        try: env.reset(seed=client_env_seed)\n",
        "        except: env.reset()\n",
        "    obs, _ = env.reset()\n",
        "\n",
        "    O_list, A_list, LP_list = [], [], []\n",
        "    R_list, C_list, D_list = [], [], []\n",
        "\n",
        "    t = 0\n",
        "    while (t < steps) or (not term and not trunc):\n",
        "        t += 1\n",
        "        o_t = torch.as_tensor(obs, dtype=torch.float32, device='cpu').unsqueeze(0)\n",
        "        with torch.no_grad():\n",
        "            logits = policy(o_t)\n",
        "            dist = torch.distributions.Categorical(logits=logits)\n",
        "            a = dist.sample().to(torch.long)\n",
        "            lp = dist.log_prob(a)\n",
        "\n",
        "        nobs, r, term, trunc, info = env.step(a.item())\n",
        "\n",
        "        O_list.append(obs)\n",
        "        A_list.append(a)\n",
        "        LP_list.append(lp)\n",
        "        R_list.append(float(r))\n",
        "        C_list.append(info.get(\"costs\", np.zeros(2, np.float32)))\n",
        "        D_list.append(float(term or trunc))\n",
        "\n",
        "        obs = nobs\n",
        "\n",
        "        if term or trunc:\n",
        "            obs, _ = env.reset()\n",
        "\n",
        "    env.close()\n",
        "\n",
        "    O = np.array(O_list, dtype=np.float32)\n",
        "    A = torch.cat(A_list, dim=0)\n",
        "    LP = torch.cat(LP_list, dim=0)\n",
        "    R = np.array(R_list, dtype=np.float32)\n",
        "    C = np.array(C_list, dtype=np.float32)\n",
        "    D = np.array(D_list, dtype=np.float32)\n",
        "\n",
        "    return (O, A, LP, R, C, D)\n",
        "\n",
        "def worker_calculate_gradients(client_state_dict, data, pseudo_reward_ratio, gamma, lam, vf_iters, vf_lr, error_feedback, compression_rate=0.1):\n",
        "    policy = Policy()\n",
        "    value = Value()\n",
        "    value_optimizer = torch.optim.Adam(value.parameters(), lr=vf_lr)\n",
        "\n",
        "    policy.load_state_dict(client_state_dict['policy'])\n",
        "    policy = policy.to('cpu')\n",
        "    value.load_state_dict(client_state_dict['value'])\n",
        "    value = value.to('cpu')\n",
        "    value_optimizer.load_state_dict(client_state_dict['optimizer'])\n",
        "\n",
        "    O, A_cpu, LP_cpu, R, C, D = data\n",
        "\n",
        "    local_pseudo_reward = R*pseudo_reward_ratio[0] -C*pseudo_reward_ratio[1]\n",
        "\n",
        "    obs_t = torch.as_tensor(O, dtype=torch.float32, device='cpu')\n",
        "    with torch.no_grad():\n",
        "        vpred = value(obs_t).numpy()\n",
        "    adv, target = gae(local_pseudo_reward, vpred, D, gamma, lam)\n",
        "    adv = (adv - adv.mean()) / (adv.std() + 1e-8)\n",
        "\n",
        "    adv_t = torch.as_tensor(adv, dtype=torch.float32, device='cpu')\n",
        "    tgt_t = torch.as_tensor(target, dtype=torch.float32, device='cpu')\n",
        "\n",
        "    for _ in range(vf_iters):\n",
        "        value_optimizer.zero_grad()\n",
        "        v = value(obs_t)\n",
        "        v_loss = F.mse_loss(v, tgt_t)\n",
        "        v_loss.backward()\n",
        "        value_optimizer.step()\n",
        "\n",
        "    policy.zero_grad()\n",
        "    logits = policy(obs_t)\n",
        "    dist = torch.distributions.Categorical(logits=logits)\n",
        "    logp = dist.log_prob(A_cpu)\n",
        "    ratio = torch.exp(logp - LP_cpu)\n",
        "    loss = - (ratio * adv_t).mean()\n",
        "\n",
        "    # torch.float32\n",
        "    policy_grad = flat_grad(loss, policy, retain=False, create=False)\n",
        "\n",
        "    # Incorporate error feedback\n",
        "    if error_feedback is not None:\n",
        "        policy_grad_with_ef = policy_grad + error_feedback\n",
        "    else:\n",
        "        policy_grad_with_ef = policy_grad\n",
        "\n",
        "    # Implement Top-k compression\n",
        "    if compression_rate == 1.0:\n",
        "        compressed_policy_grad = policy_grad_with_ef\n",
        "    elif compression_rate < 1.0:\n",
        "        k = int(policy_grad_with_ef.numel() * compression_rate)\n",
        "        if k > 0:\n",
        "            topk_values, topk_indices = torch.topk(torch.abs(policy_grad_with_ef), k)\n",
        "            compressed_policy_grad = torch.zeros_like(policy_grad_with_ef)\n",
        "            compressed_policy_grad[topk_indices] = policy_grad_with_ef[topk_indices]\n",
        "        else:\n",
        "            compressed_policy_grad = torch.zeros_like(policy_grad_with_ef) # Handle case where k=0\n",
        "    else:\n",
        "        compressed_policy_grad = uniform_quantize(policy_grad_with_ef, num_bits=compression_rate)\n",
        "\n",
        "    # Update error feedback\n",
        "    new_error_feedback = policy_grad_with_ef - compressed_policy_grad\n",
        "\n",
        "    return (compressed_policy_grad,\n",
        "            {k: v for k, v in value.state_dict().items()},\n",
        "            obs_t, A_cpu, LP_cpu, adv_t,\n",
        "            new_error_feedback)\n",
        "\n",
        "\n",
        "# ---------------- Client/Server ----------------\n",
        "\n",
        "class Client:\n",
        "    def __init__(self, env, policy, value, vf_lr=3e-4):\n",
        "        self.env = env\n",
        "        self.policy = policy\n",
        "        self.value = value\n",
        "        self.value_optimizer = torch.optim.Adam(self.value.parameters(), lr=vf_lr)\n",
        "        self.error = None # Add error feedback attribute\n",
        "        self.tolerance = random.randint(-5, 5)\n",
        "\n",
        "    def update_local_model(self, policy_sd, value_sd):\n",
        "        \"\"\"Updates the client's local policy and value network models.\"\"\"\n",
        "        self.policy.load_state_dict(policy_sd)\n",
        "        self.value.load_state_dict(value_sd)\n",
        "\n",
        "class Server:\n",
        "    def __init__(self):\n",
        "        self.global_policy = Policy().to(device)\n",
        "        self.global_value  = Value().to(device)\n",
        "\n",
        "    def aggregate_metrics(self, client_metrics_data):\n",
        "        \"\"\"Aggregates metrics and data from clients.\"\"\"\n",
        "        if not client_metrics_data:\n",
        "            return None, None\n",
        "\n",
        "        Rets = [item[0] for item in client_metrics_data]\n",
        "        Costs = [item[1] for item in client_metrics_data]\n",
        "\n",
        "        avg_Ret = np.mean(Rets)\n",
        "        avg_Cost = np.mean(Costs)\n",
        "\n",
        "        return (avg_Ret, avg_Cost)\n",
        "\n",
        "\n",
        "    def trimmed_hinge(self, x, beta):\n",
        "        return np.minimum(1.0, np.maximum(1+beta*x, 0.0))\n",
        "\n",
        "    def determine_pseudo_reward_ratio(self, avg_Cost, d_limit, beta):\n",
        "        \"\"\"Determines the pseudo-reward ratio based on aggregated constraints.\"\"\"\n",
        "        viol = avg_Cost - d_limit\n",
        "\n",
        "        if beta is not None:\n",
        "            weight = self.trimmed_hinge(viol, beta)\n",
        "            return (1.0-weight, weight)\n",
        "        else:\n",
        "            if viol > 0:\n",
        "                return (0.0, 1.0, 0.0)\n",
        "            else:\n",
        "                return (1.0, 0.0, 0.0)\n",
        "\n",
        "\n",
        "    def aggregate_gradients_and_value_sds(self, client_updates, num_total_clients):\n",
        "        \"\"\"Aggregates policy gradients and value network state dictionaries from selected clients.\"\"\"\n",
        "        if not client_updates:\n",
        "            return None, None, None, None, None, None\n",
        "\n",
        "        policy_grads = [update[0] for update in client_updates]\n",
        "        value_sds = [update[1] for update in client_updates]\n",
        "        obs_ts = [update[2] for update in client_updates]\n",
        "        A_ts = [update[3] for update in client_updates]\n",
        "        LP_ts = [update[4] for update in client_updates]\n",
        "        adv_ts = [update[5] for update in client_updates]\n",
        "\n",
        "        # Aggregate only from selected clients and scale by n/m\n",
        "        num_selected_clients = len(client_updates)\n",
        "        scaling_factor = num_total_clients / num_selected_clients\n",
        "\n",
        "        avg_policy_grad = torch.mean(torch.stack(policy_grads), dim=0) * scaling_factor\n",
        "\n",
        "        avg_value_sd = {}\n",
        "        for key in value_sds[0]:\n",
        "            avg_value_sd[key] = torch.mean(torch.stack([sd[key] for sd in value_sds]), dim=0)\n",
        "\n",
        "        aggregated_obs_t = torch.cat(obs_ts, dim=0)\n",
        "        aggregated_acts_t = torch.cat(A_ts, dim=0)\n",
        "        aggregated_old_logp_t = torch.cat(LP_ts, dim=0)\n",
        "        aggregated_adv_t = torch.cat(adv_ts, dim=0)\n",
        "\n",
        "\n",
        "        return (avg_policy_grad, avg_value_sd,\n",
        "                aggregated_obs_t, aggregated_acts_t,\n",
        "                aggregated_old_logp_t, aggregated_adv_t)\n",
        "\n",
        "\n",
        "    def update_models(self, aggregated_policy_grad, aggregated_value_sd, obs_t, acts_t, old_logp_t, adv_t, max_kl=0.01, cg_iters=10, damping=0.1, learning_rate=1.0):\n",
        "        \"\"\"Updates the global policy and value network models.\"\"\"\n",
        "        g = aggregated_policy_grad\n",
        "\n",
        "        old_logits = self.global_policy(obs_t).detach()\n",
        "        Avp = lambda v: fisher_vector_product_hvp(self.global_policy, obs_t, old_logits, v, damping=damping)\n",
        "\n",
        "        stepdir = conjgrad(Avp, -g, iters=cg_iters)       # Natural gradient\n",
        "        shs = 0.5 * torch.dot(stepdir, Avp(stepdir))      # Second-order approximation of KLD\n",
        "        shs_val = float(shs.abs().item())\n",
        "        if shs_val <= 1e-12 or not np.isfinite(shs_val):  # Calculated gradient is not reliable\n",
        "            step = 1e-2 * (-g) * learning_rate # Apply learning rate here as well\n",
        "        else:\n",
        "            scale = torch.sqrt((2.0 * torch.as_tensor(max_kl, device=shs.device)) / (shs + 1e-8))\n",
        "            step  = scale * stepdir * learning_rate # Apply learning rate here\n",
        "\n",
        "        params = flat_params(self.global_policy)\n",
        "        expected = float((-g * step).sum().item())\n",
        "        if not np.isfinite(expected) or expected <= 0:\n",
        "            return\n",
        "\n",
        "        def server_surr_value():\n",
        "            logits = self.global_policy(obs_t)\n",
        "            dist = torch.distributions.Categorical(logits=logits)\n",
        "            logp = dist.log_prob(acts_t)\n",
        "            ratio = torch.exp(logp - old_logp_t)\n",
        "            return - (ratio * adv_t).mean()\n",
        "\n",
        "        ok, new_params = linesearch(self.global_policy, server_surr_value, params, step, expected)\n",
        "        set_params(self.global_policy, new_params if ok else params)\n",
        "\n",
        "\n",
        "        self.global_value.load_state_dict(aggregated_value_sd)\n",
        "\n",
        "\n",
        "    def distribute_models(self):\n",
        "        \"\"\"Distributes the updated global policy and value network models.\"\"\"\n",
        "        return self.global_policy.state_dict(), self.global_value.state_dict()\n",
        "\n",
        "\n",
        "# ---------------- Plotting (x-axis = iterations) ----------------\n",
        "def _movavg(x, k):\n",
        "    x = np.asarray(x, dtype=float)\n",
        "    if k is None or k <= 1 or k > len(x):\n",
        "        return x\n",
        "    k = int(k)\n",
        "    w = np.ones(k, dtype=float) / float(k)\n",
        "    smoothed = np.convolve(x, w, mode=\"same\")\n",
        "    # Replace the last k//2 points with the original values to avoid the drop\n",
        "    end_replace = k // 2\n",
        "    if end_replace > 0:\n",
        "        smoothed[-end_replace:] = x[-end_replace:]\n",
        "    return smoothed\n",
        "\n",
        "def plot_federated_results(histories, d_limit=30.0, smooth=20,\n",
        "                           filename=\"federated_crpo_cartpole_iter_fig.png\", title_tag=\"Federated CRPO (Hard Switch)\"):\n",
        "    \"\"\"\n",
        "    Single PNG with two panels showing mean and min/max range over multiple histories:\n",
        "      Left: Return vs Iterations\n",
        "      Right: Constraint Values vs Iterations (dashed limits)\n",
        "    Saves to current directory.\n",
        "    \"\"\"\n",
        "    if not histories:\n",
        "        print(\"No histories to plot.\")\n",
        "        return\n",
        "\n",
        "    # Align histories to the minimum number of iterations\n",
        "    min_len = min(len(h[\"R\"]) for h in histories)\n",
        "    R_data = np.array([h[\"R\"][:min_len] for h in histories])\n",
        "    C_data = np.array([h[\"C\"][:min_len] for h in histories])\n",
        "\n",
        "    R_mean, R_min, R_max = np.mean(R_data, axis=0), np.min(R_data, axis=0), np.max(R_data, axis=0)\n",
        "    C_mean, C_min, C_max = np.mean(C_data, axis=0), np.min(C_data, axis=0), np.max(C_data, axis=0)\n",
        "\n",
        "    xs = np.arange(1, min_len + 1)\n",
        "\n",
        "    R_s_mean  = _movavg(R_mean,  smooth)\n",
        "    R_s_min  = _movavg(R_min,  smooth)\n",
        "    R_s_max  = _movavg(R_max,  smooth)\n",
        "    C_s_mean = _movavg(C_mean, smooth)\n",
        "    C_s_min = _movavg(C_min, smooth)\n",
        "    C_s_max = _movavg(C_max, smooth)\n",
        "\n",
        "    fig, axes = plt.subplots(1, 2, figsize=(12, 4.5), dpi=140)\n",
        "\n",
        "    ax = axes[0]\n",
        "    ax.plot(xs, R_s_mean, label=title_tag)\n",
        "    ax.fill_between(xs, R_s_min, R_s_max, alpha=0.2)\n",
        "    ax.set_xlabel(\"Rounds\")\n",
        "    ax.set_ylabel(\"Return\")\n",
        "    ax.set_title(\"Return\")\n",
        "    ax.grid(True, alpha=0.3)\n",
        "    ax.legend(loc=\"best\")\n",
        "\n",
        "    ax = axes[1]\n",
        "    ax.plot(xs, C_s_mean, label=\"Constraint\")\n",
        "    ax.fill_between(xs, C_s_min, C_s_max, alpha=0.2)\n",
        "    ax.axhline(d_limit, linestyle=\"--\", linewidth=1.5, label=\"Limit\")\n",
        "    ax.set_xlabel(\"Rounds\")\n",
        "    ax.set_ylabel(\"Constraint Values\")\n",
        "    ax.set_title(\"Constraint Values\")\n",
        "    ax.grid(True, alpha=0.3)\n",
        "    ax.legend(loc=\"best\")\n",
        "\n",
        "    fig.tight_layout()\n",
        "    fig.savefig(os.path.join(os.getcwd(), filename))\n",
        "    plt.close(fig)\n",
        "    print(f\"Saved figure to ./{filename}\")\n",
        "\n",
        "\n",
        "# ---------------- Run training & plot ----------------\n",
        "def train_federated_crpo_cartpole_parallel(\n",
        "    num_rounds=500, num_total_clients=5, num_selected_clients=2, steps_per_batch=8192, gamma=1, lam=0.97,\n",
        "    max_kl=0.01, cg_iters=10, damping=0.1,\n",
        "    d_limit=30.0, beta=None,\n",
        "    vf_lr=3e-4, vf_iters=100, seed=SEED,\n",
        "    compression_rate=0.1 # Add compression_rate parameter\n",
        "):\n",
        "    steps_per_batch = steps_per_batch // num_total_clients\n",
        "\n",
        "    server = Server()\n",
        "\n",
        "    clients = []\n",
        "    for i in range(num_total_clients):\n",
        "        env = make_env(seed=seed + i)\n",
        "        client_policy = Policy().to(device)\n",
        "        client_value = Value().to(device)\n",
        "        client_policy.load_state_dict(server.global_policy.state_dict())\n",
        "        client_value.load_state_dict(server.global_value.state_dict())\n",
        "        clients.append(Client(env, client_policy, client_value, vf_lr=vf_lr))\n",
        "\n",
        "\n",
        "    R_hist, C_hist = [], []\n",
        "\n",
        "    print(f\"Starting parallel federated learning for {num_rounds} rounds with {num_total_clients} total clients and {num_selected_clients} selected clients per round.\")\n",
        "\n",
        "    if num_total_clients == 1:\n",
        "        for round_num in range(num_rounds):\n",
        "            print(f\"[FedSGM] it {round_num+1:04d}/{num_rounds} | \", end=\"\")\n",
        "\n",
        "            client_data = worker_collect_data({'policy': clients[0].policy.state_dict()}, clients[0].env, seed + round_num * num_total_clients, steps_per_batch, gamma)\n",
        "\n",
        "            avg_Ret, avg_Cost, avg_C2 = evaluate(client_data[3], client_data[4], client_data[5], gamma)\n",
        "\n",
        "            pseudo_reward_ratio = server.determine_pseudo_reward_ratio(avg_Cost, d_limit, beta)\n",
        "            print(f\"switching ratio:({pseudo_reward_ratio[0]:.2f}, {pseudo_reward_ratio[1]:.2f}) | \", end=\"\")\n",
        "            print(f\"R:{avg_Ret:7.2f} | C:{avg_Cost:7.2f}/{d_limit}\")\n",
        "\n",
        "            update_data = worker_calculate_gradients({'policy': clients[0].policy.state_dict(), 'value': clients[0].value.state_dict(), 'optimizer': clients[0].value_optimizer.state_dict()},\n",
        "                                                     client_data, pseudo_reward_ratio, gamma, lam, vf_iters, vf_lr, clients[0].error, compression_rate)\n",
        "\n",
        "            aggregated_policy_grad_cpu = update_data[0]\n",
        "            aggregated_value_sd_cpu = update_data[1]\n",
        "            aggregated_obs_t_cpu = update_data[2]\n",
        "            aggregated_acts_t_cpu = update_data[3]\n",
        "            aggregated_old_logp_t_cpu = update_data[4]\n",
        "            aggregated_adv_t_cpu = update_data[5]\n",
        "\n",
        "            clients[0].error = update_data[-1] # Store the error feedback\n",
        "\n",
        "            if aggregated_policy_grad_cpu is not None:\n",
        "                aggregated_policy_grad = aggregated_policy_grad_cpu.to(device)\n",
        "                aggregated_value_sd = {k: v.to(device) for k, v in aggregated_value_sd_cpu.items()}\n",
        "                aggregated_obs_t = aggregated_obs_t_cpu.to(device)\n",
        "                aggregated_acts_t = aggregated_acts_t_cpu.to(device)\n",
        "                aggregated_old_logp_t = aggregated_old_logp_t_cpu.to(device)\n",
        "                aggregated_adv_t = aggregated_adv_t_cpu.to(device)\n",
        "\n",
        "                server.update_models(\n",
        "                    aggregated_policy_grad,\n",
        "                    aggregated_value_sd,\n",
        "                    obs_t=aggregated_obs_t,\n",
        "                    acts_t=aggregated_acts_t,\n",
        "                    old_logp_t=aggregated_old_logp_t,\n",
        "                    adv_t=aggregated_adv_t,\n",
        "                    max_kl=max_kl,\n",
        "                    cg_iters=cg_iters,\n",
        "                    damping=damping,\n",
        "                    learning_rate=num_total_clients/num_selected_clients # Apply learning rate based on sampling ratio\n",
        "                )\n",
        "            else:\n",
        "                print(\"Warning: No valid client updates to aggregate gradients. Skipping server model update.\")\n",
        "\n",
        "            R_hist.append(avg_Ret)\n",
        "            C_hist.append(avg_Cost)\n",
        "\n",
        "            updated_policy_sd_cpu, updated_value_sd_cpu = server.distribute_models()\n",
        "            clients[0].update_local_model(updated_policy_sd_cpu, updated_value_sd_cpu)\n",
        "    else:\n",
        "        with concurrent.futures.ProcessPoolExecutor(max_workers=num_selected_clients) as executor:\n",
        "\n",
        "            for round_num in range(num_rounds):\n",
        "                print(f\"[FedSGM] it {round_num+1:04d}/{num_rounds} | \", end=\"\")\n",
        "\n",
        "                # Sample clients for this round\n",
        "                selected_client_indices = random.sample(range(num_total_clients), num_selected_clients)\n",
        "                selected_clients = [clients[i] for i in selected_client_indices]\n",
        "\n",
        "                collect_futures = {executor.submit(worker_collect_data,\n",
        "                                                  {'policy': client.policy.state_dict()},\n",
        "                                                   client.env,\n",
        "                                                  seed + round_num * num_total_clients + client_idx, # Ensure unique seeds for each client in each round\n",
        "                                                  steps_per_batch, gamma): client_idx\n",
        "                                  for client_idx, client in zip(selected_client_indices, selected_clients)}\n",
        "\n",
        "                client_data = {}\n",
        "                for future in concurrent.futures.as_completed(collect_futures):\n",
        "                    client_idx = collect_futures[future]\n",
        "                    try:\n",
        "                        data = future.result()\n",
        "                        client_data[client_idx] = data\n",
        "                    except Exception as exc:\n",
        "                        print(f'Client {client_idx} data collection generated an exception: {exc}')\n",
        "\n",
        "                client_metrics = []\n",
        "                constraints = []\n",
        "                for client_idx in selected_client_indices:\n",
        "                    if client_idx in client_data:\n",
        "                        data = client_data[client_idx]\n",
        "                        Ret, Cost = evaluate(data[3], data[4], data[5], gamma)\n",
        "                        client_metrics.append((Ret, Cost))\n",
        "                        constraints.append(Cost-clients[client_idx].tolerance)\n",
        "\n",
        "                (avg_Ret, avg_Cost) = server.aggregate_metrics(client_metrics)\n",
        "                constraint = np.mean(constraints)\n",
        "\n",
        "                if avg_Ret is None:\n",
        "                    print(\"Warning: No valid client data for aggregation. Skipping server update and model distribution.\")\n",
        "                    continue\n",
        "\n",
        "                pseudo_reward_ratio = server.determine_pseudo_reward_ratio(constraint, d_limit, beta)\n",
        "                print(f\"switching ratio:({pseudo_reward_ratio[0]:.2f}, {pseudo_reward_ratio[1]:.2f}) | \", end=\"\")\n",
        "                print(f\"R:{avg_Ret:7.2f} | C:{avg_Cost:7.2f}/{d_limit}\")\n",
        "\n",
        "                grad_futures = {executor.submit(worker_calculate_gradients,\n",
        "                                                {'policy': client.policy.state_dict(),\n",
        "                                                'value': client.value.state_dict(),\n",
        "                                                'optimizer': client.value_optimizer.state_dict()},\n",
        "                                                client_data[client_idx],\n",
        "                                                pseudo_reward_ratio,\n",
        "                                                gamma, lam, vf_iters, vf_lr,\n",
        "                                                client.error, # Pass client's error feedback\n",
        "                                                compression_rate): client_idx # Pass compression rate\n",
        "                                for client_idx, client in zip(selected_client_indices, selected_clients) if client_idx in client_data}\n",
        "\n",
        "\n",
        "                client_updates = {}\n",
        "                client_errors = {} # Store updated errors for selected clients\n",
        "                for future in concurrent.futures.as_completed(grad_futures):\n",
        "                    client_idx = grad_futures[future]\n",
        "                    try:\n",
        "                        update_data = future.result()\n",
        "                        client_updates[client_idx] = update_data[:-1] # Exclude error feedback for aggregation\n",
        "                        client_errors[client_idx] = update_data[-1] # Store the error feedback\n",
        "                    except Exception as exc:\n",
        "                        print(f'Client {client_idx} gradient calculation generated an exception: {exc}')\n",
        "\n",
        "                valid_client_updates = list(client_updates.values())\n",
        "\n",
        "                (aggregated_policy_grad_cpu, aggregated_value_sd_cpu,\n",
        "                aggregated_obs_t_cpu, aggregated_acts_t_cpu,\n",
        "                aggregated_old_logp_t_cpu, aggregated_adv_t_cpu) = server.aggregate_gradients_and_value_sds(valid_client_updates, num_total_clients)\n",
        "\n",
        "                if aggregated_policy_grad_cpu is not None:\n",
        "                    aggregated_policy_grad = aggregated_policy_grad_cpu.to(device)\n",
        "                    aggregated_value_sd = {k: v.to(device) for k, v in aggregated_value_sd_cpu.items()}\n",
        "                    aggregated_obs_t = aggregated_obs_t_cpu.to(device)\n",
        "                    aggregated_acts_t = aggregated_acts_t_cpu.to(device)\n",
        "                    aggregated_old_logp_t = aggregated_old_logp_t_cpu.to(device)\n",
        "                    aggregated_adv_t = aggregated_adv_t_cpu.to(device)\n",
        "\n",
        "                    server.update_models(\n",
        "                        aggregated_policy_grad,\n",
        "                        aggregated_value_sd,\n",
        "                        obs_t=aggregated_obs_t,\n",
        "                        acts_t=aggregated_acts_t,\n",
        "                        old_logp_t=aggregated_old_logp_t,\n",
        "                        adv_t=aggregated_adv_t,\n",
        "                        max_kl=max_kl,\n",
        "                        cg_iters=cg_iters,\n",
        "                        damping=damping,\n",
        "                        learning_rate=num_total_clients/num_selected_clients # Apply learning rate based on sampling ratio\n",
        "                    )\n",
        "                else:\n",
        "                    print(\"Warning: No valid client updates to aggregate gradients. Skipping server model update.\")\n",
        "\n",
        "                R_hist.append(avg_Ret)\n",
        "                C_hist.append(avg_Cost)\n",
        "\n",
        "                updated_policy_sd_cpu, updated_value_sd_cpu = server.distribute_models()\n",
        "                # Update all clients with the global model, but only update error feedback for selected clients\n",
        "                for i in range(num_total_clients):\n",
        "                    clients[i].update_local_model(updated_policy_sd_cpu, updated_value_sd_cpu)\n",
        "                    if i in client_errors:\n",
        "                        clients[i].error = client_errors[i] # Update error feedback for selected clients\n",
        "\n",
        "\n",
        "    for client in clients:\n",
        "        client.env.close()\n",
        "\n",
        "    feasible_idx = [i for i, c in enumerate(C_hist)\n",
        "                    if c is not None and c <= d_limit] # Fix indexing here\n",
        "\n",
        "    if feasible_idx:\n",
        "        lastN = feasible_idx[-min(50, len(feasible_idx)):]\n",
        "        avg_lastN = float(np.mean([R_hist[i] for i in lastN]))\n",
        "        print(f\"Avg return over last {len(lastN)} feasible rounds: {avg_lastN:.2f}\")\n",
        "    else:\n",
        "        print(\"No feasible rounds (Avg Cost<=d_limit).\")\n",
        "\n",
        "    return server.global_policy, {\"R\":np.array(R_hist), \"C\":np.array(C_hist)}"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "EoDGGtvBqTuV",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "00f9f396-22b7-4301-f742-b8a987a3004a"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "--- Running Experiment 1/5 ---\n",
            "Starting parallel federated learning for 500 rounds with 10 total clients and 7 selected clients per round.\n",
            "[FedSGM] it 0001/500 | switching ratio:(0.27, 0.73) | R:  27.60 | C:  25.38/30.0\n",
            "[FedSGM] it 0002/500 | switching ratio:(0.98, 0.02) | R:  18.11 | C:  17.44/30.0\n",
            "[FedSGM] it 0003/500 | switching ratio:(0.51, 0.49) | R:  24.60 | C:  22.94/30.0\n",
            "[FedSGM] it 0004/500 | switching ratio:(0.16, 0.84) | R:  31.84 | C:  28.09/30.0\n",
            "[FedSGM] it 0005/500 | switching ratio:(0.67, 0.33) | R:  23.11 | C:  21.77/30.0\n",
            "[FedSGM] it 0006/500 | switching ratio:(0.20, 0.80) | R:  30.98 | C:  27.30/30.0\n",
            "[FedSGM] it 0007/500 | switching ratio:(0.79, 0.21) | R:  19.97 | C:  19.06/30.0\n",
            "[FedSGM] it 0008/500 | switching ratio:(0.15, 0.85) | R:  32.77 | C:  28.71/30.0\n",
            "[FedSGM] it 0009/500 | switching ratio:(0.83, 0.17) | R:  20.61 | C:  19.62/30.0\n",
            "[FedSGM] it 0010/500 | switching ratio:(0.12, 0.88) | R:  32.12 | C:  28.45/30.0\n",
            "[FedSGM] it 0011/500 | switching ratio:(0.76, 0.24) | R:  21.20 | C:  20.10/30.0\n",
            "[FedSGM] it 0012/500 | switching ratio:(0.34, 0.66) | R:  28.62 | C:  26.21/30.0\n",
            "[FedSGM] it 0013/500 | switching ratio:(0.78, 0.22) | R:  21.00 | C:  20.01/30.0\n",
            "[FedSGM] it 0014/500 | switching ratio:(0.26, 0.74) | R:  30.13 | C:  26.68/30.0\n",
            "[FedSGM] it 0015/500 | switching ratio:(0.51, 0.49) | R:  27.12 | C:  24.57/30.0\n",
            "[FedSGM] it 0016/500 | switching ratio:(0.12, 0.88) | R:  31.67 | C:  28.01/30.0\n",
            "[FedSGM] it 0017/500 | switching ratio:(0.62, 0.38) | R:  22.82 | C:  20.93/30.0\n",
            "[FedSGM] it 0018/500 | switching ratio:(0.76, 0.24) | R:  21.64 | C:  20.45/30.0\n",
            "[FedSGM] it 0019/500 | switching ratio:(0.00, 1.00) | R:  38.14 | C:  33.04/30.0\n",
            "[FedSGM] it 0020/500 | switching ratio:(0.49, 0.51) | R:  24.92 | C:  22.79/30.0\n",
            "[FedSGM] it 0021/500 | switching ratio:(0.68, 0.32) | R:  22.05 | C:  20.77/30.0\n",
            "[FedSGM] it 0022/500 | switching ratio:(0.13, 0.87) | R:  32.91 | C:  28.03/30.0\n",
            "[FedSGM] it 0023/500 | switching ratio:(0.58, 0.42) | R:  22.86 | C:  21.48/30.0\n",
            "[FedSGM] it 0024/500 | switching ratio:(0.17, 0.83) | R:  31.08 | C:  27.60/30.0\n",
            "[FedSGM] it 0025/500 | switching ratio:(0.66, 0.34) | R:  22.48 | C:  21.04/30.0\n",
            "[FedSGM] it 0026/500 | switching ratio:(0.53, 0.47) | R:  24.76 | C:  22.42/30.0\n",
            "[FedSGM] it 0027/500 | switching ratio:(0.00, 1.00) | R:  39.99 | C:  32.52/30.0\n",
            "[FedSGM] it 0028/500 | switching ratio:(0.26, 0.74) | R:  30.83 | C:  27.32/30.0\n",
            "[FedSGM] it 0029/500 | switching ratio:(0.79, 0.21) | R:  20.07 | C:  18.93/30.0\n",
            "[FedSGM] it 0030/500 | switching ratio:(0.71, 0.29) | R:  19.85 | C:  18.97/30.0\n",
            "[FedSGM] it 0031/500 | switching ratio:(0.42, 0.58) | R:  27.70 | C:  25.06/30.0\n",
            "[FedSGM] it 0032/500 | switching ratio:(0.00, 1.00) | R:  38.43 | C:  32.29/30.0\n",
            "[FedSGM] it 0033/500 | switching ratio:(0.76, 0.24) | R:  21.96 | C:  20.78/30.0\n",
            "[FedSGM] it 0034/500 | switching ratio:(0.65, 0.35) | R:  22.69 | C:  21.47/30.0\n",
            "[FedSGM] it 0035/500 | switching ratio:(0.00, 1.00) | R:  50.99 | C:  38.49/30.0\n",
            "[FedSGM] it 0036/500 | switching ratio:(0.00, 1.00) | R:  36.96 | C:  31.35/30.0\n",
            "[FedSGM] it 0037/500 | switching ratio:(0.65, 0.35) | R:  23.30 | C:  21.45/30.0\n",
            "[FedSGM] it 0038/500 | switching ratio:(1.00, 0.00) | R:  16.91 | C:  16.26/30.0\n",
            "[FedSGM] it 0039/500 | switching ratio:(0.72, 0.28) | R:  21.27 | C:  19.96/30.0\n",
            "[FedSGM] it 0040/500 | switching ratio:(0.00, 1.00) | R:  39.31 | C:  33.02/30.0\n",
            "[FedSGM] it 0041/500 | switching ratio:(0.07, 0.93) | R:  35.19 | C:  30.12/30.0\n",
            "[FedSGM] it 0042/500 | switching ratio:(0.70, 0.30) | R:  21.90 | C:  20.42/30.0\n",
            "[FedSGM] it 0043/500 | switching ratio:(1.00, 0.00) | R:  15.81 | C:  15.28/30.0\n",
            "[FedSGM] it 0044/500 | switching ratio:(0.72, 0.28) | R:  23.60 | C:  21.36/30.0\n",
            "[FedSGM] it 0045/500 | switching ratio:(0.00, 1.00) | R:  42.54 | C:  33.81/30.0\n",
            "[FedSGM] it 0046/500 | switching ratio:(0.00, 1.00) | R:  41.43 | C:  34.64/30.0\n",
            "[FedSGM] it 0047/500 | switching ratio:(0.47, 0.53) | R:  25.30 | C:  23.11/30.0\n",
            "[FedSGM] it 0048/500 | switching ratio:(0.92, 0.08) | R:  18.62 | C:  17.74/30.0\n",
            "[FedSGM] it 0049/500 | switching ratio:(0.50, 0.50) | R:  24.71 | C:  22.94/30.0\n",
            "[FedSGM] it 0050/500 | switching ratio:(0.00, 1.00) | R:  60.00 | C:  44.91/30.0\n",
            "[FedSGM] it 0051/500 | switching ratio:(0.00, 1.00) | R:  36.11 | C:  30.81/30.0\n",
            "[FedSGM] it 0052/500 | switching ratio:(0.58, 0.42) | R:  24.29 | C:  22.51/30.0\n",
            "[FedSGM] it 0053/500 | switching ratio:(0.99, 0.01) | R:  16.05 | C:  15.50/30.0\n",
            "[FedSGM] it 0054/500 | switching ratio:(0.83, 0.17) | R:  19.99 | C:  19.11/30.0\n",
            "[FedSGM] it 0055/500 | switching ratio:(0.14, 0.86) | R:  32.30 | C:  28.23/30.0\n",
            "[FedSGM] it 0056/500 | switching ratio:(0.06, 0.94) | R:  34.35 | C:  30.09/30.0\n",
            "[FedSGM] it 0057/500 | switching ratio:(0.77, 0.23) | R:  20.21 | C:  19.12/30.0\n",
            "[FedSGM] it 0058/500 | switching ratio:(0.73, 0.27) | R:  20.40 | C:  19.41/30.0\n",
            "[FedSGM] it 0059/500 | switching ratio:(0.24, 0.76) | R:  32.11 | C:  28.46/30.0\n",
            "[FedSGM] it 0060/500 | switching ratio:(0.13, 0.87) | R:  32.60 | C:  28.81/30.0\n",
            "[FedSGM] it 0061/500 | switching ratio:(0.75, 0.25) | R:  21.11 | C:  19.79/30.0\n",
            "[FedSGM] it 0062/500 | switching ratio:(0.60, 0.40) | R:  21.95 | C:  20.36/30.0\n",
            "[FedSGM] it 0063/500 | switching ratio:(0.00, 1.00) | R:  36.98 | C:  31.07/30.0\n",
            "[FedSGM] it 0064/500 | switching ratio:(0.43, 0.57) | R:  28.19 | C:  24.93/30.0\n",
            "[FedSGM] it 0065/500 | switching ratio:(0.71, 0.29) | R:  20.98 | C:  19.93/30.0\n",
            "[FedSGM] it 0066/500 | switching ratio:(0.54, 0.46) | R:  24.46 | C:  22.68/30.0\n",
            "[FedSGM] it 0067/500 | switching ratio:(0.00, 1.00) | R:  39.72 | C:  32.99/30.0\n",
            "[FedSGM] it 0068/500 | switching ratio:(0.39, 0.61) | R:  27.77 | C:  24.82/30.0\n",
            "[FedSGM] it 0069/500 | switching ratio:(0.75, 0.25) | R:  19.36 | C:  18.42/30.0\n",
            "[FedSGM] it 0070/500 | switching ratio:(0.72, 0.28) | R:  22.19 | C:  20.59/30.0\n",
            "[FedSGM] it 0071/500 | switching ratio:(0.05, 0.95) | R:  34.08 | C:  29.82/30.0\n",
            "[FedSGM] it 0072/500 | switching ratio:(0.56, 0.44) | R:  25.47 | C:  23.06/30.0\n",
            "[FedSGM] it 0073/500 | switching ratio:(1.00, 0.00) | R:  17.33 | C:  16.58/30.0\n",
            "[FedSGM] it 0074/500 | switching ratio:(0.74, 0.26) | R:  21.69 | C:  20.47/30.0\n",
            "[FedSGM] it 0075/500 | switching ratio:(0.00, 1.00) | R:  37.85 | C:  31.88/30.0\n",
            "[FedSGM] it 0076/500 | switching ratio:(0.45, 0.55) | R:  26.48 | C:  24.06/30.0\n",
            "[FedSGM] it 0077/500 | switching ratio:(1.00, 0.00) | R:  16.76 | C:  16.13/30.0\n",
            "[FedSGM] it 0078/500 | switching ratio:(0.79, 0.21) | R:  21.58 | C:  20.27/30.0\n",
            "[FedSGM] it 0079/500 | switching ratio:(0.04, 0.96) | R:  35.19 | C:  29.55/30.0\n",
            "[FedSGM] it 0080/500 | switching ratio:(0.12, 0.88) | R:  32.40 | C:  28.24/30.0\n",
            "[FedSGM] it 0081/500 | switching ratio:(0.85, 0.15) | R:  18.68 | C:  17.80/30.0\n",
            "[FedSGM] it 0082/500 | switching ratio:(0.91, 0.09) | R:  18.77 | C:  18.06/30.0\n",
            "[FedSGM] it 0083/500 | switching ratio:(0.52, 0.48) | R:  25.21 | C:  22.99/30.0\n",
            "[FedSGM] it 0084/500 | switching ratio:(0.00, 1.00) | R:  43.58 | C:  34.69/30.0\n",
            "[FedSGM] it 0085/500 | switching ratio:(0.59, 0.41) | R:  25.35 | C:  23.25/30.0\n",
            "[FedSGM] it 0086/500 | switching ratio:(0.82, 0.18) | R:  19.62 | C:  18.86/30.0\n",
            "[FedSGM] it 0087/500 | switching ratio:(0.27, 0.73) | R:  28.47 | C:  25.79/30.0\n",
            "[FedSGM] it 0088/500 | switching ratio:(0.20, 0.80) | R:  32.35 | C:  28.47/30.0\n",
            "[FedSGM] it 0089/500 | switching ratio:(0.70, 0.30) | R:  21.26 | C:  20.06/30.0\n",
            "[FedSGM] it 0090/500 | switching ratio:(0.54, 0.46) | R:  24.92 | C:  22.60/30.0\n",
            "[FedSGM] it 0091/500 | switching ratio:(0.00, 1.00) | R:  60.27 | C:  43.26/30.0\n",
            "[FedSGM] it 0092/500 | switching ratio:(0.00, 1.00) | R:  48.96 | C:  36.49/30.0\n",
            "[FedSGM] it 0093/500 | switching ratio:(0.80, 0.20) | R:  20.17 | C:  18.60/30.0\n",
            "[FedSGM] it 0094/500 | switching ratio:(0.88, 0.12) | R:  19.13 | C:  17.34/30.0\n",
            "[FedSGM] it 0095/500 | switching ratio:(0.34, 0.66) | R:  33.55 | C:  26.76/30.0\n",
            "[FedSGM] it 0096/500 | switching ratio:(0.00, 1.00) | R:  73.46 | C:  43.33/30.0\n",
            "[FedSGM] it 0097/500 | switching ratio:(0.00, 1.00) | R:  70.12 | C:  35.73/30.0\n",
            "[FedSGM] it 0098/500 | switching ratio:(1.00, 0.00) | R:  16.03 | C:  13.21/30.0\n",
            "[FedSGM] it 0099/500 | switching ratio:(0.99, 0.01) | R:  28.23 | C:  17.38/30.0\n",
            "[FedSGM] it 0100/500 | switching ratio:(0.00, 1.00) | R:  74.93 | C:  34.45/30.0\n",
            "[FedSGM] it 0101/500 | switching ratio:(0.00, 1.00) | R: 115.67 | C:  41.16/30.0\n",
            "[FedSGM] it 0102/500 | switching ratio:(0.40, 0.60) | R:  61.65 | C:  24.22/30.0\n",
            "[FedSGM] it 0103/500 | switching ratio:(0.00, 1.00) | R: 123.07 | C:  36.99/30.0\n",
            "[FedSGM] it 0104/500 | switching ratio:(0.00, 1.00) | R: 100.72 | C:  31.50/30.0\n",
            "[FedSGM] it 0105/500 | switching ratio:(1.00, 0.00) | R:  18.87 | C:  12.09/30.0\n",
            "[FedSGM] it 0106/500 | switching ratio:(0.71, 0.29) | R:  52.08 | C:  20.99/30.0\n",
            "[FedSGM] it 0107/500 | switching ratio:(0.00, 1.00) | R: 117.28 | C:  37.53/30.0\n",
            "[FedSGM] it 0108/500 | switching ratio:(0.00, 1.00) | R: 168.17 | C:  50.32/30.0\n",
            "[FedSGM] it 0109/500 | switching ratio:(0.00, 1.00) | R: 165.90 | C:  50.32/30.0\n",
            "[FedSGM] it 0110/500 | switching ratio:(0.00, 1.00) | R: 180.70 | C:  52.08/30.0\n",
            "[FedSGM] it 0111/500 | switching ratio:(0.69, 0.31) | R:  56.48 | C:  21.94/30.0\n",
            "[FedSGM] it 0112/500 | switching ratio:(0.00, 1.00) | R: 114.77 | C:  38.28/30.0\n",
            "[FedSGM] it 0113/500 | switching ratio:(0.00, 1.00) | R: 109.24 | C:  38.58/30.0\n",
            "[FedSGM] it 0114/500 | switching ratio:(1.00, 0.00) | R:  32.81 | C:  15.96/30.0\n",
            "[FedSGM] it 0115/500 | switching ratio:(0.35, 0.65) | R:  62.54 | C:  24.92/30.0\n",
            "[FedSGM] it 0116/500 | switching ratio:(0.00, 1.00) | R: 120.64 | C:  41.18/30.0\n",
            "[FedSGM] it 0117/500 | switching ratio:(0.00, 1.00) | R: 137.42 | C:  46.82/30.0\n",
            "[FedSGM] it 0118/500 | switching ratio:(0.00, 1.00) | R: 106.10 | C:  37.16/30.0\n",
            "[FedSGM] it 0119/500 | switching ratio:(0.87, 0.13) | R:  37.37 | C:  17.54/30.0\n",
            "[FedSGM] it 0120/500 | switching ratio:(0.37, 0.63) | R:  64.36 | C:  25.92/30.0\n",
            "[FedSGM] it 0121/500 | switching ratio:(0.00, 1.00) | R: 126.90 | C:  45.32/30.0\n",
            "[FedSGM] it 0122/500 | switching ratio:(0.00, 1.00) | R: 128.33 | C:  44.30/30.0\n",
            "[FedSGM] it 0123/500 | switching ratio:(0.00, 1.00) | R:  90.39 | C:  33.17/30.0\n",
            "[FedSGM] it 0124/500 | switching ratio:(1.00, 0.00) | R:  27.18 | C:  14.63/30.0\n",
            "[FedSGM] it 0125/500 | switching ratio:(0.73, 0.27) | R:  46.80 | C:  20.62/30.0\n",
            "[FedSGM] it 0126/500 | switching ratio:(0.00, 1.00) | R:  83.75 | C:  32.36/30.0\n",
            "[FedSGM] it 0127/500 | switching ratio:(0.00, 1.00) | R:  97.42 | C:  36.75/30.0\n",
            "[FedSGM] it 0128/500 | switching ratio:(0.00, 1.00) | R:  94.21 | C:  35.13/30.0\n",
            "[FedSGM] it 0129/500 | switching ratio:(0.83, 0.17) | R:  35.18 | C:  17.22/30.0\n",
            "[FedSGM] it 0130/500 | switching ratio:(0.00, 1.00) | R:  72.68 | C:  29.81/30.0\n",
            "[FedSGM] it 0131/500 | switching ratio:(0.00, 1.00) | R:  88.05 | C:  32.57/30.0\n",
            "[FedSGM] it 0132/500 | switching ratio:(1.00, 0.00) | R:  30.74 | C:  15.69/30.0\n",
            "[FedSGM] it 0133/500 | switching ratio:(0.11, 0.89) | R:  73.82 | C:  28.11/30.0\n",
            "[FedSGM] it 0134/500 | switching ratio:(0.00, 1.00) | R: 119.89 | C:  43.49/30.0\n",
            "[FedSGM] it 0135/500 | switching ratio:(0.00, 1.00) | R: 102.14 | C:  36.51/30.0\n",
            "[FedSGM] it 0136/500 | switching ratio:(0.23, 0.77) | R:  69.67 | C:  26.27/30.0\n",
            "[FedSGM] it 0137/500 | switching ratio:(1.00, 0.00) | R:  16.29 | C:  11.08/30.0\n",
            "[FedSGM] it 0138/500 | switching ratio:(0.92, 0.08) | R:  38.01 | C:  17.12/30.0\n",
            "[FedSGM] it 0139/500 | switching ratio:(0.52, 0.48) | R:  59.39 | C:  23.39/30.0\n",
            "[FedSGM] it 0140/500 | switching ratio:(0.00, 1.00) | R: 114.37 | C:  40.30/30.0\n",
            "[FedSGM] it 0141/500 | switching ratio:(0.00, 1.00) | R: 140.04 | C:  48.64/30.0\n",
            "[FedSGM] it 0142/500 | switching ratio:(0.00, 1.00) | R: 139.74 | C:  48.49/30.0\n",
            "[FedSGM] it 0143/500 | switching ratio:(0.00, 1.00) | R: 138.55 | C:  46.66/30.0\n",
            "[FedSGM] it 0144/500 | switching ratio:(0.00, 1.00) | R: 137.17 | C:  47.29/30.0\n",
            "[FedSGM] it 0145/500 | switching ratio:(0.00, 1.00) | R: 132.20 | C:  45.82/30.0\n",
            "[FedSGM] it 0146/500 | switching ratio:(0.15, 0.85) | R:  77.50 | C:  28.18/30.0\n",
            "[FedSGM] it 0147/500 | switching ratio:(1.00, 0.00) | R:  31.66 | C:  15.31/30.0\n",
            "[FedSGM] it 0148/500 | switching ratio:(1.00, 0.00) | R:  25.77 | C:  13.86/30.0\n",
            "[FedSGM] it 0149/500 | switching ratio:(0.67, 0.33) | R:  50.04 | C:  20.91/30.0\n",
            "[FedSGM] it 0150/500 | switching ratio:(0.00, 1.00) | R:  98.59 | C:  35.17/30.0\n",
            "[FedSGM] it 0151/500 | switching ratio:(0.00, 1.00) | R: 122.43 | C:  42.93/30.0\n",
            "[FedSGM] it 0152/500 | switching ratio:(0.00, 1.00) | R: 128.53 | C:  43.82/30.0\n",
            "[FedSGM] it 0153/500 | switching ratio:(0.00, 1.00) | R: 119.35 | C:  41.22/30.0\n",
            "[FedSGM] it 0154/500 | switching ratio:(0.00, 1.00) | R:  89.76 | C:  32.61/30.0\n",
            "[FedSGM] it 0155/500 | switching ratio:(0.91, 0.09) | R:  37.76 | C:  17.24/30.0\n",
            "[FedSGM] it 0156/500 | switching ratio:(1.00, 0.00) | R:  30.77 | C:  15.47/30.0\n",
            "[FedSGM] it 0157/500 | switching ratio:(0.62, 0.38) | R:  58.87 | C:  22.84/30.0\n",
            "[FedSGM] it 0158/500 | switching ratio:(0.00, 1.00) | R: 105.05 | C:  36.75/30.0\n",
            "[FedSGM] it 0159/500 | switching ratio:(0.00, 1.00) | R: 138.00 | C:  48.38/30.0\n",
            "[FedSGM] it 0160/500 | switching ratio:(0.00, 1.00) | R: 135.31 | C:  47.39/30.0\n",
            "[FedSGM] it 0161/500 | switching ratio:(0.00, 1.00) | R: 134.86 | C:  47.80/30.0\n",
            "[FedSGM] it 0162/500 | switching ratio:(0.00, 1.00) | R: 107.18 | C:  37.31/30.0\n",
            "[FedSGM] it 0163/500 | switching ratio:(1.00, 0.00) | R:  30.26 | C:  15.36/30.0\n",
            "[FedSGM] it 0164/500 | switching ratio:(0.74, 0.26) | R:  47.07 | C:  20.09/30.0\n",
            "[FedSGM] it 0165/500 | switching ratio:(0.00, 1.00) | R:  90.74 | C:  33.86/30.0\n",
            "[FedSGM] it 0166/500 | switching ratio:(0.00, 1.00) | R: 127.18 | C:  45.36/30.0\n",
            "[FedSGM] it 0167/500 | switching ratio:(0.00, 1.00) | R: 130.22 | C:  46.57/30.0\n",
            "[FedSGM] it 0168/500 | switching ratio:(0.00, 1.00) | R: 127.04 | C:  45.89/30.0\n",
            "[FedSGM] it 0169/500 | switching ratio:(0.00, 1.00) | R:  77.24 | C:  30.49/30.0\n",
            "[FedSGM] it 0170/500 | switching ratio:(0.91, 0.09) | R:  38.12 | C:  17.64/30.0\n",
            "[FedSGM] it 0171/500 | switching ratio:(0.86, 0.14) | R:  45.92 | C:  19.99/30.0\n",
            "[FedSGM] it 0172/500 | switching ratio:(0.31, 0.69) | R:  65.72 | C:  26.33/30.0\n",
            "[FedSGM] it 0173/500 | switching ratio:(0.00, 1.00) | R: 110.00 | C:  40.68/30.0\n",
            "[FedSGM] it 0174/500 | switching ratio:(0.00, 1.00) | R: 124.23 | C:  45.84/30.0\n",
            "[FedSGM] it 0175/500 | switching ratio:(0.00, 1.00) | R: 126.81 | C:  45.43/30.0\n",
            "[FedSGM] it 0176/500 | switching ratio:(0.00, 1.00) | R: 125.24 | C:  45.85/30.0\n",
            "[FedSGM] it 0177/500 | switching ratio:(0.00, 1.00) | R:  85.89 | C:  32.15/30.0\n",
            "[FedSGM] it 0178/500 | switching ratio:(0.96, 0.04) | R:  36.26 | C:  16.77/30.0\n",
            "[FedSGM] it 0179/500 | switching ratio:(1.00, 0.00) | R:  32.46 | C:  15.70/30.0\n",
            "[FedSGM] it 0180/500 | switching ratio:(0.16, 0.84) | R:  74.32 | C:  28.60/30.0\n",
            "[FedSGM] it 0181/500 | switching ratio:(0.00, 1.00) | R: 102.64 | C:  36.81/30.0\n",
            "[FedSGM] it 0182/500 | switching ratio:(0.00, 1.00) | R: 112.03 | C:  39.84/30.0\n",
            "[FedSGM] it 0183/500 | switching ratio:(0.00, 1.00) | R: 107.12 | C:  38.09/30.0\n",
            "[FedSGM] it 0184/500 | switching ratio:(0.24, 0.76) | R:  66.77 | C:  26.19/30.0\n",
            "[FedSGM] it 0185/500 | switching ratio:(0.92, 0.08) | R:  39.38 | C:  17.64/30.0\n",
            "[FedSGM] it 0186/500 | switching ratio:(0.73, 0.27) | R:  53.32 | C:  21.77/30.0\n",
            "[FedSGM] it 0187/500 | switching ratio:(0.00, 1.00) | R:  91.69 | C:  33.64/30.0\n",
            "[FedSGM] it 0188/500 | switching ratio:(0.00, 1.00) | R: 116.14 | C:  41.56/30.0\n",
            "[FedSGM] it 0189/500 | switching ratio:(0.00, 1.00) | R: 124.63 | C:  45.01/30.0\n",
            "[FedSGM] it 0190/500 | switching ratio:(0.00, 1.00) | R: 125.92 | C:  44.17/30.0\n",
            "[FedSGM] it 0191/500 | switching ratio:(0.00, 1.00) | R:  88.65 | C:  32.62/30.0\n",
            "[FedSGM] it 0192/500 | switching ratio:(0.58, 0.42) | R:  52.45 | C:  21.17/30.0\n",
            "[FedSGM] it 0193/500 | switching ratio:(1.00, 0.00) | R:  33.45 | C:  15.67/30.0\n",
            "[FedSGM] it 0194/500 | switching ratio:(0.55, 0.45) | R:  59.26 | C:  23.21/30.0\n",
            "[FedSGM] it 0195/500 | switching ratio:(0.00, 1.00) | R:  99.92 | C:  35.09/30.0\n",
            "[FedSGM] it 0196/500 | switching ratio:(0.00, 1.00) | R: 101.45 | C:  36.22/30.0\n",
            "[FedSGM] it 0197/500 | switching ratio:(0.00, 1.00) | R: 109.76 | C:  38.28/30.0\n",
            "[FedSGM] it 0198/500 | switching ratio:(0.00, 1.00) | R:  93.93 | C:  34.28/30.0\n",
            "[FedSGM] it 0199/500 | switching ratio:(0.40, 0.60) | R:  60.36 | C:  23.45/30.0\n",
            "[FedSGM] it 0200/500 | switching ratio:(1.00, 0.00) | R:  32.18 | C:  15.31/30.0\n",
            "[FedSGM] it 0201/500 | switching ratio:(0.59, 0.41) | R:  54.72 | C:  21.76/30.0\n",
            "[FedSGM] it 0202/500 | switching ratio:(0.00, 1.00) | R: 109.27 | C:  37.90/30.0\n",
            "[FedSGM] it 0203/500 | switching ratio:(0.00, 1.00) | R: 126.92 | C:  43.78/30.0\n",
            "[FedSGM] it 0204/500 | switching ratio:(0.00, 1.00) | R: 129.28 | C:  45.49/30.0\n",
            "[FedSGM] it 0205/500 | switching ratio:(0.00, 1.00) | R: 126.68 | C:  43.73/30.0\n",
            "[FedSGM] it 0206/500 | switching ratio:(0.00, 1.00) | R:  94.11 | C:  34.10/30.0\n",
            "[FedSGM] it 0207/500 | switching ratio:(0.23, 0.77) | R:  73.99 | C:  27.26/30.0\n",
            "[FedSGM] it 0208/500 | switching ratio:(1.00, 0.00) | R:  34.38 | C:  15.79/30.0\n",
            "[FedSGM] it 0209/500 | switching ratio:(1.00, 0.00) | R:  29.54 | C:  14.64/30.0\n",
            "[FedSGM] it 0210/500 | switching ratio:(0.40, 0.60) | R:  65.23 | C:  24.95/30.0\n",
            "[FedSGM] it 0211/500 | switching ratio:(0.00, 1.00) | R: 113.72 | C:  39.65/30.0\n",
            "[FedSGM] it 0212/500 | switching ratio:(0.00, 1.00) | R: 124.78 | C:  43.68/30.0\n",
            "[FedSGM] it 0213/500 | switching ratio:(0.00, 1.00) | R: 132.32 | C:  45.75/30.0\n",
            "[FedSGM] it 0214/500 | switching ratio:(0.00, 1.00) | R: 129.65 | C:  44.98/30.0\n",
            "[FedSGM] it 0215/500 | switching ratio:(0.00, 1.00) | R: 132.07 | C:  46.54/30.0\n",
            "[FedSGM] it 0216/500 | switching ratio:(0.00, 1.00) | R:  88.87 | C:  32.03/30.0\n",
            "[FedSGM] it 0217/500 | switching ratio:(0.56, 0.44) | R:  59.89 | C:  23.10/30.0\n",
            "[FedSGM] it 0218/500 | switching ratio:(0.51, 0.49) | R:  59.20 | C:  23.33/30.0\n",
            "[FedSGM] it 0219/500 | switching ratio:(0.00, 1.00) | R:  88.75 | C:  31.13/30.0\n",
            "[FedSGM] it 0220/500 | switching ratio:(0.00, 1.00) | R:  92.33 | C:  33.24/30.0\n",
            "[FedSGM] it 0221/500 | switching ratio:(0.75, 0.25) | R:  46.55 | C:  19.31/30.0\n",
            "[FedSGM] it 0222/500 | switching ratio:(0.00, 1.00) | R:  85.87 | C:  31.23/30.0\n",
            "[FedSGM] it 0223/500 | switching ratio:(0.00, 1.00) | R:  90.26 | C:  32.55/30.0\n",
            "[FedSGM] it 0224/500 | switching ratio:(0.28, 0.72) | R:  68.99 | C:  25.95/30.0\n",
            "[FedSGM] it 0225/500 | switching ratio:(0.78, 0.22) | R:  47.90 | C:  19.94/30.0\n",
            "[FedSGM] it 0226/500 | switching ratio:(0.05, 0.95) | R:  82.73 | C:  30.32/30.0\n",
            "[FedSGM] it 0227/500 | switching ratio:(0.00, 1.00) | R:  99.20 | C:  35.80/30.0\n",
            "[FedSGM] it 0228/500 | switching ratio:(0.00, 1.00) | R:  94.58 | C:  34.41/30.0\n",
            "[FedSGM] it 0229/500 | switching ratio:(0.40, 0.60) | R:  63.52 | C:  24.69/30.0\n",
            "[FedSGM] it 0230/500 | switching ratio:(0.87, 0.13) | R:  43.22 | C:  18.58/30.0\n",
            "[FedSGM] it 0231/500 | switching ratio:(0.30, 0.70) | R:  61.60 | C:  25.47/30.0\n",
            "[FedSGM] it 0232/500 | switching ratio:(0.00, 1.00) | R: 112.51 | C:  39.11/30.0\n",
            "[FedSGM] it 0233/500 | switching ratio:(0.00, 1.00) | R: 104.72 | C:  39.03/30.0\n",
            "[FedSGM] it 0234/500 | switching ratio:(0.00, 1.00) | R:  96.69 | C:  35.12/30.0\n",
            "[FedSGM] it 0235/500 | switching ratio:(0.59, 0.41) | R:  54.49 | C:  22.24/30.0\n",
            "[FedSGM] it 0236/500 | switching ratio:(0.45, 0.55) | R:  58.76 | C:  23.29/30.0\n",
            "[FedSGM] it 0237/500 | switching ratio:(0.00, 1.00) | R: 105.39 | C:  38.66/30.0\n",
            "[FedSGM] it 0238/500 | switching ratio:(0.00, 1.00) | R: 116.39 | C:  40.39/30.0\n",
            "[FedSGM] it 0239/500 | switching ratio:(0.00, 1.00) | R:  95.28 | C:  33.98/30.0\n",
            "[FedSGM] it 0240/500 | switching ratio:(0.28, 0.72) | R:  69.75 | C:  25.89/30.0\n",
            "[FedSGM] it 0241/500 | switching ratio:(1.00, 0.00) | R:  29.77 | C:  14.50/30.0\n",
            "[FedSGM] it 0242/500 | switching ratio:(0.90, 0.10) | R:  40.34 | C:  17.43/30.0\n",
            "[FedSGM] it 0243/500 | switching ratio:(0.38, 0.62) | R:  71.82 | C:  26.43/30.0\n",
            "[FedSGM] it 0244/500 | switching ratio:(0.00, 1.00) | R:  95.45 | C:  33.77/30.0\n",
            "[FedSGM] it 0245/500 | switching ratio:(0.00, 1.00) | R: 122.36 | C:  41.48/30.0\n",
            "[FedSGM] it 0246/500 | switching ratio:(0.00, 1.00) | R: 130.67 | C:  43.92/30.0\n",
            "[FedSGM] it 0247/500 | switching ratio:(0.00, 1.00) | R: 122.89 | C:  42.19/30.0\n",
            "[FedSGM] it 0248/500 | switching ratio:(0.37, 0.63) | R:  68.14 | C:  25.79/30.0\n",
            "[FedSGM] it 0249/500 | switching ratio:(0.66, 0.34) | R:  53.99 | C:  21.45/30.0\n",
            "[FedSGM] it 0250/500 | switching ratio:(0.75, 0.25) | R:  51.14 | C:  20.64/30.0\n",
            "[FedSGM] it 0251/500 | switching ratio:(0.14, 0.86) | R:  76.53 | C:  28.48/30.0\n",
            "[FedSGM] it 0252/500 | switching ratio:(0.00, 1.00) | R: 109.76 | C:  38.43/30.0\n",
            "[FedSGM] it 0253/500 | switching ratio:(0.00, 1.00) | R: 110.25 | C:  38.57/30.0\n",
            "[FedSGM] it 0254/500 | switching ratio:(0.01, 0.99) | R:  82.92 | C:  30.81/30.0\n",
            "[FedSGM] it 0255/500 | switching ratio:(0.70, 0.30) | R:  52.27 | C:  21.10/30.0\n",
            "[FedSGM] it 0256/500 | switching ratio:(0.38, 0.62) | R:  69.39 | C:  26.11/30.0\n",
            "[FedSGM] it 0257/500 | switching ratio:(0.00, 1.00) | R:  99.85 | C:  35.29/30.0\n",
            "[FedSGM] it 0258/500 | switching ratio:(0.00, 1.00) | R: 109.32 | C:  38.29/30.0\n",
            "[FedSGM] it 0259/500 | switching ratio:(0.19, 0.81) | R:  76.08 | C:  28.31/30.0\n",
            "[FedSGM] it 0260/500 | switching ratio:(0.70, 0.30) | R:  46.88 | C:  19.43/30.0\n",
            "[FedSGM] it 0261/500 | switching ratio:(0.39, 0.61) | R:  67.42 | C:  25.35/30.0\n",
            "[FedSGM] it 0262/500 | switching ratio:(0.00, 1.00) | R: 108.88 | C:  38.21/30.0\n",
            "[FedSGM] it 0263/500 | switching ratio:(0.00, 1.00) | R: 112.87 | C:  38.56/30.0\n",
            "[FedSGM] it 0264/500 | switching ratio:(0.00, 1.00) | R:  90.79 | C:  32.22/30.0\n",
            "[FedSGM] it 0265/500 | switching ratio:(0.27, 0.73) | R:  70.17 | C:  25.95/30.0\n",
            "[FedSGM] it 0266/500 | switching ratio:(1.00, 0.00) | R:  31.87 | C:  15.22/30.0\n",
            "[FedSGM] it 0267/500 | switching ratio:(0.74, 0.26) | R:  50.85 | C:  20.42/30.0\n",
            "[FedSGM] it 0268/500 | switching ratio:(0.13, 0.87) | R:  78.20 | C:  28.61/30.0\n",
            "[FedSGM] it 0269/500 | switching ratio:(0.00, 1.00) | R: 118.02 | C:  40.71/30.0\n",
            "[FedSGM] it 0270/500 | switching ratio:(0.00, 1.00) | R: 110.87 | C:  38.43/30.0\n",
            "[FedSGM] it 0271/500 | switching ratio:(0.00, 1.00) | R: 109.82 | C:  38.46/30.0\n",
            "[FedSGM] it 0272/500 | switching ratio:(0.17, 0.83) | R:  80.54 | C:  28.97/30.0\n",
            "[FedSGM] it 0273/500 | switching ratio:(0.88, 0.12) | R:  48.42 | C:  19.56/30.0\n",
            "[FedSGM] it 0274/500 | switching ratio:(0.15, 0.85) | R:  78.22 | C:  28.32/30.0\n",
            "[FedSGM] it 0275/500 | switching ratio:(0.00, 1.00) | R: 119.68 | C:  41.27/30.0\n",
            "[FedSGM] it 0276/500 | switching ratio:(0.00, 1.00) | R: 110.30 | C:  38.13/30.0\n",
            "[FedSGM] it 0277/500 | switching ratio:(0.00, 1.00) | R: 115.22 | C:  38.83/30.0\n",
            "[FedSGM] it 0278/500 | switching ratio:(0.48, 0.52) | R:  59.08 | C:  22.74/30.0\n",
            "[FedSGM] it 0279/500 | switching ratio:(0.76, 0.24) | R:  49.29 | C:  19.90/30.0\n",
            "[FedSGM] it 0280/500 | switching ratio:(0.03, 0.97) | R:  86.56 | C:  30.21/30.0\n",
            "[FedSGM] it 0281/500 | switching ratio:(0.00, 1.00) | R: 108.45 | C:  37.21/30.0\n",
            "[FedSGM] it 0282/500 | switching ratio:(0.00, 1.00) | R: 102.07 | C:  35.35/30.0\n",
            "[FedSGM] it 0283/500 | switching ratio:(0.64, 0.36) | R:  52.83 | C:  21.09/30.0\n",
            "[FedSGM] it 0284/500 | switching ratio:(0.45, 0.55) | R:  68.80 | C:  24.78/30.0\n",
            "[FedSGM] it 0285/500 | switching ratio:(0.00, 1.00) | R: 108.99 | C:  37.05/30.0\n",
            "[FedSGM] it 0286/500 | switching ratio:(0.00, 1.00) | R: 106.58 | C:  35.72/30.0\n",
            "[FedSGM] it 0287/500 | switching ratio:(0.44, 0.56) | R:  68.60 | C:  24.70/30.0\n",
            "[FedSGM] it 0288/500 | switching ratio:(0.00, 1.00) | R: 101.70 | C:  34.32/30.0\n",
            "[FedSGM] it 0289/500 | switching ratio:(0.15, 0.85) | R:  78.50 | C:  27.47/30.0\n",
            "[FedSGM] it 0290/500 | switching ratio:(0.99, 0.01) | R:  33.80 | C:  15.43/30.0\n",
            "[FedSGM] it 0291/500 | switching ratio:(0.44, 0.56) | R:  64.18 | C:  23.95/30.0\n",
            "[FedSGM] it 0292/500 | switching ratio:(0.00, 1.00) | R: 121.57 | C:  39.32/30.0\n",
            "[FedSGM] it 0293/500 | switching ratio:(0.00, 1.00) | R: 142.17 | C:  45.51/30.0\n",
            "[FedSGM] it 0294/500 | switching ratio:(0.00, 1.00) | R: 139.76 | C:  45.97/30.0\n",
            "[FedSGM] it 0295/500 | switching ratio:(0.00, 1.00) | R: 144.39 | C:  47.46/30.0\n",
            "[FedSGM] it 0296/500 | switching ratio:(0.00, 1.00) | R: 121.25 | C:  39.39/30.0\n",
            "[FedSGM] it 0297/500 | switching ratio:(0.55, 0.45) | R:  67.12 | C:  23.83/30.0\n",
            "[FedSGM] it 0298/500 | switching ratio:(1.00, 0.00) | R:  32.82 | C:  14.89/30.0\n",
            "[FedSGM] it 0299/500 | switching ratio:(0.53, 0.47) | R:  62.35 | C:  22.32/30.0\n",
            "[FedSGM] it 0300/500 | switching ratio:(0.00, 1.00) | R: 121.22 | C:  38.85/30.0\n",
            "[FedSGM] it 0301/500 | switching ratio:(0.00, 1.00) | R: 124.01 | C:  40.15/30.0\n",
            "[FedSGM] it 0302/500 | switching ratio:(0.00, 1.00) | R: 109.42 | C:  35.27/30.0\n",
            "[FedSGM] it 0303/500 | switching ratio:(0.00, 1.00) | R:  94.32 | C:  31.83/30.0\n",
            "[FedSGM] it 0304/500 | switching ratio:(0.39, 0.61) | R:  76.06 | C:  26.10/30.0\n",
            "[FedSGM] it 0305/500 | switching ratio:(1.00, 0.00) | R:  35.24 | C:  15.64/30.0\n",
            "[FedSGM] it 0306/500 | switching ratio:(0.13, 0.87) | R:  83.29 | C:  28.44/30.0\n",
            "[FedSGM] it 0307/500 | switching ratio:(0.00, 1.00) | R: 131.44 | C:  42.41/30.0\n",
            "[FedSGM] it 0308/500 | switching ratio:(0.00, 1.00) | R: 130.82 | C:  42.22/30.0\n",
            "[FedSGM] it 0309/500 | switching ratio:(0.00, 1.00) | R: 129.82 | C:  41.69/30.0\n",
            "[FedSGM] it 0310/500 | switching ratio:(0.06, 0.94) | R:  87.52 | C:  29.70/30.0\n",
            "[FedSGM] it 0311/500 | switching ratio:(0.61, 0.39) | R:  57.39 | C:  21.31/30.0\n",
            "[FedSGM] it 0312/500 | switching ratio:(0.91, 0.09) | R:  36.02 | C:  15.98/30.0\n",
            "[FedSGM] it 0313/500 | switching ratio:(0.38, 0.62) | R:  76.82 | C:  26.77/30.0\n",
            "[FedSGM] it 0314/500 | switching ratio:(0.00, 1.00) | R: 116.26 | C:  38.54/30.0\n",
            "[FedSGM] it 0315/500 | switching ratio:(0.00, 1.00) | R: 121.62 | C:  39.69/30.0\n",
            "[FedSGM] it 0316/500 | switching ratio:(0.00, 1.00) | R: 141.91 | C:  45.41/30.0\n",
            "[FedSGM] it 0317/500 | switching ratio:(0.00, 1.00) | R: 140.43 | C:  46.24/30.0\n",
            "[FedSGM] it 0318/500 | switching ratio:(0.00, 1.00) | R: 129.00 | C:  40.97/30.0\n",
            "[FedSGM] it 0319/500 | switching ratio:(0.52, 0.48) | R:  63.48 | C:  22.94/30.0\n",
            "[FedSGM] it 0320/500 | switching ratio:(1.00, 0.00) | R:  31.69 | C:  14.67/30.0\n",
            "[FedSGM] it 0321/500 | switching ratio:(0.37, 0.63) | R:  75.33 | C:  26.24/30.0\n",
            "[FedSGM] it 0322/500 | switching ratio:(0.00, 1.00) | R: 135.41 | C:  44.66/30.0\n",
            "[FedSGM] it 0323/500 | switching ratio:(0.00, 1.00) | R: 143.57 | C:  45.97/30.0\n",
            "[FedSGM] it 0324/500 | switching ratio:(0.00, 1.00) | R: 139.54 | C:  44.52/30.0\n",
            "[FedSGM] it 0325/500 | switching ratio:(0.00, 1.00) | R: 125.13 | C:  40.38/30.0\n",
            "[FedSGM] it 0326/500 | switching ratio:(0.20, 0.80) | R:  81.12 | C:  27.13/30.0\n",
            "[FedSGM] it 0327/500 | switching ratio:(1.00, 0.00) | R:  25.43 | C:  13.08/30.0\n",
            "[FedSGM] it 0328/500 | switching ratio:(0.84, 0.16) | R:  47.44 | C:  18.41/30.0\n",
            "[FedSGM] it 0329/500 | switching ratio:(0.00, 1.00) | R: 110.42 | C:  34.73/30.0\n",
            "[FedSGM] it 0330/500 | switching ratio:(0.00, 1.00) | R: 148.08 | C:  46.82/30.0\n",
            "[FedSGM] it 0331/500 | switching ratio:(0.00, 1.00) | R: 140.02 | C:  44.50/30.0\n",
            "[FedSGM] it 0332/500 | switching ratio:(0.00, 1.00) | R: 146.11 | C:  45.94/30.0\n",
            "[FedSGM] it 0333/500 | switching ratio:(0.00, 1.00) | R: 146.03 | C:  46.04/30.0\n",
            "[FedSGM] it 0334/500 | switching ratio:(0.00, 1.00) | R: 145.59 | C:  45.37/30.0\n",
            "[FedSGM] it 0335/500 | switching ratio:(0.54, 0.46) | R:  62.13 | C:  22.46/30.0\n",
            "[FedSGM] it 0336/500 | switching ratio:(1.00, 0.00) | R:  25.45 | C:  13.13/30.0\n",
            "[FedSGM] it 0337/500 | switching ratio:(0.56, 0.44) | R:  66.28 | C:  23.35/30.0\n",
            "[FedSGM] it 0338/500 | switching ratio:(0.00, 1.00) | R: 133.38 | C:  41.69/30.0\n",
            "[FedSGM] it 0339/500 | switching ratio:(0.00, 1.00) | R: 152.69 | C:  47.71/30.0\n",
            "[FedSGM] it 0340/500 | switching ratio:(0.00, 1.00) | R: 149.14 | C:  46.33/30.0\n",
            "[FedSGM] it 0341/500 | switching ratio:(0.00, 1.00) | R: 154.80 | C:  48.49/30.0\n",
            "[FedSGM] it 0342/500 | switching ratio:(0.00, 1.00) | R: 150.58 | C:  46.73/30.0\n",
            "[FedSGM] it 0343/500 | switching ratio:(0.00, 1.00) | R: 123.98 | C:  37.55/30.0\n",
            "[FedSGM] it 0344/500 | switching ratio:(0.84, 0.16) | R:  47.27 | C:  18.25/30.0\n",
            "[FedSGM] it 0345/500 | switching ratio:(0.75, 0.25) | R:  51.01 | C:  19.07/30.0\n",
            "[FedSGM] it 0346/500 | switching ratio:(0.00, 1.00) | R: 118.56 | C:  36.93/30.0\n",
            "[FedSGM] it 0347/500 | switching ratio:(0.00, 1.00) | R: 154.59 | C:  47.71/30.0\n",
            "[FedSGM] it 0348/500 | switching ratio:(0.00, 1.00) | R: 153.69 | C:  47.29/30.0\n",
            "[FedSGM] it 0349/500 | switching ratio:(0.00, 1.00) | R: 152.94 | C:  46.43/30.0\n",
            "[FedSGM] it 0350/500 | switching ratio:(0.00, 1.00) | R: 149.06 | C:  46.29/30.0\n",
            "[FedSGM] it 0351/500 | switching ratio:(0.00, 1.00) | R: 143.01 | C:  43.37/30.0\n",
            "[FedSGM] it 0352/500 | switching ratio:(0.51, 0.49) | R:  69.46 | C:  23.24/30.0\n",
            "[FedSGM] it 0353/500 | switching ratio:(1.00, 0.00) | R:  34.82 | C:  15.00/30.0\n",
            "[FedSGM] it 0354/500 | switching ratio:(0.31, 0.69) | R:  81.01 | C:  26.40/30.0\n",
            "[FedSGM] it 0355/500 | switching ratio:(0.00, 1.00) | R: 151.96 | C:  45.71/30.0\n",
            "[FedSGM] it 0356/500 | switching ratio:(0.00, 1.00) | R: 158.14 | C:  48.33/30.0\n",
            "[FedSGM] it 0357/500 | switching ratio:(0.00, 1.00) | R: 158.82 | C:  48.08/30.0\n",
            "[FedSGM] it 0358/500 | switching ratio:(0.00, 1.00) | R: 153.74 | C:  45.67/30.0\n",
            "[FedSGM] it 0359/500 | switching ratio:(0.01, 0.99) | R:  94.74 | C:  29.55/30.0\n",
            "[FedSGM] it 0360/500 | switching ratio:(0.94, 0.06) | R:  46.59 | C:  17.39/30.0\n",
            "[FedSGM] it 0361/500 | switching ratio:(0.44, 0.56) | R:  71.06 | C:  24.11/30.0\n",
            "[FedSGM] it 0362/500 | switching ratio:(0.00, 1.00) | R: 142.05 | C:  41.37/30.0\n",
            "[FedSGM] it 0363/500 | switching ratio:(0.00, 1.00) | R: 157.25 | C:  45.48/30.0\n",
            "[FedSGM] it 0364/500 | switching ratio:(0.00, 1.00) | R: 160.20 | C:  46.47/30.0\n",
            "[FedSGM] it 0365/500 | switching ratio:(0.00, 1.00) | R: 155.58 | C:  45.73/30.0\n",
            "[FedSGM] it 0366/500 | switching ratio:(0.37, 0.63) | R:  79.16 | C:  25.49/30.0\n",
            "[FedSGM] it 0367/500 | switching ratio:(0.94, 0.06) | R:  41.29 | C:  16.42/30.0\n",
            "[FedSGM] it 0368/500 | switching ratio:(0.58, 0.42) | R:  68.73 | C:  22.87/30.0\n",
            "[FedSGM] it 0369/500 | switching ratio:(0.00, 1.00) | R: 145.04 | C:  42.64/30.0\n",
            "[FedSGM] it 0370/500 | switching ratio:(0.00, 1.00) | R: 161.06 | C:  47.06/30.0\n",
            "[FedSGM] it 0371/500 | switching ratio:(0.00, 1.00) | R: 157.74 | C:  46.23/30.0\n",
            "[FedSGM] it 0372/500 | switching ratio:(0.00, 1.00) | R: 162.95 | C:  47.61/30.0\n",
            "[FedSGM] it 0373/500 | switching ratio:(0.00, 1.00) | R: 140.08 | C:  41.51/30.0\n",
            "[FedSGM] it 0374/500 | switching ratio:(0.23, 0.77) | R:  87.68 | C:  27.71/30.0\n",
            "[FedSGM] it 0375/500 | switching ratio:(1.00, 0.00) | R:  34.81 | C:  14.76/30.0\n",
            "[FedSGM] it 0376/500 | switching ratio:(0.79, 0.21) | R:  51.99 | C:  18.93/30.0\n",
            "[FedSGM] it 0377/500 | switching ratio:(0.00, 1.00) | R: 127.19 | C:  37.52/30.0\n",
            "[FedSGM] it 0378/500 | switching ratio:(0.00, 1.00) | R: 154.33 | C:  45.16/30.0\n",
            "[FedSGM] it 0379/500 | switching ratio:(0.00, 1.00) | R: 155.53 | C:  46.87/30.0\n",
            "[FedSGM] it 0380/500 | switching ratio:(0.00, 1.00) | R: 159.49 | C:  46.09/30.0\n",
            "[FedSGM] it 0381/500 | switching ratio:(0.00, 1.00) | R: 161.27 | C:  47.74/30.0\n",
            "[FedSGM] it 0382/500 | switching ratio:(0.00, 1.00) | R: 167.30 | C:  48.74/30.0\n",
            "[FedSGM] it 0383/500 | switching ratio:(0.00, 1.00) | R: 134.50 | C:  39.15/30.0\n",
            "[FedSGM] it 0384/500 | switching ratio:(0.75, 0.25) | R:  55.97 | C:  19.64/30.0\n",
            "[FedSGM] it 0385/500 | switching ratio:(0.64, 0.36) | R:  59.60 | C:  20.81/30.0\n",
            "[FedSGM] it 0386/500 | switching ratio:(0.00, 1.00) | R: 140.40 | C:  39.37/30.0\n",
            "[FedSGM] it 0387/500 | switching ratio:(0.00, 1.00) | R: 162.01 | C:  46.52/30.0\n",
            "[FedSGM] it 0388/500 | switching ratio:(0.00, 1.00) | R: 163.36 | C:  44.64/30.0\n",
            "[FedSGM] it 0389/500 | switching ratio:(0.00, 1.00) | R: 155.81 | C:  43.43/30.0\n",
            "[FedSGM] it 0390/500 | switching ratio:(0.00, 1.00) | R: 128.74 | C:  36.43/30.0\n",
            "[FedSGM] it 0391/500 | switching ratio:(0.47, 0.53) | R:  78.75 | C:  23.95/30.0\n",
            "[FedSGM] it 0392/500 | switching ratio:(0.95, 0.05) | R:  43.55 | C:  16.59/30.0\n",
            "[FedSGM] it 0393/500 | switching ratio:(0.53, 0.47) | R:  79.95 | C:  24.66/30.0\n",
            "[FedSGM] it 0394/500 | switching ratio:(0.00, 1.00) | R: 140.47 | C:  39.14/30.0\n",
            "[FedSGM] it 0395/500 | switching ratio:(0.00, 1.00) | R: 165.08 | C:  45.33/30.0\n",
            "[FedSGM] it 0396/500 | switching ratio:(0.00, 1.00) | R: 158.42 | C:  44.25/30.0\n",
            "[FedSGM] it 0397/500 | switching ratio:(0.00, 1.00) | R: 150.57 | C:  42.30/30.0\n",
            "[FedSGM] it 0398/500 | switching ratio:(0.00, 1.00) | R: 139.01 | C:  38.76/30.0\n",
            "[FedSGM] it 0399/500 | switching ratio:(0.72, 0.28) | R:  63.42 | C:  20.95/30.0\n",
            "[FedSGM] it 0400/500 | switching ratio:(0.38, 0.62) | R:  78.52 | C:  23.97/30.0\n",
            "[FedSGM] it 0401/500 | switching ratio:(0.00, 1.00) | R: 142.77 | C:  38.84/30.0\n",
            "[FedSGM] it 0402/500 | switching ratio:(0.00, 1.00) | R: 161.66 | C:  44.12/30.0\n",
            "[FedSGM] it 0403/500 | switching ratio:(0.00, 1.00) | R: 161.83 | C:  44.60/30.0\n",
            "[FedSGM] it 0404/500 | switching ratio:(0.00, 1.00) | R: 127.69 | C:  35.11/30.0\n",
            "[FedSGM] it 0405/500 | switching ratio:(0.93, 0.07) | R:  49.16 | C:  17.37/30.0\n",
            "[FedSGM] it 0406/500 | switching ratio:(0.48, 0.52) | R:  80.74 | C:  24.19/30.0\n",
            "[FedSGM] it 0407/500 | switching ratio:(0.00, 1.00) | R: 145.39 | C:  40.24/30.0\n",
            "[FedSGM] it 0408/500 | switching ratio:(0.00, 1.00) | R: 167.46 | C:  45.00/30.0\n",
            "[FedSGM] it 0409/500 | switching ratio:(0.00, 1.00) | R: 166.09 | C:  44.00/30.0\n",
            "[FedSGM] it 0410/500 | switching ratio:(0.00, 1.00) | R: 156.36 | C:  41.17/30.0\n",
            "[FedSGM] it 0411/500 | switching ratio:(0.22, 0.78) | R:  98.97 | C:  27.92/30.0\n",
            "[FedSGM] it 0412/500 | switching ratio:(0.54, 0.46) | R:  80.90 | C:  23.30/30.0\n",
            "[FedSGM] it 0413/500 | switching ratio:(0.00, 1.00) | R: 116.15 | C:  30.47/30.0\n",
            "[FedSGM] it 0414/500 | switching ratio:(0.82, 0.18) | R:  57.22 | C:  18.41/30.0\n",
            "[FedSGM] it 0415/500 | switching ratio:(0.00, 1.00) | R: 119.90 | C:  31.76/30.0\n",
            "[FedSGM] it 0416/500 | switching ratio:(0.00, 1.00) | R: 159.77 | C:  42.59/30.0\n",
            "[FedSGM] it 0417/500 | switching ratio:(0.00, 1.00) | R: 157.80 | C:  42.33/30.0\n",
            "[FedSGM] it 0418/500 | switching ratio:(0.00, 1.00) | R: 119.78 | C:  31.37/30.0\n",
            "[FedSGM] it 0419/500 | switching ratio:(0.44, 0.56) | R:  86.46 | C:  24.46/30.0\n",
            "[FedSGM] it 0420/500 | switching ratio:(0.07, 0.93) | R: 109.18 | C:  28.91/30.0\n",
            "[FedSGM] it 0421/500 | switching ratio:(0.82, 0.18) | R:  64.43 | C:  20.04/30.0\n",
            "[FedSGM] it 0422/500 | switching ratio:(0.00, 1.00) | R: 132.98 | C:  34.02/30.0\n",
            "[FedSGM] it 0423/500 | switching ratio:(0.00, 1.00) | R: 131.10 | C:  32.75/30.0\n",
            "[FedSGM] it 0424/500 | switching ratio:(0.00, 1.00) | R: 129.36 | C:  32.97/30.0\n",
            "[FedSGM] it 0425/500 | switching ratio:(0.13, 0.87) | R: 110.42 | C:  28.08/30.0\n",
            "[FedSGM] it 0426/500 | switching ratio:(0.50, 0.50) | R:  88.02 | C:  23.65/30.0\n",
            "[FedSGM] it 0427/500 | switching ratio:(0.21, 0.79) | R: 106.22 | C:  27.50/30.0\n",
            "[FedSGM] it 0428/500 | switching ratio:(0.00, 1.00) | R: 139.56 | C:  34.54/30.0\n",
            "[FedSGM] it 0429/500 | switching ratio:(0.15, 0.85) | R: 118.16 | C:  29.74/30.0\n",
            "[FedSGM] it 0430/500 | switching ratio:(0.16, 0.84) | R: 108.70 | C:  27.34/30.0\n",
            "[FedSGM] it 0431/500 | switching ratio:(0.07, 0.93) | R: 114.93 | C:  28.46/30.0\n",
            "[FedSGM] it 0432/500 | switching ratio:(0.61, 0.39) | R:  75.24 | C:  20.94/30.0\n",
            "[FedSGM] it 0433/500 | switching ratio:(0.28, 0.72) | R: 101.19 | C:  26.23/30.0\n",
            "[FedSGM] it 0434/500 | switching ratio:(0.00, 1.00) | R: 161.14 | C:  39.31/30.0\n",
            "[FedSGM] it 0435/500 | switching ratio:(0.00, 1.00) | R: 178.68 | C:  43.16/30.0\n",
            "[FedSGM] it 0436/500 | switching ratio:(0.00, 1.00) | R: 153.37 | C:  35.88/30.0\n",
            "[FedSGM] it 0437/500 | switching ratio:(0.50, 0.50) | R:  98.43 | C:  24.39/30.0\n",
            "[FedSGM] it 0438/500 | switching ratio:(0.00, 1.00) | R: 135.48 | C:  32.18/30.0\n",
            "[FedSGM] it 0439/500 | switching ratio:(0.05, 0.95) | R: 132.81 | C:  30.13/30.0\n",
            "[FedSGM] it 0440/500 | switching ratio:(0.29, 0.71) | R: 106.04 | C:  25.72/30.0\n",
            "[FedSGM] it 0441/500 | switching ratio:(0.00, 1.00) | R: 137.39 | C:  30.54/30.0\n",
            "[FedSGM] it 0442/500 | switching ratio:(0.67, 0.33) | R:  80.90 | C:  21.15/30.0\n",
            "[FedSGM] it 0443/500 | switching ratio:(0.00, 1.00) | R: 145.81 | C:  32.48/30.0\n",
            "[FedSGM] it 0444/500 | switching ratio:(0.00, 1.00) | R: 173.30 | C:  38.30/30.0\n",
            "[FedSGM] it 0445/500 | switching ratio:(0.00, 1.00) | R: 172.46 | C:  37.42/30.0\n",
            "[FedSGM] it 0446/500 | switching ratio:(0.00, 1.00) | R: 171.89 | C:  36.96/30.0\n",
            "[FedSGM] it 0447/500 | switching ratio:(0.14, 0.86) | R: 123.93 | C:  28.43/30.0\n",
            "[FedSGM] it 0448/500 | switching ratio:(0.68, 0.32) | R:  72.29 | C:  19.57/30.0\n",
            "[FedSGM] it 0449/500 | switching ratio:(0.26, 0.74) | R: 121.08 | C:  27.53/30.0\n",
            "[FedSGM] it 0450/500 | switching ratio:(0.00, 1.00) | R: 153.92 | C:  33.42/30.0\n",
            "[FedSGM] it 0451/500 | switching ratio:(0.00, 1.00) | R: 180.46 | C:  37.36/30.0\n",
            "[FedSGM] it 0452/500 | switching ratio:(0.00, 1.00) | R: 186.99 | C:  37.71/30.0\n",
            "[FedSGM] it 0453/500 | switching ratio:(0.00, 1.00) | R: 168.85 | C:  35.07/30.0\n",
            "[FedSGM] it 0454/500 | switching ratio:(0.04, 0.96) | R: 141.05 | C:  29.99/30.0\n",
            "[FedSGM] it 0455/500 | switching ratio:(0.72, 0.28) | R:  83.45 | C:  20.66/30.0\n",
            "[FedSGM] it 0456/500 | switching ratio:(0.35, 0.65) | R: 112.57 | C:  25.23/30.0\n",
            "[FedSGM] it 0457/500 | switching ratio:(0.00, 1.00) | R: 162.52 | C:  32.82/30.0\n",
            "[FedSGM] it 0458/500 | switching ratio:(0.00, 1.00) | R: 185.06 | C:  35.51/30.0\n",
            "[FedSGM] it 0459/500 | switching ratio:(0.00, 1.00) | R: 190.05 | C:  36.72/30.0\n",
            "[FedSGM] it 0460/500 | switching ratio:(0.00, 1.00) | R: 189.76 | C:  35.72/30.0\n",
            "[FedSGM] it 0461/500 | switching ratio:(0.00, 1.00) | R: 181.95 | C:  34.31/30.0\n",
            "[FedSGM] it 0462/500 | switching ratio:(0.18, 0.82) | R: 152.42 | C:  29.33/30.0\n",
            "[FedSGM] it 0463/500 | switching ratio:(0.90, 0.10) | R:  64.62 | C:  17.44/30.0\n",
            "[FedSGM] it 0464/500 | switching ratio:(0.45, 0.55) | R: 106.94 | C:  23.53/30.0\n",
            "[FedSGM] it 0465/500 | switching ratio:(0.09, 0.91) | R: 159.29 | C:  30.02/30.0\n",
            "[FedSGM] it 0466/500 | switching ratio:(0.00, 1.00) | R: 199.86 | C:  37.14/30.0\n",
            "[FedSGM] it 0467/500 | switching ratio:(0.00, 1.00) | R: 171.86 | C:  31.69/30.0\n",
            "[FedSGM] it 0468/500 | switching ratio:(0.00, 1.00) | R: 186.40 | C:  33.66/30.0\n",
            "[FedSGM] it 0469/500 | switching ratio:(0.00, 1.00) | R: 177.85 | C:  33.15/30.0\n",
            "[FedSGM] it 0470/500 | switching ratio:(0.00, 1.00) | R: 169.90 | C:  30.82/30.0\n",
            "[FedSGM] it 0471/500 | switching ratio:(0.58, 0.42) | R: 110.24 | C:  22.38/30.0\n",
            "[FedSGM] it 0472/500 | switching ratio:(0.20, 0.80) | R: 150.77 | C:  27.98/30.0\n",
            "[FedSGM] it 0473/500 | switching ratio:(0.00, 1.00) | R: 191.05 | C:  33.16/30.0\n",
            "[FedSGM] it 0474/500 | switching ratio:(0.00, 1.00) | R: 191.60 | C:  34.34/30.0\n",
            "[FedSGM] it 0475/500 | switching ratio:(0.00, 1.00) | R: 195.55 | C:  33.05/30.0\n",
            "[FedSGM] it 0476/500 | switching ratio:(0.15, 0.85) | R: 174.29 | C:  28.41/30.0\n",
            "[FedSGM] it 0477/500 | switching ratio:(0.03, 0.97) | R: 191.10 | C:  31.07/30.0\n",
            "[FedSGM] it 0478/500 | switching ratio:(0.52, 0.48) | R: 138.57 | C:  23.86/30.0\n",
            "[FedSGM] it 0479/500 | switching ratio:(0.39, 0.61) | R: 153.55 | C:  24.72/30.0\n",
            "[FedSGM] it 0480/500 | switching ratio:(0.24, 0.76) | R: 163.53 | C:  25.95/30.0\n",
            "[FedSGM] it 0481/500 | switching ratio:(0.22, 0.78) | R: 186.71 | C:  27.62/30.0\n",
            "[FedSGM] it 0482/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.74/30.0\n",
            "[FedSGM] it 0483/500 | switching ratio:(0.20, 0.80) | R: 191.05 | C:  26.91/30.0\n",
            "[FedSGM] it 0484/500 | switching ratio:(0.43, 0.57) | R: 191.24 | C:  24.93/30.0\n",
            "[FedSGM] it 0485/500 | switching ratio:(0.29, 0.71) | R: 191.21 | C:  25.91/30.0\n",
            "[FedSGM] it 0486/500 | switching ratio:(0.25, 0.75) | R: 195.60 | C:  25.93/30.0\n",
            "[FedSGM] it 0487/500 | switching ratio:(0.28, 0.72) | R: 195.57 | C:  26.18/30.0\n",
            "[FedSGM] it 0488/500 | switching ratio:(0.46, 0.54) | R: 200.00 | C:  24.40/30.0\n",
            "[FedSGM] it 0489/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  26.49/30.0\n",
            "[FedSGM] it 0490/500 | switching ratio:(0.32, 0.68) | R: 200.00 | C:  25.49/30.0\n",
            "[FedSGM] it 0491/500 | switching ratio:(0.40, 0.60) | R: 200.00 | C:  26.00/30.0\n",
            "[FedSGM] it 0492/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  28.26/30.0\n",
            "[FedSGM] it 0493/500 | switching ratio:(0.32, 0.68) | R: 200.00 | C:  26.97/30.0\n",
            "[FedSGM] it 0494/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  26.43/30.0\n",
            "[FedSGM] it 0495/500 | switching ratio:(0.40, 0.60) | R: 195.57 | C:  25.23/30.0\n",
            "[FedSGM] it 0496/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0497/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  27.11/30.0\n",
            "[FedSGM] it 0498/500 | switching ratio:(0.34, 0.66) | R: 195.55 | C:  25.95/30.0\n",
            "[FedSGM] it 0499/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  28.20/30.0\n",
            "[FedSGM] it 0500/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  27.77/30.0\n",
            "Avg return over last 50 feasible rounds: 142.36\n",
            "\n",
            "--- Running Experiment 2/5 ---\n",
            "Starting parallel federated learning for 500 rounds with 10 total clients and 7 selected clients per round.\n",
            "[FedSGM] it 0001/500 | switching ratio:(0.48, 0.52) | R:  22.73 | C:  21.36/30.0\n",
            "[FedSGM] it 0002/500 | switching ratio:(0.20, 0.80) | R:  26.53 | C:  24.23/30.0\n",
            "[FedSGM] it 0003/500 | switching ratio:(0.72, 0.28) | R:  18.77 | C:  17.87/30.0\n",
            "[FedSGM] it 0004/500 | switching ratio:(0.35, 0.65) | R:  26.48 | C:  23.95/30.0\n",
            "[FedSGM] it 0005/500 | switching ratio:(0.78, 0.22) | R:  19.08 | C:  18.10/30.0\n",
            "[FedSGM] it 0006/500 | switching ratio:(0.43, 0.57) | R:  24.41 | C:  22.77/30.0\n",
            "[FedSGM] it 0007/500 | switching ratio:(0.00, 1.00) | R:  38.37 | C:  33.43/30.0\n",
            "[FedSGM] it 0008/500 | switching ratio:(0.40, 0.60) | R:  25.29 | C:  23.42/30.0\n",
            "[FedSGM] it 0009/500 | switching ratio:(0.63, 0.37) | R:  19.26 | C:  18.49/30.0\n",
            "[FedSGM] it 0010/500 | switching ratio:(0.53, 0.47) | R:  21.75 | C:  20.46/30.0\n",
            "[FedSGM] it 0011/500 | switching ratio:(0.00, 1.00) | R:  34.69 | C:  31.20/30.0\n",
            "[FedSGM] it 0012/500 | switching ratio:(0.50, 0.50) | R:  22.39 | C:  20.89/30.0\n",
            "[FedSGM] it 0013/500 | switching ratio:(0.74, 0.26) | R:  18.36 | C:  17.41/30.0\n",
            "[FedSGM] it 0014/500 | switching ratio:(0.42, 0.58) | R:  22.88 | C:  21.44/30.0\n",
            "[FedSGM] it 0015/500 | switching ratio:(0.00, 1.00) | R:  32.30 | C:  28.54/30.0\n",
            "[FedSGM] it 0016/500 | switching ratio:(0.49, 0.51) | R:  24.84 | C:  22.76/30.0\n",
            "[FedSGM] it 0017/500 | switching ratio:(0.75, 0.25) | R:  18.73 | C:  17.71/30.0\n",
            "[FedSGM] it 0018/500 | switching ratio:(0.48, 0.52) | R:  23.61 | C:  21.94/30.0\n",
            "[FedSGM] it 0019/500 | switching ratio:(0.00, 1.00) | R:  35.78 | C:  31.71/30.0\n",
            "[FedSGM] it 0020/500 | switching ratio:(0.29, 0.71) | R:  27.03 | C:  24.59/30.0\n",
            "[FedSGM] it 0021/500 | switching ratio:(0.61, 0.39) | R:  20.22 | C:  19.36/30.0\n",
            "[FedSGM] it 0022/500 | switching ratio:(0.69, 0.31) | R:  20.54 | C:  19.53/30.0\n",
            "[FedSGM] it 0023/500 | switching ratio:(0.32, 0.68) | R:  25.44 | C:  23.27/30.0\n",
            "[FedSGM] it 0024/500 | switching ratio:(0.61, 0.39) | R:  20.91 | C:  20.03/30.0\n",
            "[FedSGM] it 0025/500 | switching ratio:(0.00, 1.00) | R:  39.12 | C:  32.77/30.0\n",
            "[FedSGM] it 0026/500 | switching ratio:(0.42, 0.58) | R:  24.05 | C:  22.42/30.0\n",
            "[FedSGM] it 0027/500 | switching ratio:(0.87, 0.13) | R:  17.13 | C:  16.57/30.0\n",
            "[FedSGM] it 0028/500 | switching ratio:(0.63, 0.37) | R:  20.21 | C:  19.37/30.0\n",
            "[FedSGM] it 0029/500 | switching ratio:(0.07, 0.93) | R:  31.72 | C:  28.34/30.0\n",
            "[FedSGM] it 0030/500 | switching ratio:(0.49, 0.51) | R:  22.76 | C:  21.56/30.0\n",
            "[FedSGM] it 0031/500 | switching ratio:(0.89, 0.11) | R:  16.69 | C:  16.05/30.0\n",
            "[FedSGM] it 0032/500 | switching ratio:(0.47, 0.53) | R:  23.24 | C:  21.33/30.0\n",
            "[FedSGM] it 0033/500 | switching ratio:(0.08, 0.92) | R:  30.79 | C:  27.69/30.0\n",
            "[FedSGM] it 0034/500 | switching ratio:(0.60, 0.40) | R:  21.08 | C:  20.08/30.0\n",
            "[FedSGM] it 0035/500 | switching ratio:(0.69, 0.31) | R:  19.37 | C:  18.57/30.0\n",
            "[FedSGM] it 0036/500 | switching ratio:(0.14, 0.86) | R:  28.85 | C:  26.18/30.0\n",
            "[FedSGM] it 0037/500 | switching ratio:(0.75, 0.25) | R:  19.85 | C:  18.96/30.0\n",
            "[FedSGM] it 0038/500 | switching ratio:(0.47, 0.53) | R:  22.84 | C:  21.39/30.0\n",
            "[FedSGM] it 0039/500 | switching ratio:(0.00, 1.00) | R:  40.76 | C:  34.38/30.0\n",
            "[FedSGM] it 0040/500 | switching ratio:(0.47, 0.53) | R:  23.06 | C:  21.57/30.0\n",
            "[FedSGM] it 0041/500 | switching ratio:(0.84, 0.16) | R:  16.94 | C:  16.41/30.0\n",
            "[FedSGM] it 0042/500 | switching ratio:(0.67, 0.33) | R:  20.69 | C:  19.52/30.0\n",
            "[FedSGM] it 0043/500 | switching ratio:(0.07, 0.93) | R:  29.99 | C:  27.14/30.0\n",
            "[FedSGM] it 0044/500 | switching ratio:(0.41, 0.59) | R:  23.98 | C:  22.43/30.0\n",
            "[FedSGM] it 0045/500 | switching ratio:(0.96, 0.04) | R:  16.30 | C:  15.79/30.0\n",
            "[FedSGM] it 0046/500 | switching ratio:(0.47, 0.53) | R:  21.11 | C:  20.27/30.0\n",
            "[FedSGM] it 0047/500 | switching ratio:(0.02, 0.98) | R:  31.25 | C:  27.85/30.0\n",
            "[FedSGM] it 0048/500 | switching ratio:(0.70, 0.30) | R:  20.03 | C:  19.11/30.0\n",
            "[FedSGM] it 0049/500 | switching ratio:(0.72, 0.28) | R:  17.75 | C:  17.12/30.0\n",
            "[FedSGM] it 0050/500 | switching ratio:(0.38, 0.62) | R:  24.91 | C:  22.86/30.0\n",
            "[FedSGM] it 0051/500 | switching ratio:(0.00, 1.00) | R:  35.31 | C:  31.26/30.0\n",
            "[FedSGM] it 0052/500 | switching ratio:(0.45, 0.55) | R:  24.89 | C:  23.04/30.0\n",
            "[FedSGM] it 0053/500 | switching ratio:(0.77, 0.23) | R:  17.83 | C:  17.06/30.0\n",
            "[FedSGM] it 0054/500 | switching ratio:(0.61, 0.39) | R:  20.46 | C:  19.52/30.0\n",
            "[FedSGM] it 0055/500 | switching ratio:(0.24, 0.76) | R:  28.73 | C:  25.91/30.0\n",
            "[FedSGM] it 0056/500 | switching ratio:(0.52, 0.48) | R:  23.73 | C:  22.23/30.0\n",
            "[FedSGM] it 0057/500 | switching ratio:(0.82, 0.18) | R:  18.32 | C:  17.56/30.0\n",
            "[FedSGM] it 0058/500 | switching ratio:(0.41, 0.59) | R:  24.36 | C:  22.63/30.0\n",
            "[FedSGM] it 0059/500 | switching ratio:(0.00, 1.00) | R:  33.99 | C:  29.90/30.0\n",
            "[FedSGM] it 0060/500 | switching ratio:(0.04, 0.96) | R:  29.38 | C:  26.60/30.0\n",
            "[FedSGM] it 0061/500 | switching ratio:(0.65, 0.35) | R:  18.73 | C:  17.90/30.0\n",
            "[FedSGM] it 0062/500 | switching ratio:(1.00, 0.00) | R:  14.72 | C:  14.21/30.0\n",
            "[FedSGM] it 0063/500 | switching ratio:(0.69, 0.31) | R:  19.09 | C:  18.19/30.0\n",
            "[FedSGM] it 0064/500 | switching ratio:(0.51, 0.49) | R:  23.43 | C:  21.82/30.0\n",
            "[FedSGM] it 0065/500 | switching ratio:(0.00, 1.00) | R:  37.55 | C:  33.22/30.0\n",
            "[FedSGM] it 0066/500 | switching ratio:(0.15, 0.85) | R:  27.62 | C:  25.12/30.0\n",
            "[FedSGM] it 0067/500 | switching ratio:(0.58, 0.42) | R:  21.20 | C:  20.00/30.0\n",
            "[FedSGM] it 0068/500 | switching ratio:(0.89, 0.11) | R:  16.10 | C:  15.52/30.0\n",
            "[FedSGM] it 0069/500 | switching ratio:(0.68, 0.32) | R:  20.58 | C:  19.45/30.0\n",
            "[FedSGM] it 0070/500 | switching ratio:(0.01, 0.99) | R:  32.84 | C:  28.93/30.0\n",
            "[FedSGM] it 0071/500 | switching ratio:(0.41, 0.59) | R:  23.83 | C:  22.30/30.0\n",
            "[FedSGM] it 0072/500 | switching ratio:(0.73, 0.27) | R:  19.60 | C:  18.75/30.0\n",
            "[FedSGM] it 0073/500 | switching ratio:(0.28, 0.72) | R:  24.88 | C:  23.07/30.0\n",
            "[FedSGM] it 0074/500 | switching ratio:(0.83, 0.17) | R:  18.58 | C:  17.81/30.0\n",
            "[FedSGM] it 0075/500 | switching ratio:(0.29, 0.71) | R:  25.46 | C:  23.92/30.0\n",
            "[FedSGM] it 0076/500 | switching ratio:(0.49, 0.51) | R:  21.59 | C:  20.34/30.0\n",
            "[FedSGM] it 0077/500 | switching ratio:(0.84, 0.16) | R:  17.89 | C:  17.16/30.0\n",
            "[FedSGM] it 0078/500 | switching ratio:(0.26, 0.74) | R:  26.76 | C:  24.63/30.0\n",
            "[FedSGM] it 0079/500 | switching ratio:(0.33, 0.67) | R:  25.51 | C:  23.52/30.0\n",
            "[FedSGM] it 0080/500 | switching ratio:(0.71, 0.29) | R:  19.24 | C:  18.41/30.0\n",
            "[FedSGM] it 0081/500 | switching ratio:(0.46, 0.54) | R:  23.32 | C:  21.64/30.0\n",
            "[FedSGM] it 0082/500 | switching ratio:(0.00, 1.00) | R:  37.74 | C:  32.13/30.0\n",
            "[FedSGM] it 0083/500 | switching ratio:(0.54, 0.46) | R:  22.39 | C:  20.72/30.0\n",
            "[FedSGM] it 0084/500 | switching ratio:(0.81, 0.19) | R:  17.83 | C:  17.19/30.0\n",
            "[FedSGM] it 0085/500 | switching ratio:(0.43, 0.57) | R:  24.76 | C:  23.07/30.0\n",
            "[FedSGM] it 0086/500 | switching ratio:(0.00, 1.00) | R:  35.26 | C:  30.74/30.0\n",
            "[FedSGM] it 0087/500 | switching ratio:(0.43, 0.57) | R:  24.40 | C:  22.17/30.0\n",
            "[FedSGM] it 0088/500 | switching ratio:(0.79, 0.21) | R:  17.56 | C:  16.93/30.0\n",
            "[FedSGM] it 0089/500 | switching ratio:(0.53, 0.47) | R:  20.82 | C:  19.77/30.0\n",
            "[FedSGM] it 0090/500 | switching ratio:(0.35, 0.65) | R:  26.79 | C:  24.47/30.0\n",
            "[FedSGM] it 0091/500 | switching ratio:(0.53, 0.47) | R:  22.15 | C:  20.90/30.0\n",
            "[FedSGM] it 0092/500 | switching ratio:(0.07, 0.93) | R:  31.23 | C:  28.05/30.0\n",
            "[FedSGM] it 0093/500 | switching ratio:(0.53, 0.47) | R:  23.64 | C:  21.73/30.0\n",
            "[FedSGM] it 0094/500 | switching ratio:(1.00, 0.00) | R:  14.48 | C:  14.10/30.0\n",
            "[FedSGM] it 0095/500 | switching ratio:(0.61, 0.39) | R:  19.18 | C:  18.31/30.0\n",
            "[FedSGM] it 0096/500 | switching ratio:(0.24, 0.76) | R:  27.21 | C:  24.83/30.0\n",
            "[FedSGM] it 0097/500 | switching ratio:(0.58, 0.42) | R:  20.84 | C:  19.73/30.0\n",
            "[FedSGM] it 0098/500 | switching ratio:(0.31, 0.69) | R:  27.45 | C:  24.63/30.0\n",
            "[FedSGM] it 0099/500 | switching ratio:(0.86, 0.14) | R:  16.47 | C:  15.80/30.0\n",
            "[FedSGM] it 0100/500 | switching ratio:(0.56, 0.44) | R:  22.28 | C:  20.98/30.0\n",
            "[FedSGM] it 0101/500 | switching ratio:(0.00, 1.00) | R:  44.86 | C:  35.06/30.0\n",
            "[FedSGM] it 0102/500 | switching ratio:(0.37, 0.63) | R:  25.75 | C:  23.16/30.0\n",
            "[FedSGM] it 0103/500 | switching ratio:(0.74, 0.26) | R:  18.65 | C:  17.78/30.0\n",
            "[FedSGM] it 0104/500 | switching ratio:(0.75, 0.25) | R:  18.82 | C:  17.93/30.0\n",
            "[FedSGM] it 0105/500 | switching ratio:(0.40, 0.60) | R:  26.49 | C:  23.84/30.0\n",
            "[FedSGM] it 0106/500 | switching ratio:(0.00, 1.00) | R:  36.44 | C:  30.49/30.0\n",
            "[FedSGM] it 0107/500 | switching ratio:(0.45, 0.55) | R:  23.33 | C:  22.03/30.0\n",
            "[FedSGM] it 0108/500 | switching ratio:(0.82, 0.18) | R:  16.13 | C:  15.64/30.0\n",
            "[FedSGM] it 0109/500 | switching ratio:(0.89, 0.11) | R:  17.02 | C:  16.50/30.0\n",
            "[FedSGM] it 0110/500 | switching ratio:(0.50, 0.50) | R:  21.69 | C:  20.27/30.0\n",
            "[FedSGM] it 0111/500 | switching ratio:(0.00, 1.00) | R:  34.39 | C:  29.47/30.0\n",
            "[FedSGM] it 0112/500 | switching ratio:(0.53, 0.47) | R:  23.61 | C:  21.70/30.0\n",
            "[FedSGM] it 0113/500 | switching ratio:(0.87, 0.13) | R:  17.08 | C:  16.45/30.0\n",
            "[FedSGM] it 0114/500 | switching ratio:(0.64, 0.36) | R:  21.13 | C:  19.81/30.0\n",
            "[FedSGM] it 0115/500 | switching ratio:(0.15, 0.85) | R:  29.17 | C:  26.16/30.0\n",
            "[FedSGM] it 0116/500 | switching ratio:(0.47, 0.53) | R:  22.22 | C:  21.04/30.0\n",
            "[FedSGM] it 0117/500 | switching ratio:(0.87, 0.13) | R:  15.33 | C:  14.98/30.0\n",
            "[FedSGM] it 0118/500 | switching ratio:(0.59, 0.41) | R:  21.04 | C:  19.92/30.0\n",
            "[FedSGM] it 0119/500 | switching ratio:(0.13, 0.87) | R:  30.24 | C:  27.30/30.0\n",
            "[FedSGM] it 0120/500 | switching ratio:(0.38, 0.62) | R:  24.17 | C:  22.37/30.0\n",
            "[FedSGM] it 0121/500 | switching ratio:(0.71, 0.29) | R:  17.35 | C:  16.75/30.0\n",
            "[FedSGM] it 0122/500 | switching ratio:(0.61, 0.39) | R:  19.34 | C:  18.47/30.0\n",
            "[FedSGM] it 0123/500 | switching ratio:(0.31, 0.69) | R:  26.83 | C:  24.18/30.0\n",
            "[FedSGM] it 0124/500 | switching ratio:(0.51, 0.49) | R:  20.93 | C:  19.61/30.0\n",
            "[FedSGM] it 0125/500 | switching ratio:(0.96, 0.04) | R:  15.79 | C:  15.33/30.0\n",
            "[FedSGM] it 0126/500 | switching ratio:(0.63, 0.37) | R:  21.30 | C:  20.08/30.0\n",
            "[FedSGM] it 0127/500 | switching ratio:(0.00, 1.00) | R:  33.66 | C:  29.92/30.0\n",
            "[FedSGM] it 0128/500 | switching ratio:(0.42, 0.58) | R:  23.94 | C:  21.99/30.0\n",
            "[FedSGM] it 0129/500 | switching ratio:(0.91, 0.09) | R:  15.69 | C:  15.16/30.0\n",
            "[FedSGM] it 0130/500 | switching ratio:(0.50, 0.50) | R:  22.90 | C:  21.21/30.0\n",
            "[FedSGM] it 0131/500 | switching ratio:(0.08, 0.92) | R:  29.48 | C:  26.73/30.0\n",
            "[FedSGM] it 0132/500 | switching ratio:(0.57, 0.43) | R:  22.25 | C:  20.63/30.0\n",
            "[FedSGM] it 0133/500 | switching ratio:(0.77, 0.23) | R:  17.37 | C:  16.74/30.0\n",
            "[FedSGM] it 0134/500 | switching ratio:(0.37, 0.63) | R:  23.53 | C:  21.95/30.0\n",
            "[FedSGM] it 0135/500 | switching ratio:(0.00, 1.00) | R:  34.11 | C:  29.39/30.0\n",
            "[FedSGM] it 0136/500 | switching ratio:(0.67, 0.33) | R:  18.30 | C:  17.54/30.0\n",
            "[FedSGM] it 0137/500 | switching ratio:(0.80, 0.20) | R:  16.34 | C:  15.67/30.0\n",
            "[FedSGM] it 0138/500 | switching ratio:(0.33, 0.67) | R:  25.79 | C:  23.64/30.0\n",
            "[FedSGM] it 0139/500 | switching ratio:(0.27, 0.73) | R:  27.62 | C:  24.75/30.0\n",
            "[FedSGM] it 0140/500 | switching ratio:(0.75, 0.25) | R:  17.31 | C:  16.58/30.0\n",
            "[FedSGM] it 0141/500 | switching ratio:(0.25, 0.75) | R:  26.90 | C:  24.48/30.0\n",
            "[FedSGM] it 0142/500 | switching ratio:(0.84, 0.16) | R:  17.12 | C:  16.36/30.0\n",
            "[FedSGM] it 0143/500 | switching ratio:(0.21, 0.79) | R:  27.74 | C:  24.56/30.0\n",
            "[FedSGM] it 0144/500 | switching ratio:(0.65, 0.35) | R:  22.33 | C:  20.32/30.0\n",
            "[FedSGM] it 0145/500 | switching ratio:(0.00, 1.00) | R:  32.08 | C:  27.81/30.0\n",
            "[FedSGM] it 0146/500 | switching ratio:(0.60, 0.40) | R:  20.17 | C:  18.77/30.0\n",
            "[FedSGM] it 0147/500 | switching ratio:(0.79, 0.21) | R:  17.31 | C:  16.20/30.0\n",
            "[FedSGM] it 0148/500 | switching ratio:(0.35, 0.65) | R:  26.47 | C:  23.30/30.0\n",
            "[FedSGM] it 0149/500 | switching ratio:(0.26, 0.74) | R:  30.05 | C:  25.57/30.0\n",
            "[FedSGM] it 0150/500 | switching ratio:(0.68, 0.32) | R:  21.23 | C:  19.60/30.0\n",
            "[FedSGM] it 0151/500 | switching ratio:(0.13, 0.87) | R:  30.90 | C:  26.14/30.0\n",
            "[FedSGM] it 0152/500 | switching ratio:(0.65, 0.35) | R:  20.58 | C:  18.75/30.0\n",
            "[FedSGM] it 0153/500 | switching ratio:(0.21, 0.79) | R:  28.47 | C:  24.23/30.0\n",
            "[FedSGM] it 0154/500 | switching ratio:(0.71, 0.29) | R:  20.33 | C:  18.08/30.0\n",
            "[FedSGM] it 0155/500 | switching ratio:(0.36, 0.64) | R:  26.79 | C:  23.13/30.0\n",
            "[FedSGM] it 0156/500 | switching ratio:(0.00, 1.00) | R:  37.18 | C:  29.12/30.0\n",
            "[FedSGM] it 0157/500 | switching ratio:(0.58, 0.42) | R:  21.27 | C:  18.96/30.0\n",
            "[FedSGM] it 0158/500 | switching ratio:(0.99, 0.01) | R:  15.52 | C:  14.61/30.0\n",
            "[FedSGM] it 0159/500 | switching ratio:(0.59, 0.41) | R:  22.79 | C:  19.72/30.0\n",
            "[FedSGM] it 0160/500 | switching ratio:(0.00, 1.00) | R:  39.24 | C:  31.60/30.0\n",
            "[FedSGM] it 0161/500 | switching ratio:(0.49, 0.51) | R:  24.10 | C:  20.88/30.0\n",
            "[FedSGM] it 0162/500 | switching ratio:(1.00, 0.00) | R:  15.10 | C:  14.31/30.0\n",
            "[FedSGM] it 0163/500 | switching ratio:(0.60, 0.40) | R:  20.88 | C:  18.27/30.0\n",
            "[FedSGM] it 0164/500 | switching ratio:(0.12, 0.88) | R:  31.61 | C:  25.96/30.0\n",
            "[FedSGM] it 0165/500 | switching ratio:(0.28, 0.72) | R:  31.65 | C:  25.72/30.0\n",
            "[FedSGM] it 0166/500 | switching ratio:(0.61, 0.39) | R:  20.62 | C:  18.20/30.0\n",
            "[FedSGM] it 0167/500 | switching ratio:(0.58, 0.42) | R:  23.37 | C:  20.29/30.0\n",
            "[FedSGM] it 0168/500 | switching ratio:(0.00, 1.00) | R:  40.53 | C:  29.37/30.0\n",
            "[FedSGM] it 0169/500 | switching ratio:(0.22, 0.78) | R:  32.13 | C:  25.41/30.0\n",
            "[FedSGM] it 0170/500 | switching ratio:(0.58, 0.42) | R:  22.68 | C:  19.65/30.0\n",
            "[FedSGM] it 0171/500 | switching ratio:(0.58, 0.42) | R:  23.54 | C:  19.71/30.0\n",
            "[FedSGM] it 0172/500 | switching ratio:(0.13, 0.87) | R:  33.09 | C:  26.02/30.0\n",
            "[FedSGM] it 0173/500 | switching ratio:(0.68, 0.32) | R:  23.69 | C:  19.64/30.0\n",
            "[FedSGM] it 0174/500 | switching ratio:(0.04, 0.96) | R:  35.98 | C:  27.37/30.0\n",
            "[FedSGM] it 0175/500 | switching ratio:(0.72, 0.28) | R:  20.95 | C:  17.88/30.0\n",
            "[FedSGM] it 0176/500 | switching ratio:(0.45, 0.55) | R:  28.07 | C:  21.82/30.0\n",
            "[FedSGM] it 0177/500 | switching ratio:(0.00, 1.00) | R:  82.61 | C:  45.71/30.0\n",
            "[FedSGM] it 0178/500 | switching ratio:(0.00, 1.00) | R:  83.26 | C:  39.23/30.0\n",
            "[FedSGM] it 0179/500 | switching ratio:(0.63, 0.37) | R:  27.81 | C:  19.27/30.0\n",
            "[FedSGM] it 0180/500 | switching ratio:(0.58, 0.42) | R:  29.55 | C:  20.16/30.0\n",
            "[FedSGM] it 0181/500 | switching ratio:(0.00, 1.00) | R:  87.18 | C:  37.98/30.0\n",
            "[FedSGM] it 0182/500 | switching ratio:(0.00, 1.00) | R: 111.96 | C:  41.57/30.0\n",
            "[FedSGM] it 0183/500 | switching ratio:(0.00, 1.00) | R: 111.71 | C:  40.73/30.0\n",
            "[FedSGM] it 0184/500 | switching ratio:(0.70, 0.30) | R:  35.46 | C:  17.91/30.0\n",
            "[FedSGM] it 0185/500 | switching ratio:(0.68, 0.32) | R:  34.80 | C:  17.82/30.0\n",
            "[FedSGM] it 0186/500 | switching ratio:(0.00, 1.00) | R:  74.40 | C:  28.04/30.0\n",
            "[FedSGM] it 0187/500 | switching ratio:(0.00, 1.00) | R: 130.36 | C:  33.03/30.0\n",
            "[FedSGM] it 0188/500 | switching ratio:(0.00, 1.00) | R: 127.13 | C:  32.87/30.0\n",
            "[FedSGM] it 0189/500 | switching ratio:(0.32, 0.68) | R:  82.31 | C:  24.66/30.0\n",
            "[FedSGM] it 0190/500 | switching ratio:(0.44, 0.56) | R: 118.24 | C:  22.05/30.0\n",
            "[FedSGM] it 0191/500 | switching ratio:(0.36, 0.64) | R: 173.53 | C:  23.93/30.0\n",
            "[FedSGM] it 0192/500 | switching ratio:(0.00, 1.00) | R: 185.54 | C:  28.55/30.0\n",
            "[FedSGM] it 0193/500 | switching ratio:(0.17, 0.83) | R: 195.52 | C:  26.99/30.0\n",
            "[FedSGM] it 0194/500 | switching ratio:(0.05, 0.95) | R: 195.57 | C:  27.36/30.0\n",
            "[FedSGM] it 0195/500 | switching ratio:(0.07, 0.93) | R: 195.67 | C:  27.11/30.0\n",
            "[FedSGM] it 0196/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0197/500 | switching ratio:(0.18, 0.82) | R: 176.16 | C:  25.55/30.0\n",
            "[FedSGM] it 0198/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  27.71/30.0\n",
            "[FedSGM] it 0199/500 | switching ratio:(0.18, 0.82) | R: 195.55 | C:  25.60/30.0\n",
            "[FedSGM] it 0200/500 | switching ratio:(0.13, 0.87) | R: 195.50 | C:  26.37/30.0\n",
            "[FedSGM] it 0201/500 | switching ratio:(0.01, 0.99) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0202/500 | switching ratio:(0.11, 0.89) | R: 191.60 | C:  27.08/30.0\n",
            "[FedSGM] it 0203/500 | switching ratio:(0.29, 0.71) | R: 195.55 | C:  24.65/30.0\n",
            "[FedSGM] it 0204/500 | switching ratio:(0.33, 0.67) | R: 191.10 | C:  24.54/30.0\n",
            "[FedSGM] it 0205/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  25.66/30.0\n",
            "[FedSGM] it 0206/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  25.69/30.0\n",
            "[FedSGM] it 0207/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  25.74/30.0\n",
            "[FedSGM] it 0208/500 | switching ratio:(0.12, 0.88) | R: 195.57 | C:  26.49/30.0\n",
            "[FedSGM] it 0209/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0210/500 | switching ratio:(0.30, 0.70) | R: 195.55 | C:  24.98/30.0\n",
            "[FedSGM] it 0211/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  26.69/30.0\n",
            "[FedSGM] it 0212/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  26.00/30.0\n",
            "[FedSGM] it 0213/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  26.06/30.0\n",
            "[FedSGM] it 0214/500 | switching ratio:(0.13, 0.87) | R: 200.00 | C:  27.37/30.0\n",
            "[FedSGM] it 0215/500 | switching ratio:(0.13, 0.87) | R: 195.55 | C:  25.26/30.0\n",
            "[FedSGM] it 0216/500 | switching ratio:(0.21, 0.79) | R: 191.00 | C:  24.74/30.0\n",
            "[FedSGM] it 0217/500 | switching ratio:(0.07, 0.93) | R: 191.14 | C:  26.46/30.0\n",
            "[FedSGM] it 0218/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  25.83/30.0\n",
            "[FedSGM] it 0219/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0220/500 | switching ratio:(0.28, 0.72) | R: 179.10 | C:  23.83/30.0\n",
            "[FedSGM] it 0221/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.11/30.0\n",
            "[FedSGM] it 0222/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  25.46/30.0\n",
            "[FedSGM] it 0223/500 | switching ratio:(0.38, 0.62) | R: 200.00 | C:  24.00/30.0\n",
            "[FedSGM] it 0224/500 | switching ratio:(0.08, 0.92) | R: 195.52 | C:  27.01/30.0\n",
            "[FedSGM] it 0225/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  25.71/30.0\n",
            "[FedSGM] it 0226/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  26.49/30.0\n",
            "[FedSGM] it 0227/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  25.57/30.0\n",
            "[FedSGM] it 0228/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.43/30.0\n",
            "[FedSGM] it 0229/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  25.17/30.0\n",
            "[FedSGM] it 0230/500 | switching ratio:(0.20, 0.80) | R: 191.17 | C:  25.15/30.0\n",
            "[FedSGM] it 0231/500 | switching ratio:(0.03, 0.97) | R: 195.86 | C:  27.87/30.0\n",
            "[FedSGM] it 0232/500 | switching ratio:(0.07, 0.93) | R: 195.52 | C:  25.97/30.0\n",
            "[FedSGM] it 0233/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  25.80/30.0\n",
            "[FedSGM] it 0234/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  26.54/30.0\n",
            "[FedSGM] it 0235/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  24.49/30.0\n",
            "[FedSGM] it 0236/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  24.94/30.0\n",
            "[FedSGM] it 0237/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  26.00/30.0\n",
            "[FedSGM] it 0238/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  25.89/30.0\n",
            "[FedSGM] it 0239/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  25.03/30.0\n",
            "[FedSGM] it 0240/500 | switching ratio:(0.29, 0.71) | R: 195.57 | C:  24.05/30.0\n",
            "[FedSGM] it 0241/500 | switching ratio:(0.20, 0.80) | R: 187.02 | C:  24.47/30.0\n",
            "[FedSGM] it 0242/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  27.34/30.0\n",
            "[FedSGM] it 0243/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0244/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.11/30.0\n",
            "[FedSGM] it 0245/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  28.11/30.0\n",
            "[FedSGM] it 0246/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  27.14/30.0\n",
            "[FedSGM] it 0247/500 | switching ratio:(0.14, 0.86) | R: 195.57 | C:  26.00/30.0\n",
            "[FedSGM] it 0248/500 | switching ratio:(0.14, 0.86) | R: 195.55 | C:  25.31/30.0\n",
            "[FedSGM] it 0249/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  27.23/30.0\n",
            "[FedSGM] it 0250/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  26.97/30.0\n",
            "[FedSGM] it 0251/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.14/30.0\n",
            "[FedSGM] it 0252/500 | switching ratio:(0.00, 1.00) | R: 189.11 | C:  28.84/30.0\n",
            "[FedSGM] it 0253/500 | switching ratio:(0.20, 0.80) | R: 191.48 | C:  24.43/30.0\n",
            "[FedSGM] it 0254/500 | switching ratio:(0.13, 0.87) | R: 195.55 | C:  26.38/30.0\n",
            "[FedSGM] it 0255/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0256/500 | switching ratio:(0.22, 0.78) | R: 180.64 | C:  25.29/30.0\n",
            "[FedSGM] it 0257/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  28.14/30.0\n",
            "[FedSGM] it 0258/500 | switching ratio:(0.18, 0.82) | R: 195.55 | C:  26.37/30.0\n",
            "[FedSGM] it 0259/500 | switching ratio:(0.19, 0.81) | R: 195.50 | C:  26.58/30.0\n",
            "[FedSGM] it 0260/500 | switching ratio:(0.00, 1.00) | R: 195.57 | C:  28.65/30.0\n",
            "[FedSGM] it 0261/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  27.74/30.0\n",
            "[FedSGM] it 0262/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0263/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  26.89/30.0\n",
            "[FedSGM] it 0264/500 | switching ratio:(0.25, 0.75) | R: 191.17 | C:  25.54/30.0\n",
            "[FedSGM] it 0265/500 | switching ratio:(0.10, 0.90) | R: 187.94 | C:  26.41/30.0\n",
            "[FedSGM] it 0266/500 | switching ratio:(0.24, 0.76) | R: 195.52 | C:  26.15/30.0\n",
            "[FedSGM] it 0267/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0268/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0269/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  25.26/30.0\n",
            "[FedSGM] it 0270/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  24.66/30.0\n",
            "[FedSGM] it 0271/500 | switching ratio:(0.37, 0.63) | R: 155.34 | C:  24.01/30.0\n",
            "[FedSGM] it 0272/500 | switching ratio:(0.05, 0.95) | R: 195.60 | C:  26.32/30.0\n",
            "[FedSGM] it 0273/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  25.74/30.0\n",
            "[FedSGM] it 0274/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0275/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0276/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.60/30.0\n",
            "[FedSGM] it 0277/500 | switching ratio:(0.27, 0.73) | R: 195.60 | C:  25.24/30.0\n",
            "[FedSGM] it 0278/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0279/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  25.09/30.0\n",
            "[FedSGM] it 0280/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  24.94/30.0\n",
            "[FedSGM] it 0281/500 | switching ratio:(0.37, 0.63) | R: 186.62 | C:  23.32/30.0\n",
            "[FedSGM] it 0282/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  24.80/30.0\n",
            "[FedSGM] it 0283/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.46/30.0\n",
            "[FedSGM] it 0284/500 | switching ratio:(0.03, 0.97) | R: 192.05 | C:  27.75/30.0\n",
            "[FedSGM] it 0285/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  27.40/30.0\n",
            "[FedSGM] it 0286/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.09/30.0\n",
            "[FedSGM] it 0287/500 | switching ratio:(0.06, 0.94) | R: 200.00 | C:  27.11/30.0\n",
            "[FedSGM] it 0288/500 | switching ratio:(0.15, 0.85) | R: 195.60 | C:  25.02/30.0\n",
            "[FedSGM] it 0289/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.94/30.0\n",
            "[FedSGM] it 0290/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  28.06/30.0\n",
            "[FedSGM] it 0291/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  26.09/30.0\n",
            "[FedSGM] it 0292/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.94/30.0\n",
            "[FedSGM] it 0293/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  28.77/30.0\n",
            "[FedSGM] it 0294/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  26.91/30.0\n",
            "[FedSGM] it 0295/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  26.43/30.0\n",
            "[FedSGM] it 0296/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  25.14/30.0\n",
            "[FedSGM] it 0297/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  24.86/30.0\n",
            "[FedSGM] it 0298/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  24.09/30.0\n",
            "[FedSGM] it 0299/500 | switching ratio:(0.21, 0.79) | R: 195.60 | C:  25.55/30.0\n",
            "[FedSGM] it 0300/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0301/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  26.40/30.0\n",
            "[FedSGM] it 0302/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  25.49/30.0\n",
            "[FedSGM] it 0303/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  26.51/30.0\n",
            "[FedSGM] it 0304/500 | switching ratio:(0.28, 0.72) | R: 195.60 | C:  23.93/30.0\n",
            "[FedSGM] it 0305/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  25.29/30.0\n",
            "[FedSGM] it 0306/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  24.66/30.0\n",
            "[FedSGM] it 0307/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  24.89/30.0\n",
            "[FedSGM] it 0308/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  25.29/30.0\n",
            "[FedSGM] it 0309/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  24.26/30.0\n",
            "[FedSGM] it 0310/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.49/30.0\n",
            "[FedSGM] it 0311/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  24.09/30.0\n",
            "[FedSGM] it 0312/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  24.89/30.0\n",
            "[FedSGM] it 0313/500 | switching ratio:(0.24, 0.76) | R: 195.57 | C:  25.28/30.0\n",
            "[FedSGM] it 0314/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  24.80/30.0\n",
            "[FedSGM] it 0315/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  25.03/30.0\n",
            "[FedSGM] it 0316/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.23/30.0\n",
            "[FedSGM] it 0317/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  26.00/30.0\n",
            "[FedSGM] it 0318/500 | switching ratio:(0.32, 0.68) | R: 200.00 | C:  23.20/30.0\n",
            "[FedSGM] it 0319/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  27.06/30.0\n",
            "[FedSGM] it 0320/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  24.14/30.0\n",
            "[FedSGM] it 0321/500 | switching ratio:(0.24, 0.76) | R: 195.98 | C:  24.47/30.0\n",
            "[FedSGM] it 0322/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  25.26/30.0\n",
            "[FedSGM] it 0323/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  25.89/30.0\n",
            "[FedSGM] it 0324/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  25.86/30.0\n",
            "[FedSGM] it 0325/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  26.74/30.0\n",
            "[FedSGM] it 0326/500 | switching ratio:(0.07, 0.93) | R: 195.57 | C:  26.50/30.0\n",
            "[FedSGM] it 0327/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  25.57/30.0\n",
            "[FedSGM] it 0328/500 | switching ratio:(0.13, 0.87) | R: 191.62 | C:  24.93/30.0\n",
            "[FedSGM] it 0329/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  24.97/30.0\n",
            "[FedSGM] it 0330/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.11/30.0\n",
            "[FedSGM] it 0331/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  27.20/30.0\n",
            "[FedSGM] it 0332/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  24.00/30.0\n",
            "[FedSGM] it 0333/500 | switching ratio:(0.26, 0.74) | R: 195.98 | C:  24.29/30.0\n",
            "[FedSGM] it 0334/500 | switching ratio:(0.07, 0.93) | R: 200.00 | C:  27.77/30.0\n",
            "[FedSGM] it 0335/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0336/500 | switching ratio:(0.03, 0.97) | R: 196.02 | C:  27.81/30.0\n",
            "[FedSGM] it 0337/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  26.09/30.0\n",
            "[FedSGM] it 0338/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  26.69/30.0\n",
            "[FedSGM] it 0339/500 | switching ratio:(0.13, 0.87) | R: 200.00 | C:  25.66/30.0\n",
            "[FedSGM] it 0340/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  26.17/30.0\n",
            "[FedSGM] it 0341/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  27.11/30.0\n",
            "[FedSGM] it 0342/500 | switching ratio:(0.04, 0.96) | R: 196.02 | C:  27.81/30.0\n",
            "[FedSGM] it 0343/500 | switching ratio:(0.12, 0.88) | R: 195.52 | C:  26.29/30.0\n",
            "[FedSGM] it 0344/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  25.20/30.0\n",
            "[FedSGM] it 0345/500 | switching ratio:(0.22, 0.78) | R: 191.50 | C:  25.98/30.0\n",
            "[FedSGM] it 0346/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  25.43/30.0\n",
            "[FedSGM] it 0347/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.34/30.0\n",
            "[FedSGM] it 0348/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.91/30.0\n",
            "[FedSGM] it 0349/500 | switching ratio:(0.10, 0.90) | R: 196.02 | C:  27.35/30.0\n",
            "[FedSGM] it 0350/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.54/30.0\n",
            "[FedSGM] it 0351/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.91/30.0\n",
            "[FedSGM] it 0352/500 | switching ratio:(0.00, 1.00) | R: 195.55 | C:  27.80/30.0\n",
            "[FedSGM] it 0353/500 | switching ratio:(0.00, 1.00) | R: 183.81 | C:  28.20/30.0\n",
            "[FedSGM] it 0354/500 | switching ratio:(0.15, 0.85) | R: 195.55 | C:  25.08/30.0\n",
            "[FedSGM] it 0355/500 | switching ratio:(0.20, 0.80) | R: 196.02 | C:  26.25/30.0\n",
            "[FedSGM] it 0356/500 | switching ratio:(0.15, 0.85) | R: 182.49 | C:  26.11/30.0\n",
            "[FedSGM] it 0357/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  26.06/30.0\n",
            "[FedSGM] it 0358/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.57/30.0\n",
            "[FedSGM] it 0359/500 | switching ratio:(0.07, 0.93) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0360/500 | switching ratio:(0.11, 0.89) | R: 195.52 | C:  25.97/30.0\n",
            "[FedSGM] it 0361/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  26.57/30.0\n",
            "[FedSGM] it 0362/500 | switching ratio:(0.19, 0.81) | R: 195.55 | C:  25.51/30.0\n",
            "[FedSGM] it 0363/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.97/30.0\n",
            "[FedSGM] it 0364/500 | switching ratio:(0.30, 0.70) | R: 191.93 | C:  24.89/30.0\n",
            "[FedSGM] it 0365/500 | switching ratio:(0.24, 0.76) | R: 195.55 | C:  25.12/30.0\n",
            "[FedSGM] it 0366/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.77/30.0\n",
            "[FedSGM] it 0367/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  26.71/30.0\n",
            "[FedSGM] it 0368/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.23/30.0\n",
            "[FedSGM] it 0369/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.66/30.0\n",
            "[FedSGM] it 0370/500 | switching ratio:(0.10, 0.90) | R: 195.55 | C:  26.79/30.0\n",
            "[FedSGM] it 0371/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.17/30.0\n",
            "[FedSGM] it 0372/500 | switching ratio:(0.33, 0.67) | R: 195.57 | C:  25.00/30.0\n",
            "[FedSGM] it 0373/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  26.91/30.0\n",
            "[FedSGM] it 0374/500 | switching ratio:(0.10, 0.90) | R: 196.02 | C:  26.64/30.0\n",
            "[FedSGM] it 0375/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  26.69/30.0\n",
            "[FedSGM] it 0376/500 | switching ratio:(0.06, 0.94) | R: 200.00 | C:  26.34/30.0\n",
            "[FedSGM] it 0377/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  27.94/30.0\n",
            "[FedSGM] it 0378/500 | switching ratio:(0.07, 0.93) | R: 200.00 | C:  28.03/30.0\n",
            "[FedSGM] it 0379/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  24.31/30.0\n",
            "[FedSGM] it 0380/500 | switching ratio:(0.30, 0.70) | R: 184.29 | C:  24.27/30.0\n",
            "[FedSGM] it 0381/500 | switching ratio:(0.07, 0.93) | R: 200.00 | C:  25.94/30.0\n",
            "[FedSGM] it 0382/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  23.26/30.0\n",
            "[FedSGM] it 0383/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.91/30.0\n",
            "[FedSGM] it 0384/500 | switching ratio:(0.36, 0.64) | R: 200.00 | C:  24.63/30.0\n",
            "[FedSGM] it 0385/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0386/500 | switching ratio:(0.23, 0.77) | R: 195.60 | C:  25.22/30.0\n",
            "[FedSGM] it 0387/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  25.77/30.0\n",
            "[FedSGM] it 0388/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.31/30.0\n",
            "[FedSGM] it 0389/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  28.00/30.0\n",
            "[FedSGM] it 0390/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  28.57/30.0\n",
            "[FedSGM] it 0391/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.83/30.0\n",
            "[FedSGM] it 0392/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  27.06/30.0\n",
            "[FedSGM] it 0393/500 | switching ratio:(0.02, 0.98) | R: 195.57 | C:  28.02/30.0\n",
            "[FedSGM] it 0394/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.09/30.0\n",
            "[FedSGM] it 0395/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  26.69/30.0\n",
            "[FedSGM] it 0396/500 | switching ratio:(0.28, 0.72) | R: 191.19 | C:  24.35/30.0\n",
            "[FedSGM] it 0397/500 | switching ratio:(0.01, 0.99) | R: 191.64 | C:  27.65/30.0\n",
            "[FedSGM] it 0398/500 | switching ratio:(0.34, 0.66) | R: 200.00 | C:  24.26/30.0\n",
            "[FedSGM] it 0399/500 | switching ratio:(0.24, 0.76) | R: 200.00 | C:  24.51/30.0\n",
            "[FedSGM] it 0400/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  26.00/30.0\n",
            "[FedSGM] it 0401/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  27.37/30.0\n",
            "[FedSGM] it 0402/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  25.74/30.0\n",
            "[FedSGM] it 0403/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  27.26/30.0\n",
            "[FedSGM] it 0404/500 | switching ratio:(0.19, 0.81) | R: 195.55 | C:  25.51/30.0\n",
            "[FedSGM] it 0405/500 | switching ratio:(0.20, 0.80) | R: 195.98 | C:  24.82/30.0\n",
            "[FedSGM] it 0406/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  25.17/30.0\n",
            "[FedSGM] it 0407/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  26.46/30.0\n",
            "[FedSGM] it 0408/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  26.06/30.0\n",
            "[FedSGM] it 0409/500 | switching ratio:(0.19, 0.81) | R: 195.57 | C:  25.70/30.0\n",
            "[FedSGM] it 0410/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  26.00/30.0\n",
            "[FedSGM] it 0411/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.80/30.0\n",
            "[FedSGM] it 0412/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  27.80/30.0\n",
            "[FedSGM] it 0413/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  28.34/30.0\n",
            "[FedSGM] it 0414/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  26.97/30.0\n",
            "[FedSGM] it 0415/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  26.23/30.0\n",
            "[FedSGM] it 0416/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  27.29/30.0\n",
            "[FedSGM] it 0417/500 | switching ratio:(0.06, 0.94) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0418/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  27.94/30.0\n",
            "[FedSGM] it 0419/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  25.80/30.0\n",
            "[FedSGM] it 0420/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.26/30.0\n",
            "[FedSGM] it 0421/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.43/30.0\n",
            "[FedSGM] it 0422/500 | switching ratio:(0.13, 0.87) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0423/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  27.49/30.0\n",
            "[FedSGM] it 0424/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  25.40/30.0\n",
            "[FedSGM] it 0425/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  24.63/30.0\n",
            "[FedSGM] it 0426/500 | switching ratio:(0.10, 0.90) | R: 195.57 | C:  26.56/30.0\n",
            "[FedSGM] it 0427/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  26.14/30.0\n",
            "[FedSGM] it 0428/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  25.54/30.0\n",
            "[FedSGM] it 0429/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0430/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  25.37/30.0\n",
            "[FedSGM] it 0431/500 | switching ratio:(0.24, 0.76) | R: 200.00 | C:  25.86/30.0\n",
            "[FedSGM] it 0432/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  25.97/30.0\n",
            "[FedSGM] it 0433/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.11/30.0\n",
            "[FedSGM] it 0434/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  25.74/30.0\n",
            "[FedSGM] it 0435/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  25.89/30.0\n",
            "[FedSGM] it 0436/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  25.29/30.0\n",
            "[FedSGM] it 0437/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  26.94/30.0\n",
            "[FedSGM] it 0438/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  27.31/30.0\n",
            "[FedSGM] it 0439/500 | switching ratio:(0.01, 0.99) | R: 200.00 | C:  28.00/30.0\n",
            "[FedSGM] it 0440/500 | switching ratio:(0.14, 0.86) | R: 191.07 | C:  25.92/30.0\n",
            "[FedSGM] it 0441/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  26.60/30.0\n",
            "[FedSGM] it 0442/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0443/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  24.83/30.0\n",
            "[FedSGM] it 0444/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  25.97/30.0\n",
            "[FedSGM] it 0445/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  25.20/30.0\n",
            "[FedSGM] it 0446/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0447/500 | switching ratio:(0.37, 0.63) | R: 200.00 | C:  24.17/30.0\n",
            "[FedSGM] it 0448/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0449/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  25.26/30.0\n",
            "[FedSGM] it 0450/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.09/30.0\n",
            "[FedSGM] it 0451/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0452/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  26.54/30.0\n",
            "[FedSGM] it 0453/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  26.14/30.0\n",
            "[FedSGM] it 0454/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  25.97/30.0\n",
            "[FedSGM] it 0455/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.74/30.0\n",
            "[FedSGM] it 0456/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  26.43/30.0\n",
            "[FedSGM] it 0457/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  25.09/30.0\n",
            "[FedSGM] it 0458/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0459/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.57/30.0\n",
            "[FedSGM] it 0460/500 | switching ratio:(0.24, 0.76) | R: 200.00 | C:  24.89/30.0\n",
            "[FedSGM] it 0461/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  24.91/30.0\n",
            "[FedSGM] it 0462/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  25.14/30.0\n",
            "[FedSGM] it 0463/500 | switching ratio:(0.03, 0.97) | R: 196.05 | C:  27.76/30.0\n",
            "[FedSGM] it 0464/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  27.49/30.0\n",
            "[FedSGM] it 0465/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  26.54/30.0\n",
            "[FedSGM] it 0466/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  28.40/30.0\n",
            "[FedSGM] it 0467/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.11/30.0\n",
            "[FedSGM] it 0468/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.20/30.0\n",
            "[FedSGM] it 0469/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  27.03/30.0\n",
            "[FedSGM] it 0470/500 | switching ratio:(0.17, 0.83) | R: 187.19 | C:  25.87/30.0\n",
            "[FedSGM] it 0471/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  24.43/30.0\n",
            "[FedSGM] it 0472/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  26.80/30.0\n",
            "[FedSGM] it 0473/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  24.49/30.0\n",
            "[FedSGM] it 0474/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  25.60/30.0\n",
            "[FedSGM] it 0475/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  24.97/30.0\n",
            "[FedSGM] it 0476/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  26.31/30.0\n",
            "[FedSGM] it 0477/500 | switching ratio:(0.03, 0.97) | R: 200.00 | C:  28.54/30.0\n",
            "[FedSGM] it 0478/500 | switching ratio:(0.06, 0.94) | R: 200.00 | C:  27.29/30.0\n",
            "[FedSGM] it 0479/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0480/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  29.06/30.0\n",
            "[FedSGM] it 0481/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  28.20/30.0\n",
            "[FedSGM] it 0482/500 | switching ratio:(0.06, 0.94) | R: 196.05 | C:  27.18/30.0\n",
            "[FedSGM] it 0483/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  26.83/30.0\n",
            "[FedSGM] it 0484/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  24.34/30.0\n",
            "[FedSGM] it 0485/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  25.83/30.0\n",
            "[FedSGM] it 0486/500 | switching ratio:(0.23, 0.77) | R: 191.12 | C:  24.74/30.0\n",
            "[FedSGM] it 0487/500 | switching ratio:(0.22, 0.78) | R: 195.60 | C:  23.93/30.0\n",
            "[FedSGM] it 0488/500 | switching ratio:(0.01, 0.99) | R: 200.00 | C:  26.17/30.0\n",
            "[FedSGM] it 0489/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0490/500 | switching ratio:(0.07, 0.93) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0491/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.17/30.0\n",
            "[FedSGM] it 0492/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  26.63/30.0\n",
            "[FedSGM] it 0493/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  24.89/30.0\n",
            "[FedSGM] it 0494/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  25.94/30.0\n",
            "[FedSGM] it 0495/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  25.80/30.0\n",
            "[FedSGM] it 0496/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  25.09/30.0\n",
            "[FedSGM] it 0497/500 | switching ratio:(0.33, 0.67) | R: 200.00 | C:  23.69/30.0\n",
            "[FedSGM] it 0498/500 | switching ratio:(0.06, 0.94) | R: 200.00 | C:  26.11/30.0\n",
            "[FedSGM] it 0499/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  24.46/30.0\n",
            "[FedSGM] it 0500/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  24.34/30.0\n",
            "Avg return over last 50 feasible rounds: 199.32\n",
            "\n",
            "--- Running Experiment 3/5 ---\n",
            "Starting parallel federated learning for 500 rounds with 10 total clients and 7 selected clients per round.\n",
            "[FedSGM] it 0001/500 | switching ratio:(0.73, 0.27) | R:  22.44 | C:  21.43/30.0\n",
            "[FedSGM] it 0002/500 | switching ratio:(0.11, 0.89) | R:  31.40 | C:  28.76/30.0\n",
            "[FedSGM] it 0003/500 | switching ratio:(0.83, 0.17) | R:  19.80 | C:  18.82/30.0\n",
            "[FedSGM] it 0004/500 | switching ratio:(0.20, 0.80) | R:  29.30 | C:  26.81/30.0\n",
            "[FedSGM] it 0005/500 | switching ratio:(0.69, 0.31) | R:  22.49 | C:  21.26/30.0\n",
            "[FedSGM] it 0006/500 | switching ratio:(0.25, 0.75) | R:  28.97 | C:  26.75/30.0\n",
            "[FedSGM] it 0007/500 | switching ratio:(0.53, 0.47) | R:  22.68 | C:  21.63/30.0\n",
            "[FedSGM] it 0008/500 | switching ratio:(0.72, 0.28) | R:  21.69 | C:  20.29/30.0\n",
            "[FedSGM] it 0009/500 | switching ratio:(0.01, 0.99) | R:  34.97 | C:  30.75/30.0\n",
            "[FedSGM] it 0010/500 | switching ratio:(0.52, 0.48) | R:  25.44 | C:  23.81/30.0\n",
            "[FedSGM] it 0011/500 | switching ratio:(0.53, 0.47) | R:  23.17 | C:  21.58/30.0\n",
            "[FedSGM] it 0012/500 | switching ratio:(0.08, 0.92) | R:  33.88 | C:  29.36/30.0\n",
            "[FedSGM] it 0013/500 | switching ratio:(0.56, 0.44) | R:  23.38 | C:  21.66/30.0\n",
            "[FedSGM] it 0014/500 | switching ratio:(0.31, 0.69) | R:  27.23 | C:  25.03/30.0\n",
            "[FedSGM] it 0015/500 | switching ratio:(0.75, 0.25) | R:  18.79 | C:  17.85/30.0\n",
            "[FedSGM] it 0016/500 | switching ratio:(0.72, 0.28) | R:  21.50 | C:  20.08/30.0\n",
            "[FedSGM] it 0017/500 | switching ratio:(0.00, 1.00) | R:  37.38 | C:  31.63/30.0\n",
            "[FedSGM] it 0018/500 | switching ratio:(0.08, 0.92) | R:  34.60 | C:  30.74/30.0\n",
            "[FedSGM] it 0019/500 | switching ratio:(0.58, 0.42) | R:  22.69 | C:  21.29/30.0\n",
            "[FedSGM] it 0020/500 | switching ratio:(0.99, 0.01) | R:  17.36 | C:  16.65/30.0\n",
            "[FedSGM] it 0021/500 | switching ratio:(0.63, 0.37) | R:  21.97 | C:  20.68/30.0\n",
            "[FedSGM] it 0022/500 | switching ratio:(0.00, 1.00) | R:  35.02 | C:  31.07/30.0\n",
            "[FedSGM] it 0023/500 | switching ratio:(0.09, 0.91) | R:  32.35 | C:  28.73/30.0\n",
            "[FedSGM] it 0024/500 | switching ratio:(0.57, 0.43) | R:  24.28 | C:  22.46/30.0\n",
            "[FedSGM] it 0025/500 | switching ratio:(0.82, 0.18) | R:  19.70 | C:  18.64/30.0\n",
            "[FedSGM] it 0026/500 | switching ratio:(0.84, 0.16) | R:  19.30 | C:  18.26/30.0\n",
            "[FedSGM] it 0027/500 | switching ratio:(0.73, 0.27) | R:  22.62 | C:  21.21/30.0\n",
            "[FedSGM] it 0028/500 | switching ratio:(0.00, 1.00) | R:  36.12 | C:  31.19/30.0\n",
            "[FedSGM] it 0029/500 | switching ratio:(0.00, 1.00) | R:  38.82 | C:  33.92/30.0\n",
            "[FedSGM] it 0030/500 | switching ratio:(0.33, 0.67) | R:  27.77 | C:  24.88/30.0\n",
            "[FedSGM] it 0031/500 | switching ratio:(0.68, 0.32) | R:  22.40 | C:  21.08/30.0\n",
            "[FedSGM] it 0032/500 | switching ratio:(0.71, 0.29) | R:  22.23 | C:  20.66/30.0\n",
            "[FedSGM] it 0033/500 | switching ratio:(0.00, 1.00) | R:  33.96 | C:  30.28/30.0\n",
            "[FedSGM] it 0034/500 | switching ratio:(0.48, 0.52) | R:  24.24 | C:  22.23/30.0\n",
            "[FedSGM] it 0035/500 | switching ratio:(0.75, 0.25) | R:  20.86 | C:  19.69/30.0\n",
            "[FedSGM] it 0036/500 | switching ratio:(0.56, 0.44) | R:  24.06 | C:  21.94/30.0\n",
            "[FedSGM] it 0037/500 | switching ratio:(0.00, 1.00) | R:  37.06 | C:  31.53/30.0\n",
            "[FedSGM] it 0038/500 | switching ratio:(0.03, 0.97) | R:  34.62 | C:  30.17/30.0\n",
            "[FedSGM] it 0039/500 | switching ratio:(0.57, 0.43) | R:  22.78 | C:  21.28/30.0\n",
            "[FedSGM] it 0040/500 | switching ratio:(1.00, 0.00) | R:  16.23 | C:  15.67/30.0\n",
            "[FedSGM] it 0041/500 | switching ratio:(0.71, 0.29) | R:  21.23 | C:  20.14/30.0\n",
            "[FedSGM] it 0042/500 | switching ratio:(0.57, 0.43) | R:  23.10 | C:  21.56/30.0\n",
            "[FedSGM] it 0043/500 | switching ratio:(0.00, 1.00) | R:  35.68 | C:  31.29/30.0\n",
            "[FedSGM] it 0044/500 | switching ratio:(0.16, 0.84) | R:  32.86 | C:  28.62/30.0\n",
            "[FedSGM] it 0045/500 | switching ratio:(0.54, 0.46) | R:  25.79 | C:  23.68/30.0\n",
            "[FedSGM] it 0046/500 | switching ratio:(0.66, 0.34) | R:  20.69 | C:  19.38/30.0\n",
            "[FedSGM] it 0047/500 | switching ratio:(0.45, 0.55) | R:  26.15 | C:  23.74/30.0\n",
            "[FedSGM] it 0048/500 | switching ratio:(0.00, 1.00) | R:  49.45 | C:  37.94/30.0\n",
            "[FedSGM] it 0049/500 | switching ratio:(0.15, 0.85) | R:  30.30 | C:  27.31/30.0\n",
            "[FedSGM] it 0050/500 | switching ratio:(0.60, 0.40) | R:  23.98 | C:  21.79/30.0\n",
            "[FedSGM] it 0051/500 | switching ratio:(0.70, 0.30) | R:  22.41 | C:  21.13/30.0\n",
            "[FedSGM] it 0052/500 | switching ratio:(0.31, 0.69) | R:  30.02 | C:  26.07/30.0\n",
            "[FedSGM] it 0053/500 | switching ratio:(0.20, 0.80) | R:  32.20 | C:  28.44/30.0\n",
            "[FedSGM] it 0054/500 | switching ratio:(0.59, 0.41) | R:  23.90 | C:  22.10/30.0\n",
            "[FedSGM] it 0055/500 | switching ratio:(0.64, 0.36) | R:  24.30 | C:  22.30/30.0\n",
            "[FedSGM] it 0056/500 | switching ratio:(0.28, 0.72) | R:  30.07 | C:  26.91/30.0\n",
            "[FedSGM] it 0057/500 | switching ratio:(0.44, 0.56) | R:  28.72 | C:  25.44/30.0\n",
            "[FedSGM] it 0058/500 | switching ratio:(0.59, 0.41) | R:  22.97 | C:  21.29/30.0\n",
            "[FedSGM] it 0059/500 | switching ratio:(0.17, 0.83) | R:  30.50 | C:  27.21/30.0\n",
            "[FedSGM] it 0060/500 | switching ratio:(0.55, 0.45) | R:  25.19 | C:  23.00/30.0\n",
            "[FedSGM] it 0061/500 | switching ratio:(0.63, 0.37) | R:  23.31 | C:  21.55/30.0\n",
            "[FedSGM] it 0062/500 | switching ratio:(0.46, 0.54) | R:  26.76 | C:  24.16/30.0\n",
            "[FedSGM] it 0063/500 | switching ratio:(0.38, 0.62) | R:  28.21 | C:  24.70/30.0\n",
            "[FedSGM] it 0064/500 | switching ratio:(0.27, 0.73) | R:  29.12 | C:  25.87/30.0\n",
            "[FedSGM] it 0065/500 | switching ratio:(0.61, 0.39) | R:  23.90 | C:  21.82/30.0\n",
            "[FedSGM] it 0066/500 | switching ratio:(0.02, 0.98) | R:  36.73 | C:  30.14/30.0\n",
            "[FedSGM] it 0067/500 | switching ratio:(0.40, 0.60) | R:  29.82 | C:  26.03/30.0\n",
            "[FedSGM] it 0068/500 | switching ratio:(0.78, 0.22) | R:  20.30 | C:  18.93/30.0\n",
            "[FedSGM] it 0069/500 | switching ratio:(0.70, 0.30) | R:  22.39 | C:  20.89/30.0\n",
            "[FedSGM] it 0070/500 | switching ratio:(0.62, 0.38) | R:  22.50 | C:  20.83/30.0\n",
            "[FedSGM] it 0071/500 | switching ratio:(0.45, 0.55) | R:  26.74 | C:  24.21/30.0\n",
            "[FedSGM] it 0072/500 | switching ratio:(0.00, 1.00) | R:  35.54 | C:  30.65/30.0\n",
            "[FedSGM] it 0073/500 | switching ratio:(0.43, 0.57) | R:  28.35 | C:  25.12/30.0\n",
            "[FedSGM] it 0074/500 | switching ratio:(0.59, 0.41) | R:  22.20 | C:  20.37/30.0\n",
            "[FedSGM] it 0075/500 | switching ratio:(0.62, 0.38) | R:  23.82 | C:  21.92/30.0\n",
            "[FedSGM] it 0076/500 | switching ratio:(0.58, 0.42) | R:  24.90 | C:  22.64/30.0\n",
            "[FedSGM] it 0077/500 | switching ratio:(0.19, 0.81) | R:  31.44 | C:  27.08/30.0\n",
            "[FedSGM] it 0078/500 | switching ratio:(0.14, 0.86) | R:  31.47 | C:  27.39/30.0\n",
            "[FedSGM] it 0079/500 | switching ratio:(0.64, 0.36) | R:  24.32 | C:  22.13/30.0\n",
            "[FedSGM] it 0080/500 | switching ratio:(0.44, 0.56) | R:  26.46 | C:  23.84/30.0\n",
            "[FedSGM] it 0081/500 | switching ratio:(0.37, 0.63) | R:  29.49 | C:  24.98/30.0\n",
            "[FedSGM] it 0082/500 | switching ratio:(0.16, 0.84) | R:  35.93 | C:  27.76/30.0\n",
            "[FedSGM] it 0083/500 | switching ratio:(0.32, 0.68) | R:  32.49 | C:  25.45/30.0\n",
            "[FedSGM] it 0084/500 | switching ratio:(0.98, 0.02) | R:  17.37 | C:  15.66/30.0\n",
            "[FedSGM] it 0085/500 | switching ratio:(0.70, 0.30) | R:  23.97 | C:  18.93/30.0\n",
            "[FedSGM] it 0086/500 | switching ratio:(0.90, 0.10) | R:  21.65 | C:  18.32/30.0\n",
            "[FedSGM] it 0087/500 | switching ratio:(0.95, 0.05) | R:  20.56 | C:  17.38/30.0\n",
            "[FedSGM] it 0088/500 | switching ratio:(0.47, 0.53) | R:  31.67 | C:  23.71/30.0\n",
            "[FedSGM] it 0089/500 | switching ratio:(0.00, 1.00) | R:  55.26 | C:  35.65/30.0\n",
            "[FedSGM] it 0090/500 | switching ratio:(0.00, 1.00) | R:  52.29 | C:  34.35/30.0\n",
            "[FedSGM] it 0091/500 | switching ratio:(0.00, 1.00) | R:  60.44 | C:  37.08/30.0\n",
            "[FedSGM] it 0092/500 | switching ratio:(0.95, 0.05) | R:  22.56 | C:  18.28/30.0\n",
            "[FedSGM] it 0093/500 | switching ratio:(0.56, 0.44) | R:  32.02 | C:  23.96/30.0\n",
            "[FedSGM] it 0094/500 | switching ratio:(0.67, 0.33) | R:  27.20 | C:  20.66/30.0\n",
            "[FedSGM] it 0095/500 | switching ratio:(0.46, 0.54) | R:  34.57 | C:  25.21/30.0\n",
            "[FedSGM] it 0096/500 | switching ratio:(0.41, 0.59) | R:  36.98 | C:  24.44/30.0\n",
            "[FedSGM] it 0097/500 | switching ratio:(0.00, 1.00) | R:  88.81 | C:  50.93/30.0\n",
            "[FedSGM] it 0098/500 | switching ratio:(0.00, 1.00) | R:  63.12 | C:  38.17/30.0\n",
            "[FedSGM] it 0099/500 | switching ratio:(0.00, 1.00) | R:  71.16 | C:  42.75/30.0\n",
            "[FedSGM] it 0100/500 | switching ratio:(0.18, 0.82) | R:  43.93 | C:  27.14/30.0\n",
            "[FedSGM] it 0101/500 | switching ratio:(0.85, 0.15) | R:  21.06 | C:  17.02/30.0\n",
            "[FedSGM] it 0102/500 | switching ratio:(1.00, 0.00) | R:  19.03 | C:  15.73/30.0\n",
            "[FedSGM] it 0103/500 | switching ratio:(1.00, 0.00) | R:  17.39 | C:  15.40/30.0\n",
            "[FedSGM] it 0104/500 | switching ratio:(1.00, 0.00) | R:  17.19 | C:  14.92/30.0\n",
            "[FedSGM] it 0105/500 | switching ratio:(0.96, 0.04) | R:  21.86 | C:  17.20/30.0\n",
            "[FedSGM] it 0106/500 | switching ratio:(0.44, 0.56) | R:  32.32 | C:  24.36/30.0\n",
            "[FedSGM] it 0107/500 | switching ratio:(0.39, 0.61) | R:  35.70 | C:  24.11/30.0\n",
            "[FedSGM] it 0108/500 | switching ratio:(0.30, 0.70) | R:  36.20 | C:  24.93/30.0\n",
            "[FedSGM] it 0109/500 | switching ratio:(0.55, 0.45) | R:  34.01 | C:  23.69/30.0\n",
            "[FedSGM] it 0110/500 | switching ratio:(0.00, 1.00) | R:  68.39 | C:  39.30/30.0\n",
            "[FedSGM] it 0111/500 | switching ratio:(0.00, 1.00) | R:  59.70 | C:  33.89/30.0\n",
            "[FedSGM] it 0112/500 | switching ratio:(0.97, 0.03) | R:  21.37 | C:  16.21/30.0\n",
            "[FedSGM] it 0113/500 | switching ratio:(1.00, 0.00) | R:  21.72 | C:  16.62/30.0\n",
            "[FedSGM] it 0114/500 | switching ratio:(1.00, 0.00) | R:  21.02 | C:  16.33/30.0\n",
            "[FedSGM] it 0115/500 | switching ratio:(0.71, 0.29) | R:  25.47 | C:  18.37/30.0\n",
            "[FedSGM] it 0116/500 | switching ratio:(0.26, 0.74) | R:  40.86 | C:  26.06/30.0\n",
            "[FedSGM] it 0117/500 | switching ratio:(0.34, 0.66) | R:  41.03 | C:  26.04/30.0\n",
            "[FedSGM] it 0118/500 | switching ratio:(0.23, 0.77) | R:  39.78 | C:  25.79/30.0\n",
            "[FedSGM] it 0119/500 | switching ratio:(0.08, 0.92) | R:  44.21 | C:  29.09/30.0\n",
            "[FedSGM] it 0120/500 | switching ratio:(0.18, 0.82) | R:  45.12 | C:  28.61/30.0\n",
            "[FedSGM] it 0121/500 | switching ratio:(1.00, 0.00) | R:  14.79 | C:  13.11/30.0\n",
            "[FedSGM] it 0122/500 | switching ratio:(1.00, 0.00) | R:  14.70 | C:  13.00/30.0\n",
            "[FedSGM] it 0123/500 | switching ratio:(1.00, 0.00) | R:  15.74 | C:  13.81/30.0\n",
            "[FedSGM] it 0124/500 | switching ratio:(1.00, 0.00) | R:  17.25 | C:  14.28/30.0\n",
            "[FedSGM] it 0125/500 | switching ratio:(1.00, 0.00) | R:  14.88 | C:  13.17/30.0\n",
            "[FedSGM] it 0126/500 | switching ratio:(0.90, 0.10) | R:  23.15 | C:  17.78/30.0\n",
            "[FedSGM] it 0127/500 | switching ratio:(0.03, 0.97) | R:  51.40 | C:  30.46/30.0\n",
            "[FedSGM] it 0128/500 | switching ratio:(0.12, 0.88) | R:  51.11 | C:  29.43/30.0\n",
            "[FedSGM] it 0129/500 | switching ratio:(0.39, 0.61) | R:  39.31 | C:  24.82/30.0\n",
            "[FedSGM] it 0130/500 | switching ratio:(0.60, 0.40) | R:  36.61 | C:  22.52/30.0\n",
            "[FedSGM] it 0131/500 | switching ratio:(0.49, 0.51) | R:  34.59 | C:  22.87/30.0\n",
            "[FedSGM] it 0132/500 | switching ratio:(0.17, 0.83) | R:  41.60 | C:  26.14/30.0\n",
            "[FedSGM] it 0133/500 | switching ratio:(0.18, 0.82) | R:  45.99 | C:  28.27/30.0\n",
            "[FedSGM] it 0134/500 | switching ratio:(0.08, 0.92) | R:  44.55 | C:  28.55/30.0\n",
            "[FedSGM] it 0135/500 | switching ratio:(1.00, 0.00) | R:  21.12 | C:  15.20/30.0\n",
            "[FedSGM] it 0136/500 | switching ratio:(1.00, 0.00) | R:  17.15 | C:  14.06/30.0\n",
            "[FedSGM] it 0137/500 | switching ratio:(1.00, 0.00) | R:  20.33 | C:  15.78/30.0\n",
            "[FedSGM] it 0138/500 | switching ratio:(1.00, 0.00) | R:  21.23 | C:  15.75/30.0\n",
            "[FedSGM] it 0139/500 | switching ratio:(0.54, 0.46) | R:  37.85 | C:  22.95/30.0\n",
            "[FedSGM] it 0140/500 | switching ratio:(0.00, 1.00) | R:  56.42 | C:  30.95/30.0\n",
            "[FedSGM] it 0141/500 | switching ratio:(0.00, 1.00) | R:  50.36 | C:  29.99/30.0\n",
            "[FedSGM] it 0142/500 | switching ratio:(0.00, 1.00) | R:  60.51 | C:  33.38/30.0\n",
            "[FedSGM] it 0143/500 | switching ratio:(0.93, 0.07) | R:  26.59 | C:  17.57/30.0\n",
            "[FedSGM] it 0144/500 | switching ratio:(0.89, 0.11) | R:  25.22 | C:  16.97/30.0\n",
            "[FedSGM] it 0145/500 | switching ratio:(0.68, 0.32) | R:  31.64 | C:  20.47/30.0\n",
            "[FedSGM] it 0146/500 | switching ratio:(0.36, 0.64) | R:  44.26 | C:  24.99/30.0\n",
            "[FedSGM] it 0147/500 | switching ratio:(0.00, 1.00) | R:  85.67 | C:  42.64/30.0\n",
            "[FedSGM] it 0148/500 | switching ratio:(0.00, 1.00) | R:  81.44 | C:  39.78/30.0\n",
            "[FedSGM] it 0149/500 | switching ratio:(0.00, 1.00) | R:  86.61 | C:  43.79/30.0\n",
            "[FedSGM] it 0150/500 | switching ratio:(0.69, 0.31) | R:  32.51 | C:  21.40/30.0\n",
            "[FedSGM] it 0151/500 | switching ratio:(1.00, 0.00) | R:  14.95 | C:  12.36/30.0\n",
            "[FedSGM] it 0152/500 | switching ratio:(1.00, 0.00) | R:  20.50 | C:  14.60/30.0\n",
            "[FedSGM] it 0153/500 | switching ratio:(1.00, 0.00) | R:  19.99 | C:  14.76/30.0\n",
            "[FedSGM] it 0154/500 | switching ratio:(0.52, 0.48) | R:  37.18 | C:  22.02/30.0\n",
            "[FedSGM] it 0155/500 | switching ratio:(0.05, 0.95) | R:  56.31 | C:  30.77/30.0\n",
            "[FedSGM] it 0156/500 | switching ratio:(0.00, 1.00) | R:  55.74 | C:  30.98/30.0\n",
            "[FedSGM] it 0157/500 | switching ratio:(0.00, 1.00) | R:  63.38 | C:  34.24/30.0\n",
            "[FedSGM] it 0158/500 | switching ratio:(0.00, 1.00) | R:  58.15 | C:  31.85/30.0\n",
            "[FedSGM] it 0159/500 | switching ratio:(0.99, 0.01) | R:  23.20 | C:  15.66/30.0\n",
            "[FedSGM] it 0160/500 | switching ratio:(1.00, 0.00) | R:  19.10 | C:  13.89/30.0\n",
            "[FedSGM] it 0161/500 | switching ratio:(0.97, 0.03) | R:  25.73 | C:  16.99/30.0\n",
            "[FedSGM] it 0162/500 | switching ratio:(0.15, 0.85) | R:  48.83 | C:  27.64/30.0\n",
            "[FedSGM] it 0163/500 | switching ratio:(0.30, 0.70) | R:  44.35 | C:  24.92/30.0\n",
            "[FedSGM] it 0164/500 | switching ratio:(0.00, 1.00) | R:  81.57 | C:  40.58/30.0\n",
            "[FedSGM] it 0165/500 | switching ratio:(0.00, 1.00) | R:  97.91 | C:  44.97/30.0\n",
            "[FedSGM] it 0166/500 | switching ratio:(0.00, 1.00) | R:  85.70 | C:  41.37/30.0\n",
            "[FedSGM] it 0167/500 | switching ratio:(0.73, 0.27) | R:  32.24 | C:  18.95/30.0\n",
            "[FedSGM] it 0168/500 | switching ratio:(0.66, 0.34) | R:  38.21 | C:  22.33/30.0\n",
            "[FedSGM] it 0169/500 | switching ratio:(0.56, 0.44) | R:  40.68 | C:  22.34/30.0\n",
            "[FedSGM] it 0170/500 | switching ratio:(0.00, 1.00) | R:  71.58 | C:  34.22/30.0\n",
            "[FedSGM] it 0171/500 | switching ratio:(0.00, 1.00) | R:  81.02 | C:  38.92/30.0\n",
            "[FedSGM] it 0172/500 | switching ratio:(0.21, 0.79) | R:  56.25 | C:  27.47/30.0\n",
            "[FedSGM] it 0173/500 | switching ratio:(1.00, 0.00) | R:  22.84 | C:  14.27/30.0\n",
            "[FedSGM] it 0174/500 | switching ratio:(1.00, 0.00) | R:  26.77 | C:  15.82/30.0\n",
            "[FedSGM] it 0175/500 | switching ratio:(0.87, 0.13) | R:  33.74 | C:  18.02/30.0\n",
            "[FedSGM] it 0176/500 | switching ratio:(0.61, 0.39) | R:  44.86 | C:  23.02/30.0\n",
            "[FedSGM] it 0177/500 | switching ratio:(0.00, 1.00) | R:  92.78 | C:  39.72/30.0\n",
            "[FedSGM] it 0178/500 | switching ratio:(0.00, 1.00) | R: 102.86 | C:  43.41/30.0\n",
            "[FedSGM] it 0179/500 | switching ratio:(0.00, 1.00) | R: 102.31 | C:  43.67/30.0\n",
            "[FedSGM] it 0180/500 | switching ratio:(0.00, 1.00) | R: 100.87 | C:  44.26/30.0\n",
            "[FedSGM] it 0181/500 | switching ratio:(0.38, 0.62) | R:  51.91 | C:  24.64/30.0\n",
            "[FedSGM] it 0182/500 | switching ratio:(1.00, 0.00) | R:  20.17 | C:  13.48/30.0\n",
            "[FedSGM] it 0183/500 | switching ratio:(1.00, 0.00) | R:  20.92 | C:  13.74/30.0\n",
            "[FedSGM] it 0184/500 | switching ratio:(0.96, 0.04) | R:  33.27 | C:  17.39/30.0\n",
            "[FedSGM] it 0185/500 | switching ratio:(0.39, 0.61) | R:  51.35 | C:  23.57/30.0\n",
            "[FedSGM] it 0186/500 | switching ratio:(0.00, 1.00) | R:  96.80 | C:  39.97/30.0\n",
            "[FedSGM] it 0187/500 | switching ratio:(0.00, 1.00) | R: 104.77 | C:  41.39/30.0\n",
            "[FedSGM] it 0188/500 | switching ratio:(0.00, 1.00) | R:  85.52 | C:  35.19/30.0\n",
            "[FedSGM] it 0189/500 | switching ratio:(0.00, 1.00) | R: 100.89 | C:  40.17/30.0\n",
            "[FedSGM] it 0190/500 | switching ratio:(0.62, 0.38) | R:  46.37 | C:  21.71/30.0\n",
            "[FedSGM] it 0191/500 | switching ratio:(0.75, 0.25) | R:  41.83 | C:  20.13/30.0\n",
            "[FedSGM] it 0192/500 | switching ratio:(0.72, 0.28) | R:  44.86 | C:  20.83/30.0\n",
            "[FedSGM] it 0193/500 | switching ratio:(0.00, 1.00) | R:  87.68 | C:  36.08/30.0\n",
            "[FedSGM] it 0194/500 | switching ratio:(0.00, 1.00) | R: 111.44 | C:  42.74/30.0\n",
            "[FedSGM] it 0195/500 | switching ratio:(0.00, 1.00) | R: 112.13 | C:  43.01/30.0\n",
            "[FedSGM] it 0196/500 | switching ratio:(0.00, 1.00) | R: 115.82 | C:  44.65/30.0\n",
            "[FedSGM] it 0197/500 | switching ratio:(0.00, 1.00) | R:  86.26 | C:  34.18/30.0\n",
            "[FedSGM] it 0198/500 | switching ratio:(1.00, 0.00) | R:  25.58 | C:  14.78/30.0\n",
            "[FedSGM] it 0199/500 | switching ratio:(1.00, 0.00) | R:  25.16 | C:  14.12/30.0\n",
            "[FedSGM] it 0200/500 | switching ratio:(0.78, 0.22) | R:  34.45 | C:  18.51/30.0\n",
            "[FedSGM] it 0201/500 | switching ratio:(0.13, 0.87) | R:  65.44 | C:  27.85/30.0\n",
            "[FedSGM] it 0202/500 | switching ratio:(0.00, 1.00) | R:  79.66 | C:  31.57/30.0\n",
            "[FedSGM] it 0203/500 | switching ratio:(0.00, 1.00) | R:  81.33 | C:  32.38/30.0\n",
            "[FedSGM] it 0204/500 | switching ratio:(0.09, 0.91) | R:  72.66 | C:  29.46/30.0\n",
            "[FedSGM] it 0205/500 | switching ratio:(0.68, 0.32) | R:  41.09 | C:  19.44/30.0\n",
            "[FedSGM] it 0206/500 | switching ratio:(0.35, 0.65) | R:  55.76 | C:  24.65/30.0\n",
            "[FedSGM] it 0207/500 | switching ratio:(0.00, 1.00) | R:  99.78 | C:  39.27/30.0\n",
            "[FedSGM] it 0208/500 | switching ratio:(0.00, 1.00) | R: 115.66 | C:  43.19/30.0\n",
            "[FedSGM] it 0209/500 | switching ratio:(0.00, 1.00) | R: 102.24 | C:  38.88/30.0\n",
            "[FedSGM] it 0210/500 | switching ratio:(0.98, 0.02) | R:  31.31 | C:  16.04/30.0\n",
            "[FedSGM] it 0211/500 | switching ratio:(1.00, 0.00) | R:  30.27 | C:  15.46/30.0\n",
            "[FedSGM] it 0212/500 | switching ratio:(0.17, 0.83) | R:  75.38 | C:  28.44/30.0\n",
            "[FedSGM] it 0213/500 | switching ratio:(0.00, 1.00) | R: 121.95 | C:  43.88/30.0\n",
            "[FedSGM] it 0214/500 | switching ratio:(0.00, 1.00) | R: 118.00 | C:  41.71/30.0\n",
            "[FedSGM] it 0215/500 | switching ratio:(0.00, 1.00) | R: 114.35 | C:  41.31/30.0\n",
            "[FedSGM] it 0216/500 | switching ratio:(0.48, 0.52) | R:  58.01 | C:  22.67/30.0\n",
            "[FedSGM] it 0217/500 | switching ratio:(0.97, 0.03) | R:  33.24 | C:  15.83/30.0\n",
            "[FedSGM] it 0218/500 | switching ratio:(0.16, 0.84) | R:  76.42 | C:  27.81/30.0\n",
            "[FedSGM] it 0219/500 | switching ratio:(0.00, 1.00) | R: 136.99 | C:  46.63/30.0\n",
            "[FedSGM] it 0220/500 | switching ratio:(0.00, 1.00) | R: 130.08 | C:  45.44/30.0\n",
            "[FedSGM] it 0221/500 | switching ratio:(0.00, 1.00) | R: 129.73 | C:  43.43/30.0\n",
            "[FedSGM] it 0222/500 | switching ratio:(0.32, 0.68) | R:  74.86 | C:  27.44/30.0\n",
            "[FedSGM] it 0223/500 | switching ratio:(0.95, 0.05) | R:  37.73 | C:  16.71/30.0\n",
            "[FedSGM] it 0224/500 | switching ratio:(0.07, 0.93) | R:  78.52 | C:  28.07/30.0\n",
            "[FedSGM] it 0225/500 | switching ratio:(0.00, 1.00) | R: 139.77 | C:  45.66/30.0\n",
            "[FedSGM] it 0226/500 | switching ratio:(0.00, 1.00) | R: 142.51 | C:  48.56/30.0\n",
            "[FedSGM] it 0227/500 | switching ratio:(0.00, 1.00) | R: 149.96 | C:  49.49/30.0\n",
            "[FedSGM] it 0228/500 | switching ratio:(0.00, 1.00) | R: 144.42 | C:  46.61/30.0\n",
            "[FedSGM] it 0229/500 | switching ratio:(0.00, 1.00) | R: 130.31 | C:  40.04/30.0\n",
            "[FedSGM] it 0230/500 | switching ratio:(0.16, 0.84) | R:  79.20 | C:  27.13/30.0\n",
            "[FedSGM] it 0231/500 | switching ratio:(0.88, 0.12) | R:  42.99 | C:  17.73/30.0\n",
            "[FedSGM] it 0232/500 | switching ratio:(0.80, 0.20) | R:  46.88 | C:  18.81/30.0\n",
            "[FedSGM] it 0233/500 | switching ratio:(0.14, 0.86) | R:  81.51 | C:  27.49/30.0\n",
            "[FedSGM] it 0234/500 | switching ratio:(0.00, 1.00) | R: 135.55 | C:  42.94/30.0\n",
            "[FedSGM] it 0235/500 | switching ratio:(0.00, 1.00) | R: 122.63 | C:  39.93/30.0\n",
            "[FedSGM] it 0236/500 | switching ratio:(0.00, 1.00) | R: 140.71 | C:  43.33/30.0\n",
            "[FedSGM] it 0237/500 | switching ratio:(0.00, 1.00) | R: 100.46 | C:  31.27/30.0\n",
            "[FedSGM] it 0238/500 | switching ratio:(0.67, 0.33) | R:  56.72 | C:  20.66/30.0\n",
            "[FedSGM] it 0239/500 | switching ratio:(0.56, 0.44) | R:  58.12 | C:  20.80/30.0\n",
            "[FedSGM] it 0240/500 | switching ratio:(0.00, 1.00) | R: 107.58 | C:  33.72/30.0\n",
            "[FedSGM] it 0241/500 | switching ratio:(0.00, 1.00) | R: 139.98 | C:  40.63/30.0\n",
            "[FedSGM] it 0242/500 | switching ratio:(0.00, 1.00) | R: 126.58 | C:  37.65/30.0\n",
            "[FedSGM] it 0243/500 | switching ratio:(0.11, 0.89) | R:  90.46 | C:  27.97/30.0\n",
            "[FedSGM] it 0244/500 | switching ratio:(0.60, 0.40) | R:  62.27 | C:  21.69/30.0\n",
            "[FedSGM] it 0245/500 | switching ratio:(0.55, 0.45) | R:  68.66 | C:  22.94/30.0\n",
            "[FedSGM] it 0246/500 | switching ratio:(0.00, 1.00) | R: 109.66 | C:  30.88/30.0\n",
            "[FedSGM] it 0247/500 | switching ratio:(0.00, 1.00) | R: 122.45 | C:  33.83/30.0\n",
            "[FedSGM] it 0248/500 | switching ratio:(0.00, 1.00) | R: 125.13 | C:  37.06/30.0\n",
            "[FedSGM] it 0249/500 | switching ratio:(0.10, 0.90) | R:  96.37 | C:  28.10/30.0\n",
            "[FedSGM] it 0250/500 | switching ratio:(0.77, 0.23) | R:  57.78 | C:  19.88/30.0\n",
            "[FedSGM] it 0251/500 | switching ratio:(0.28, 0.72) | R:  91.23 | C:  27.71/30.0\n",
            "[FedSGM] it 0252/500 | switching ratio:(0.00, 1.00) | R: 133.03 | C:  36.24/30.0\n",
            "[FedSGM] it 0253/500 | switching ratio:(0.00, 1.00) | R: 124.96 | C:  34.76/30.0\n",
            "[FedSGM] it 0254/500 | switching ratio:(0.00, 1.00) | R: 118.05 | C:  32.29/30.0\n",
            "[FedSGM] it 0255/500 | switching ratio:(0.40, 0.60) | R:  77.73 | C:  24.45/30.0\n",
            "[FedSGM] it 0256/500 | switching ratio:(0.49, 0.51) | R:  79.13 | C:  23.51/30.0\n",
            "[FedSGM] it 0257/500 | switching ratio:(0.04, 0.96) | R: 104.31 | C:  29.78/30.0\n",
            "[FedSGM] it 0258/500 | switching ratio:(0.00, 1.00) | R: 123.91 | C:  33.84/30.0\n",
            "[FedSGM] it 0259/500 | switching ratio:(0.31, 0.69) | R:  99.10 | C:  26.82/30.0\n",
            "[FedSGM] it 0260/500 | switching ratio:(0.00, 1.00) | R: 119.76 | C:  30.95/30.0\n",
            "[FedSGM] it 0261/500 | switching ratio:(0.51, 0.49) | R:  82.77 | C:  23.04/30.0\n",
            "[FedSGM] it 0262/500 | switching ratio:(0.00, 1.00) | R: 135.20 | C:  32.98/30.0\n",
            "[FedSGM] it 0263/500 | switching ratio:(0.00, 1.00) | R: 133.85 | C:  33.89/30.0\n",
            "[FedSGM] it 0264/500 | switching ratio:(0.00, 1.00) | R: 131.27 | C:  34.43/30.0\n",
            "[FedSGM] it 0265/500 | switching ratio:(0.27, 0.73) | R: 102.18 | C:  26.26/30.0\n",
            "[FedSGM] it 0266/500 | switching ratio:(0.79, 0.21) | R:  67.59 | C:  19.52/30.0\n",
            "[FedSGM] it 0267/500 | switching ratio:(0.27, 0.73) | R: 103.93 | C:  26.24/30.0\n",
            "[FedSGM] it 0268/500 | switching ratio:(0.00, 1.00) | R: 144.64 | C:  35.07/30.0\n",
            "[FedSGM] it 0269/500 | switching ratio:(0.00, 1.00) | R: 148.52 | C:  36.61/30.0\n",
            "[FedSGM] it 0270/500 | switching ratio:(0.00, 1.00) | R: 152.76 | C:  37.55/30.0\n",
            "[FedSGM] it 0271/500 | switching ratio:(0.00, 1.00) | R: 146.46 | C:  35.96/30.0\n",
            "[FedSGM] it 0272/500 | switching ratio:(0.00, 1.00) | R: 144.46 | C:  32.55/30.0\n",
            "[FedSGM] it 0273/500 | switching ratio:(0.41, 0.59) | R:  94.36 | C:  23.90/30.0\n",
            "[FedSGM] it 0274/500 | switching ratio:(0.43, 0.57) | R:  90.16 | C:  23.00/30.0\n",
            "[FedSGM] it 0275/500 | switching ratio:(0.14, 0.86) | R: 121.15 | C:  29.03/30.0\n",
            "[FedSGM] it 0276/500 | switching ratio:(0.00, 1.00) | R: 144.34 | C:  33.57/30.0\n",
            "[FedSGM] it 0277/500 | switching ratio:(0.00, 1.00) | R: 146.72 | C:  34.00/30.0\n",
            "[FedSGM] it 0278/500 | switching ratio:(0.17, 0.83) | R: 114.91 | C:  28.06/30.0\n",
            "[FedSGM] it 0279/500 | switching ratio:(0.38, 0.62) | R:  97.35 | C:  23.71/30.0\n",
            "[FedSGM] it 0280/500 | switching ratio:(0.33, 0.67) | R: 108.55 | C:  25.25/30.0\n",
            "[FedSGM] it 0281/500 | switching ratio:(0.00, 1.00) | R: 148.40 | C:  32.34/30.0\n",
            "[FedSGM] it 0282/500 | switching ratio:(0.00, 1.00) | R: 141.97 | C:  31.44/30.0\n",
            "[FedSGM] it 0283/500 | switching ratio:(0.00, 1.00) | R: 134.81 | C:  29.54/30.0\n",
            "[FedSGM] it 0284/500 | switching ratio:(0.44, 0.56) | R: 120.61 | C:  25.51/30.0\n",
            "[FedSGM] it 0285/500 | switching ratio:(0.30, 0.70) | R: 126.37 | C:  27.58/30.0\n",
            "[FedSGM] it 0286/500 | switching ratio:(0.00, 1.00) | R: 161.41 | C:  33.32/30.0\n",
            "[FedSGM] it 0287/500 | switching ratio:(0.00, 1.00) | R: 152.20 | C:  33.56/30.0\n",
            "[FedSGM] it 0288/500 | switching ratio:(0.12, 0.88) | R: 123.90 | C:  28.87/30.0\n",
            "[FedSGM] it 0289/500 | switching ratio:(0.44, 0.56) | R: 115.30 | C:  25.49/30.0\n",
            "[FedSGM] it 0290/500 | switching ratio:(0.11, 0.89) | R: 138.69 | C:  29.83/30.0\n",
            "[FedSGM] it 0291/500 | switching ratio:(0.00, 1.00) | R: 164.54 | C:  35.05/30.0\n",
            "[FedSGM] it 0292/500 | switching ratio:(0.00, 1.00) | R: 156.15 | C:  31.74/30.0\n",
            "[FedSGM] it 0293/500 | switching ratio:(0.00, 1.00) | R: 156.67 | C:  32.24/30.0\n",
            "[FedSGM] it 0294/500 | switching ratio:(0.00, 1.00) | R: 148.59 | C:  30.34/30.0\n",
            "[FedSGM] it 0295/500 | switching ratio:(0.56, 0.44) | R: 100.83 | C:  22.25/30.0\n",
            "[FedSGM] it 0296/500 | switching ratio:(0.01, 0.99) | R: 140.12 | C:  29.87/30.0\n",
            "[FedSGM] it 0297/500 | switching ratio:(0.51, 0.49) | R: 107.81 | C:  23.08/30.0\n",
            "[FedSGM] it 0298/500 | switching ratio:(0.00, 1.00) | R: 157.22 | C:  33.06/30.0\n",
            "[FedSGM] it 0299/500 | switching ratio:(0.00, 1.00) | R: 165.72 | C:  32.40/30.0\n",
            "[FedSGM] it 0300/500 | switching ratio:(0.00, 1.00) | R: 166.54 | C:  32.52/30.0\n",
            "[FedSGM] it 0301/500 | switching ratio:(0.00, 1.00) | R: 165.83 | C:  33.00/30.0\n",
            "[FedSGM] it 0302/500 | switching ratio:(0.00, 1.00) | R: 169.40 | C:  34.68/30.0\n",
            "[FedSGM] it 0303/500 | switching ratio:(0.00, 1.00) | R: 160.37 | C:  31.62/30.0\n",
            "[FedSGM] it 0304/500 | switching ratio:(0.43, 0.57) | R: 123.72 | C:  25.75/30.0\n",
            "[FedSGM] it 0305/500 | switching ratio:(0.31, 0.69) | R: 114.05 | C:  24.37/30.0\n",
            "[FedSGM] it 0306/500 | switching ratio:(0.00, 1.00) | R: 147.73 | C:  28.67/30.0\n",
            "[FedSGM] it 0307/500 | switching ratio:(0.18, 0.82) | R: 138.40 | C:  27.18/30.0\n",
            "[FedSGM] it 0308/500 | switching ratio:(0.27, 0.73) | R: 143.61 | C:  27.24/30.0\n",
            "[FedSGM] it 0309/500 | switching ratio:(0.03, 0.97) | R: 163.61 | C:  29.58/30.0\n",
            "[FedSGM] it 0310/500 | switching ratio:(0.00, 1.00) | R: 173.30 | C:  31.26/30.0\n",
            "[FedSGM] it 0311/500 | switching ratio:(0.00, 1.00) | R: 170.86 | C:  30.50/30.0\n",
            "[FedSGM] it 0312/500 | switching ratio:(0.00, 1.00) | R: 172.03 | C:  30.80/30.0\n",
            "[FedSGM] it 0313/500 | switching ratio:(0.00, 1.00) | R: 172.60 | C:  31.55/30.0\n",
            "[FedSGM] it 0314/500 | switching ratio:(0.28, 0.72) | R: 144.06 | C:  27.26/30.0\n",
            "[FedSGM] it 0315/500 | switching ratio:(0.91, 0.09) | R:  76.91 | C:  16.81/30.0\n",
            "[FedSGM] it 0316/500 | switching ratio:(0.59, 0.41) | R: 120.42 | C:  23.46/30.0\n",
            "[FedSGM] it 0317/500 | switching ratio:(0.13, 0.87) | R: 170.25 | C:  29.00/30.0\n",
            "[FedSGM] it 0318/500 | switching ratio:(0.00, 1.00) | R: 192.86 | C:  34.12/30.0\n",
            "[FedSGM] it 0319/500 | switching ratio:(0.00, 1.00) | R: 189.93 | C:  33.48/30.0\n",
            "[FedSGM] it 0320/500 | switching ratio:(0.00, 1.00) | R: 189.12 | C:  31.55/30.0\n",
            "[FedSGM] it 0321/500 | switching ratio:(0.00, 1.00) | R: 189.71 | C:  33.40/30.0\n",
            "[FedSGM] it 0322/500 | switching ratio:(0.00, 1.00) | R: 189.60 | C:  33.57/30.0\n",
            "[FedSGM] it 0323/500 | switching ratio:(0.00, 1.00) | R: 187.55 | C:  32.17/30.0\n",
            "[FedSGM] it 0324/500 | switching ratio:(0.05, 0.95) | R: 186.45 | C:  30.45/30.0\n",
            "[FedSGM] it 0325/500 | switching ratio:(0.10, 0.90) | R: 178.17 | C:  29.14/30.0\n",
            "[FedSGM] it 0326/500 | switching ratio:(0.42, 0.58) | R: 148.20 | C:  24.94/30.0\n",
            "[FedSGM] it 0327/500 | switching ratio:(0.38, 0.62) | R: 140.97 | C:  25.09/30.0\n",
            "[FedSGM] it 0328/500 | switching ratio:(0.10, 0.90) | R: 176.19 | C:  29.27/30.0\n",
            "[FedSGM] it 0329/500 | switching ratio:(0.15, 0.85) | R: 191.07 | C:  28.79/30.0\n",
            "[FedSGM] it 0330/500 | switching ratio:(0.00, 1.00) | R: 192.71 | C:  30.57/30.0\n",
            "[FedSGM] it 0331/500 | switching ratio:(0.00, 1.00) | R: 197.86 | C:  32.65/30.0\n",
            "[FedSGM] it 0332/500 | switching ratio:(0.00, 1.00) | R: 197.69 | C:  30.81/30.0\n",
            "[FedSGM] it 0333/500 | switching ratio:(0.10, 0.90) | R: 190.38 | C:  29.46/30.0\n",
            "[FedSGM] it 0334/500 | switching ratio:(0.05, 0.95) | R: 189.41 | C:  30.11/30.0\n",
            "[FedSGM] it 0335/500 | switching ratio:(0.18, 0.82) | R: 173.79 | C:  28.43/30.0\n",
            "[FedSGM] it 0336/500 | switching ratio:(0.26, 0.74) | R: 174.53 | C:  26.53/30.0\n",
            "[FedSGM] it 0337/500 | switching ratio:(0.12, 0.88) | R: 179.97 | C:  28.56/30.0\n",
            "[FedSGM] it 0338/500 | switching ratio:(0.24, 0.76) | R: 180.06 | C:  26.63/30.0\n",
            "[FedSGM] it 0339/500 | switching ratio:(0.26, 0.74) | R: 195.07 | C:  26.04/30.0\n",
            "[FedSGM] it 0340/500 | switching ratio:(0.17, 0.83) | R: 182.04 | C:  27.52/30.0\n",
            "[FedSGM] it 0341/500 | switching ratio:(0.15, 0.85) | R: 195.48 | C:  28.21/30.0\n",
            "[FedSGM] it 0342/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  25.20/30.0\n",
            "[FedSGM] it 0343/500 | switching ratio:(0.39, 0.61) | R: 200.00 | C:  25.57/30.0\n",
            "[FedSGM] it 0344/500 | switching ratio:(0.20, 0.80) | R: 199.79 | C:  26.60/30.0\n",
            "[FedSGM] it 0345/500 | switching ratio:(0.34, 0.66) | R: 199.79 | C:  26.18/30.0\n",
            "[FedSGM] it 0346/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  27.00/30.0\n",
            "[FedSGM] it 0347/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  26.17/30.0\n",
            "[FedSGM] it 0348/500 | switching ratio:(0.36, 0.64) | R: 191.17 | C:  24.82/30.0\n",
            "[FedSGM] it 0349/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  26.60/30.0\n",
            "[FedSGM] it 0350/500 | switching ratio:(0.41, 0.59) | R: 200.00 | C:  24.86/30.0\n",
            "[FedSGM] it 0351/500 | switching ratio:(0.36, 0.64) | R: 200.00 | C:  25.00/30.0\n",
            "[FedSGM] it 0352/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0353/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  25.31/30.0\n",
            "[FedSGM] it 0354/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  28.06/30.0\n",
            "[FedSGM] it 0355/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  27.11/30.0\n",
            "[FedSGM] it 0356/500 | switching ratio:(0.41, 0.59) | R: 195.62 | C:  24.47/30.0\n",
            "[FedSGM] it 0357/500 | switching ratio:(0.12, 0.88) | R: 200.00 | C:  27.97/30.0\n",
            "[FedSGM] it 0358/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  26.20/30.0\n",
            "[FedSGM] it 0359/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  26.60/30.0\n",
            "[FedSGM] it 0360/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  27.74/30.0\n",
            "[FedSGM] it 0361/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  27.37/30.0\n",
            "[FedSGM] it 0362/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  25.77/30.0\n",
            "[FedSGM] it 0363/500 | switching ratio:(0.32, 0.68) | R: 200.00 | C:  25.31/30.0\n",
            "[FedSGM] it 0364/500 | switching ratio:(0.42, 0.58) | R: 200.00 | C:  24.34/30.0\n",
            "[FedSGM] it 0365/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  27.11/30.0\n",
            "[FedSGM] it 0366/500 | switching ratio:(0.40, 0.60) | R: 200.00 | C:  25.17/30.0\n",
            "[FedSGM] it 0367/500 | switching ratio:(0.42, 0.58) | R: 200.00 | C:  24.51/30.0\n",
            "[FedSGM] it 0368/500 | switching ratio:(0.49, 0.51) | R: 195.64 | C:  24.30/30.0\n",
            "[FedSGM] it 0369/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  27.23/30.0\n",
            "[FedSGM] it 0370/500 | switching ratio:(0.46, 0.54) | R: 200.00 | C:  25.34/30.0\n",
            "[FedSGM] it 0371/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  26.43/30.0\n",
            "[FedSGM] it 0372/500 | switching ratio:(0.33, 0.67) | R: 200.00 | C:  26.51/30.0\n",
            "[FedSGM] it 0373/500 | switching ratio:(0.24, 0.76) | R: 195.62 | C:  26.63/30.0\n",
            "[FedSGM] it 0374/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  28.69/30.0\n",
            "[FedSGM] it 0375/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0376/500 | switching ratio:(0.34, 0.66) | R: 200.00 | C:  25.66/30.0\n",
            "[FedSGM] it 0377/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  25.46/30.0\n",
            "[FedSGM] it 0378/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  26.74/30.0\n",
            "[FedSGM] it 0379/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  26.91/30.0\n",
            "[FedSGM] it 0380/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  27.29/30.0\n",
            "[FedSGM] it 0381/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  26.40/30.0\n",
            "[FedSGM] it 0382/500 | switching ratio:(0.38, 0.62) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0383/500 | switching ratio:(0.34, 0.66) | R: 200.00 | C:  25.23/30.0\n",
            "[FedSGM] it 0384/500 | switching ratio:(0.32, 0.68) | R: 200.00 | C:  26.80/30.0\n",
            "[FedSGM] it 0385/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  25.69/30.0\n",
            "[FedSGM] it 0386/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  26.94/30.0\n",
            "[FedSGM] it 0387/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  26.94/30.0\n",
            "[FedSGM] it 0388/500 | switching ratio:(0.51, 0.49) | R: 200.00 | C:  23.86/30.0\n",
            "[FedSGM] it 0389/500 | switching ratio:(0.38, 0.62) | R: 200.00 | C:  25.46/30.0\n",
            "[FedSGM] it 0390/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  25.86/30.0\n",
            "[FedSGM] it 0391/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  29.20/30.0\n",
            "[FedSGM] it 0392/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  27.37/30.0\n",
            "[FedSGM] it 0393/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0394/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  29.17/30.0\n",
            "[FedSGM] it 0395/500 | switching ratio:(0.05, 0.95) | R: 200.00 | C:  30.17/30.0\n",
            "[FedSGM] it 0396/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.34/30.0\n",
            "[FedSGM] it 0397/500 | switching ratio:(0.18, 0.82) | R: 200.00 | C:  27.63/30.0\n",
            "[FedSGM] it 0398/500 | switching ratio:(0.06, 0.94) | R: 200.00 | C:  29.83/30.0\n",
            "[FedSGM] it 0399/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  28.23/30.0\n",
            "[FedSGM] it 0400/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  27.00/30.0\n",
            "[FedSGM] it 0401/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0402/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  27.31/30.0\n",
            "[FedSGM] it 0403/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  29.09/30.0\n",
            "[FedSGM] it 0404/500 | switching ratio:(0.15, 0.85) | R: 200.00 | C:  28.97/30.0\n",
            "[FedSGM] it 0405/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  27.17/30.0\n",
            "[FedSGM] it 0406/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  28.86/30.0\n",
            "[FedSGM] it 0407/500 | switching ratio:(0.02, 0.98) | R: 200.00 | C:  30.03/30.0\n",
            "[FedSGM] it 0408/500 | switching ratio:(0.04, 0.96) | R: 200.00 | C:  29.17/30.0\n",
            "[FedSGM] it 0409/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  29.40/30.0\n",
            "[FedSGM] it 0410/500 | switching ratio:(0.06, 0.94) | R: 195.57 | C:  28.53/30.0\n",
            "[FedSGM] it 0411/500 | switching ratio:(0.28, 0.72) | R: 195.62 | C:  27.11/30.0\n",
            "[FedSGM] it 0412/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  27.54/30.0\n",
            "[FedSGM] it 0413/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  29.51/30.0\n",
            "[FedSGM] it 0414/500 | switching ratio:(0.01, 0.99) | R: 200.00 | C:  30.66/30.0\n",
            "[FedSGM] it 0415/500 | switching ratio:(0.08, 0.92) | R: 200.00 | C:  28.49/30.0\n",
            "[FedSGM] it 0416/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  27.94/30.0\n",
            "[FedSGM] it 0417/500 | switching ratio:(0.03, 0.97) | R: 196.14 | C:  29.67/30.0\n",
            "[FedSGM] it 0418/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  26.83/30.0\n",
            "[FedSGM] it 0419/500 | switching ratio:(0.14, 0.86) | R: 200.00 | C:  27.74/30.0\n",
            "[FedSGM] it 0420/500 | switching ratio:(0.33, 0.67) | R: 200.00 | C:  27.09/30.0\n",
            "[FedSGM] it 0421/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  27.89/30.0\n",
            "[FedSGM] it 0422/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0423/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  26.74/30.0\n",
            "[FedSGM] it 0424/500 | switching ratio:(0.20, 0.80) | R: 200.00 | C:  26.83/30.0\n",
            "[FedSGM] it 0425/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  28.60/30.0\n",
            "[FedSGM] it 0426/500 | switching ratio:(0.41, 0.59) | R: 200.00 | C:  24.43/30.0\n",
            "[FedSGM] it 0427/500 | switching ratio:(0.39, 0.61) | R: 200.00 | C:  25.31/30.0\n",
            "[FedSGM] it 0428/500 | switching ratio:(0.37, 0.63) | R: 200.00 | C:  26.37/30.0\n",
            "[FedSGM] it 0429/500 | switching ratio:(0.32, 0.68) | R: 200.00 | C:  26.51/30.0\n",
            "[FedSGM] it 0430/500 | switching ratio:(0.19, 0.81) | R: 200.00 | C:  26.83/30.0\n",
            "[FedSGM] it 0431/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  25.71/30.0\n",
            "[FedSGM] it 0432/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  27.69/30.0\n",
            "[FedSGM] it 0433/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  26.66/30.0\n",
            "[FedSGM] it 0434/500 | switching ratio:(0.33, 0.67) | R: 200.00 | C:  25.17/30.0\n",
            "[FedSGM] it 0435/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  27.63/30.0\n",
            "[FedSGM] it 0436/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  26.34/30.0\n",
            "[FedSGM] it 0437/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0438/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  28.49/30.0\n",
            "[FedSGM] it 0439/500 | switching ratio:(0.29, 0.71) | R: 200.00 | C:  25.97/30.0\n",
            "[FedSGM] it 0440/500 | switching ratio:(0.40, 0.60) | R: 200.00 | C:  25.57/30.0\n",
            "[FedSGM] it 0441/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  26.11/30.0\n",
            "[FedSGM] it 0442/500 | switching ratio:(0.17, 0.83) | R: 195.62 | C:  27.85/30.0\n",
            "[FedSGM] it 0443/500 | switching ratio:(0.25, 0.75) | R: 200.00 | C:  26.69/30.0\n",
            "[FedSGM] it 0444/500 | switching ratio:(0.24, 0.76) | R: 200.00 | C:  26.54/30.0\n",
            "[FedSGM] it 0445/500 | switching ratio:(0.31, 0.69) | R: 196.02 | C:  25.90/30.0\n",
            "[FedSGM] it 0446/500 | switching ratio:(0.30, 0.70) | R: 195.60 | C:  25.79/30.0\n",
            "[FedSGM] it 0447/500 | switching ratio:(0.32, 0.68) | R: 195.62 | C:  26.50/30.0\n",
            "[FedSGM] it 0448/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  26.17/30.0\n",
            "[FedSGM] it 0449/500 | switching ratio:(0.23, 0.77) | R: 200.00 | C:  26.49/30.0\n",
            "[FedSGM] it 0450/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  27.29/30.0\n",
            "[FedSGM] it 0451/500 | switching ratio:(0.39, 0.61) | R: 200.00 | C:  24.66/30.0\n",
            "[FedSGM] it 0452/500 | switching ratio:(0.28, 0.72) | R: 200.00 | C:  25.80/30.0\n",
            "[FedSGM] it 0453/500 | switching ratio:(0.48, 0.52) | R: 200.00 | C:  24.03/30.0\n",
            "[FedSGM] it 0454/500 | switching ratio:(0.37, 0.63) | R: 200.00 | C:  24.49/30.0\n",
            "[FedSGM] it 0455/500 | switching ratio:(0.33, 0.67) | R: 200.00 | C:  26.20/30.0\n",
            "[FedSGM] it 0456/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  25.51/30.0\n",
            "[FedSGM] it 0457/500 | switching ratio:(0.34, 0.66) | R: 200.00 | C:  26.34/30.0\n",
            "[FedSGM] it 0458/500 | switching ratio:(0.34, 0.66) | R: 200.00 | C:  26.03/30.0\n",
            "[FedSGM] it 0459/500 | switching ratio:(0.39, 0.61) | R: 200.00 | C:  24.74/30.0\n",
            "[FedSGM] it 0460/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  25.06/30.0\n",
            "[FedSGM] it 0461/500 | switching ratio:(0.27, 0.73) | R: 200.00 | C:  26.74/30.0\n",
            "[FedSGM] it 0462/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  25.00/30.0\n",
            "[FedSGM] it 0463/500 | switching ratio:(0.22, 0.78) | R: 200.00 | C:  25.74/30.0\n",
            "[FedSGM] it 0464/500 | switching ratio:(0.30, 0.70) | R: 200.00 | C:  25.46/30.0\n",
            "[FedSGM] it 0465/500 | switching ratio:(0.37, 0.63) | R: 200.00 | C:  25.06/30.0\n",
            "[FedSGM] it 0466/500 | switching ratio:(0.37, 0.63) | R: 200.00 | C:  25.34/30.0\n",
            "[FedSGM] it 0467/500 | switching ratio:(0.45, 0.55) | R: 200.00 | C:  24.94/30.0\n",
            "[FedSGM] it 0468/500 | switching ratio:(0.40, 0.60) | R: 200.00 | C:  24.54/30.0\n",
            "[FedSGM] it 0469/500 | switching ratio:(0.45, 0.55) | R: 200.00 | C:  24.29/30.0\n",
            "[FedSGM] it 0470/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  24.09/30.0\n",
            "[FedSGM] it 0471/500 | switching ratio:(0.35, 0.65) | R: 200.00 | C:  26.09/30.0\n",
            "[FedSGM] it 0472/500 | switching ratio:(0.43, 0.57) | R: 200.00 | C:  24.74/30.0\n",
            "[FedSGM] it 0473/500 | switching ratio:(0.42, 0.58) | R: 200.00 | C:  25.26/30.0\n",
            "[FedSGM] it 0474/500 | switching ratio:(0.17, 0.83) | R: 200.00 | C:  28.31/30.0\n",
            "[FedSGM] it 0475/500 | switching ratio:(0.00, 1.00) | R: 192.33 | C:  31.74/30.0\n",
            "[FedSGM] it 0476/500 | switching ratio:(0.05, 0.95) | R: 195.57 | C:  30.49/30.0\n",
            "[FedSGM] it 0477/500 | switching ratio:(0.00, 1.00) | R: 195.57 | C:  33.28/30.0\n",
            "[FedSGM] it 0478/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  32.66/30.0\n",
            "[FedSGM] it 0479/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  33.43/30.0\n",
            "[FedSGM] it 0480/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.91/30.0\n",
            "[FedSGM] it 0481/500 | switching ratio:(0.10, 0.90) | R: 200.00 | C:  29.03/30.0\n",
            "[FedSGM] it 0482/500 | switching ratio:(0.07, 0.93) | R: 200.00 | C:  28.66/30.0\n",
            "[FedSGM] it 0483/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  26.86/30.0\n",
            "[FedSGM] it 0484/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  27.91/30.0\n",
            "[FedSGM] it 0485/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  27.80/30.0\n",
            "[FedSGM] it 0486/500 | switching ratio:(0.21, 0.79) | R: 200.00 | C:  26.69/30.0\n",
            "[FedSGM] it 0487/500 | switching ratio:(0.09, 0.91) | R: 200.00 | C:  28.17/30.0\n",
            "[FedSGM] it 0488/500 | switching ratio:(0.54, 0.46) | R: 179.10 | C:  22.09/30.0\n",
            "[FedSGM] it 0489/500 | switching ratio:(0.30, 0.70) | R: 195.62 | C:  25.09/30.0\n",
            "[FedSGM] it 0490/500 | switching ratio:(0.27, 0.73) | R: 191.26 | C:  25.00/30.0\n",
            "[FedSGM] it 0491/500 | switching ratio:(0.11, 0.89) | R: 200.00 | C:  29.40/30.0\n",
            "[FedSGM] it 0492/500 | switching ratio:(0.34, 0.66) | R: 191.21 | C:  26.65/30.0\n",
            "[FedSGM] it 0493/500 | switching ratio:(0.16, 0.84) | R: 200.00 | C:  26.57/30.0\n",
            "[FedSGM] it 0494/500 | switching ratio:(0.33, 0.67) | R: 200.00 | C:  26.14/30.0\n",
            "[FedSGM] it 0495/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  37.03/30.0\n",
            "[FedSGM] it 0496/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  36.23/30.0\n",
            "[FedSGM] it 0497/500 | switching ratio:(0.00, 1.00) | R: 200.00 | C:  30.29/30.0\n",
            "[FedSGM] it 0498/500 | switching ratio:(0.40, 0.60) | R: 200.00 | C:  25.31/30.0\n",
            "[FedSGM] it 0499/500 | switching ratio:(0.26, 0.74) | R: 200.00 | C:  26.29/30.0\n",
            "[FedSGM] it 0500/500 | switching ratio:(0.31, 0.69) | R: 200.00 | C:  24.71/30.0\n",
            "Avg return over last 50 feasible rounds: 198.80\n",
            "\n",
            "--- Running Experiment 4/5 ---\n",
            "Starting parallel federated learning for 500 rounds with 10 total clients and 7 selected clients per round.\n",
            "[FedSGM] it 0001/500 | switching ratio:(0.34, 0.66) | R:  26.74 | C:  25.16/30.0\n",
            "[FedSGM] it 0002/500 | switching ratio:(0.90, 0.10) | R:  16.84 | C:  16.44/30.0\n",
            "[FedSGM] it 0003/500 | switching ratio:(0.79, 0.21) | R:  21.31 | C:  20.38/30.0\n",
            "[FedSGM] it 0004/500 | switching ratio:(0.12, 0.88) | R:  31.12 | C:  28.93/30.0\n",
            "[FedSGM] it 0005/500 | switching ratio:(0.61, 0.39) | R:  22.25 | C:  21.11/30.0\n",
            "[FedSGM] it 0006/500 | switching ratio:(0.17, 0.83) | R:  30.87 | C:  28.63/30.0\n",
            "[FedSGM] it 0007/500 | switching ratio:(0.52, 0.48) | R:  24.11 | C:  22.92/30.0\n",
            "[FedSGM] it 0008/500 | switching ratio:(0.85, 0.15) | R:  18.58 | C:  17.76/30.0\n",
            "[FedSGM] it 0009/500 | switching ratio:(0.55, 0.45) | R:  24.99 | C:  23.10/30.0\n",
            "[FedSGM] it 0010/500 | switching ratio:(0.00, 1.00) | R:  41.88 | C:  35.14/30.0\n",
            "[FedSGM] it 0011/500 | switching ratio:(0.46, 0.54) | R:  25.78 | C:  23.73/30.0\n",
            "[FedSGM] it 0012/500 | switching ratio:(0.90, 0.10) | R:  17.57 | C:  16.94/30.0\n",
            "[FedSGM] it 0013/500 | switching ratio:(0.57, 0.43) | R:  24.07 | C:  22.20/30.0\n",
            "[FedSGM] it 0014/500 | switching ratio:(0.00, 1.00) | R:  40.44 | C:  33.71/30.0\n",
            "[FedSGM] it 0015/500 | switching ratio:(0.41, 0.59) | R:  25.21 | C:  23.54/30.0\n",
            "[FedSGM] it 0016/500 | switching ratio:(0.92, 0.08) | R:  17.95 | C:  17.20/30.0\n",
            "[FedSGM] it 0017/500 | switching ratio:(0.52, 0.48) | R:  24.49 | C:  22.82/30.0\n",
            "[FedSGM] it 0018/500 | switching ratio:(0.00, 1.00) | R:  38.53 | C:  32.44/30.0\n",
            "[FedSGM] it 0019/500 | switching ratio:(0.44, 0.56) | R:  24.73 | C:  23.09/30.0\n",
            "[FedSGM] it 0020/500 | switching ratio:(0.97, 0.03) | R:  18.03 | C:  17.30/30.0\n",
            "[FedSGM] it 0021/500 | switching ratio:(0.73, 0.27) | R:  22.36 | C:  20.95/30.0\n",
            "[FedSGM] it 0022/500 | switching ratio:(0.00, 1.00) | R:  60.20 | C:  45.41/30.0\n",
            "[FedSGM] it 0023/500 | switching ratio:(0.02, 0.98) | R:  34.06 | C:  29.31/30.0\n",
            "[FedSGM] it 0024/500 | switching ratio:(0.83, 0.17) | R:  18.73 | C:  18.05/30.0\n",
            "[FedSGM] it 0025/500 | switching ratio:(0.36, 0.64) | R:  26.10 | C:  24.19/30.0\n",
            "[FedSGM] it 0026/500 | switching ratio:(1.00, 0.00) | R:  15.99 | C:  15.55/30.0\n",
            "[FedSGM] it 0027/500 | switching ratio:(0.75, 0.25) | R:  21.55 | C:  20.65/30.0\n",
            "[FedSGM] it 0028/500 | switching ratio:(0.00, 1.00) | R:  36.46 | C:  32.30/30.0\n",
            "[FedSGM] it 0029/500 | switching ratio:(0.62, 0.38) | R:  23.38 | C:  21.83/30.0\n",
            "[FedSGM] it 0030/500 | switching ratio:(0.00, 1.00) | R:  36.70 | C:  31.78/30.0\n",
            "[FedSGM] it 0031/500 | switching ratio:(0.77, 0.23) | R:  20.94 | C:  19.52/30.0\n",
            "[FedSGM] it 0032/500 | switching ratio:(0.22, 0.78) | R:  29.66 | C:  27.36/30.0\n",
            "[FedSGM] it 0033/500 | switching ratio:(0.99, 0.01) | R:  17.72 | C:  17.02/30.0\n",
            "[FedSGM] it 0034/500 | switching ratio:(0.55, 0.45) | R:  23.98 | C:  22.51/30.0\n",
            "[FedSGM] it 0035/500 | switching ratio:(0.00, 1.00) | R:  40.57 | C:  34.35/30.0\n",
            "[FedSGM] it 0036/500 | switching ratio:(0.57, 0.43) | R:  24.34 | C:  22.58/30.0\n",
            "[FedSGM] it 0037/500 | switching ratio:(0.80, 0.20) | R:  19.79 | C:  18.87/30.0\n",
            "[FedSGM] it 0038/500 | switching ratio:(0.28, 0.72) | R:  30.02 | C:  26.98/30.0\n",
            "[FedSGM] it 0039/500 | switching ratio:(0.49, 0.51) | R:  26.40 | C:  24.31/30.0\n",
            "[FedSGM] it 0040/500 | switching ratio:(0.58, 0.42) | R:  22.88 | C:  21.62/30.0\n",
            "[FedSGM] it 0041/500 | switching ratio:(0.00, 1.00) | R:  34.50 | C:  30.58/30.0\n"
          ]
        }
      ],
      "source": [
        "# Run federated training & plot\n",
        "num_experiments = 5\n",
        "all_federated_hist = []\n",
        "\n",
        "for i in range(num_experiments):\n",
        "    print(f\"\\n--- Running Experiment {i+1}/{num_experiments} ---\")\n",
        "    federated_policy, federated_hist = train_federated_crpo_cartpole_parallel(\n",
        "        num_rounds=500, num_total_clients=10, num_selected_clients=7, steps_per_batch=10000,\n",
        "        d_limit=30.0, beta=0.07, seed=SEED + i,\n",
        "        compression_rate=0.5 # Compression rate: e.g. 0.5 (Top-50% compression), 16 (float16 quantization)\n",
        "    )\n",
        "    all_federated_hist.append(federated_hist)\n",
        "\n",
        "# Save all histories using numpy.save\n",
        "np.save('S0.07_C50_P10_7_L1.npy', all_federated_hist)\n",
        "\n",
        "# Plot the mean and min/max range of the results\n",
        "if all_federated_hist:\n",
        "    plot_federated_results(\n",
        "        all_federated_hist, d_limit=30.0, smooth=5,\n",
        "        filename=\"S0.07_C50_P10_7_L1.png\",\n",
        "        title_tag=\"Federated SGM (Soft Switch)\"\n",
        "    )\n",
        "\n",
        "print(\"\\nDone with all experiments.\")\n",
        "# Print the last 5 rounds for each experiment\n",
        "for i, hist in enumerate(all_federated_hist):\n",
        "    print(f\"\\nExperiment {i+1} - Last 5 rounds (Avg R, Avg C):\")\n",
        "    print(list(zip(hist['R'][-5:], hist['C'][-5:])))"
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "W_xW0aU5lIcd"
      },
      "execution_count": null,
      "outputs": []
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}