{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "vgUXRKpJh1yE"
   },
   "source": [
    "# FedChill - Ci\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "execution": {
     "iopub.execute_input": "2025-09-23T10:38:07.735450Z",
     "iopub.status.busy": "2025-09-23T10:38:07.735205Z",
     "iopub.status.idle": "2025-09-23T10:38:17.675577Z",
     "shell.execute_reply": "2025-09-23T10:38:17.674790Z",
     "shell.execute_reply.started": "2025-09-23T10:38:07.735432Z"
    },
    "id": "_dq_ZRdAh1yG",
    "outputId": "c38ff43a-2f89-4321-d643-5b651b9429aa",
    "trusted": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "import numpy as np\n",
    "from torch.utils.data import Dataset, DataLoader, Subset, random_split\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import Counter\n",
    "import copy\n",
    "import random\n",
    "from typing import Dict, List, Tuple\n",
    "import math\n",
    "\n",
    "import pandas as pd\n",
    "torch.manual_seed(42)\n",
    "np.random.seed(42)\n",
    "random.seed(42)\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print(f\"Using device: {device}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "2NKqWJJTS7GB"
   },
   "source": [
    "---"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:38:23.885706Z",
     "iopub.status.busy": "2025-09-23T10:38:23.885085Z",
     "iopub.status.idle": "2025-09-23T10:38:23.889201Z",
     "shell.execute_reply": "2025-09-23T10:38:23.888462Z",
     "shell.execute_reply.started": "2025-09-23T10:38:23.885680Z"
    },
    "id": "hHTqcMmPeQ1c",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "NUM_CLASSES = 10 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:38:31.037072Z",
     "iopub.status.busy": "2025-09-23T10:38:31.036562Z",
     "iopub.status.idle": "2025-09-23T10:38:31.050478Z",
     "shell.execute_reply": "2025-09-23T10:38:31.049750Z",
     "shell.execute_reply.started": "2025-09-23T10:38:31.037047Z"
    },
    "id": "gVCZKSAhh1yH",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "class SimpleCNN(nn.Module):\n",
    "    def __init__(self, num_classes=NUM_CLASSES, seed=42):\n",
    "        super(SimpleCNN, self).__init__()\n",
    "\n",
    "        torch.manual_seed(seed)\n",
    "\n",
    "        self.conv1 = nn.Conv2d(3, 64, 3, padding=1)\n",
    "        self.bn1 = nn.BatchNorm2d(64)\n",
    "        self.conv2 = nn.Conv2d(64, 64, 3, padding=1)\n",
    "        self.bn2 = nn.BatchNorm2d(64)\n",
    "\n",
    "        self.conv3 = nn.Conv2d(64, 128, 3, padding=1)\n",
    "        self.bn3 = nn.BatchNorm2d(128)\n",
    "        self.conv4 = nn.Conv2d(128, 128, 3, padding=1)\n",
    "        self.bn4 = nn.BatchNorm2d(128)\n",
    "\n",
    "        self.conv5 = nn.Conv2d(128, 256, 3, padding=1)\n",
    "        self.bn5 = nn.BatchNorm2d(256)\n",
    "        self.conv6 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.bn6 = nn.BatchNorm2d(256)\n",
    "\n",
    "        self.conv7 = nn.Conv2d(256, 512, 3, padding=1)\n",
    "        self.bn7 = nn.BatchNorm2d(512)\n",
    "\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.adaptive_pool = nn.AdaptiveAvgPool2d((2, 2))  \n",
    "\n",
    "        self.fc1 = nn.Linear(512 * 2 * 2, 1024)\n",
    "        self.bn_fc1 = nn.BatchNorm1d(1024)\n",
    "        self.dropout1 = nn.Dropout(0.5)\n",
    "\n",
    "        self.fc2 = nn.Linear(1024, 512)\n",
    "        self.bn_fc2 = nn.BatchNorm1d(512)\n",
    "        self.dropout2 = nn.Dropout(0.3)\n",
    "\n",
    "        self.fc3 = nn.Linear(512, num_classes)\n",
    "\n",
    "        self._initialize_weights()\n",
    "\n",
    "        torch.manual_seed(torch.initial_seed())\n",
    "\n",
    "    def _initialize_weights(self):\n",
    "        for m in self.modules():\n",
    "            if isinstance(m, nn.Conv2d):\n",
    "                nn.init.kaiming_normal_(m.weight, mode='fan_out', nonlinearity='relu')\n",
    "                if m.bias is not None:\n",
    "                    nn.init.constant_(m.bias, 0)\n",
    "            elif isinstance(m, nn.BatchNorm2d) or isinstance(m, nn.BatchNorm1d):\n",
    "                nn.init.constant_(m.weight, 1)\n",
    "                nn.init.constant_(m.bias, 0)\n",
    "            elif isinstance(m, nn.Linear):\n",
    "                nn.init.normal_(m.weight, 0, 0.01)\n",
    "                nn.init.constant_(m.bias, 0)\n",
    "\n",
    "\n",
    "    def forward(self, x):\n",
    "\n",
    "        x = F.relu(self.bn1(self.conv1(x)))\n",
    "        x = F.relu(self.bn2(self.conv2(x)))\n",
    "        x = self.pool(x)  \n",
    "\n",
    "        x = F.relu(self.bn3(self.conv3(x)))\n",
    "        x = F.relu(self.bn4(self.conv4(x)))\n",
    "        x = self.pool(x) \n",
    "\n",
    "        x = F.relu(self.bn5(self.conv5(x)))\n",
    "        x = F.relu(self.bn6(self.conv6(x)))\n",
    "        x = self.pool(x)  \n",
    "\n",
    "        x = F.relu(self.bn7(self.conv7(x)))\n",
    "        x = self.adaptive_pool(x) \n",
    "\n",
    "        x = x.view(x.size(0), -1)  \n",
    "\n",
    "        x = F.relu(self.bn_fc1(self.fc1(x)))\n",
    "        x = self.dropout1(x)\n",
    "\n",
    "        x = F.relu(self.bn_fc2(self.fc2(x)))\n",
    "        x = self.dropout2(x)\n",
    "\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "\n",
    "    def get_features(self, x):\n",
    "\n",
    "        x = F.relu(self.bn1(self.conv1(x)))\n",
    "        x = F.relu(self.bn2(self.conv2(x)))\n",
    "        x = self.pool(x)\n",
    "\n",
    "\n",
    "        x = F.relu(self.bn3(self.conv3(x)))\n",
    "        x = F.relu(self.bn4(self.conv4(x)))\n",
    "        x = self.pool(x)\n",
    "\n",
    "\n",
    "        x = F.relu(self.bn5(self.conv5(x)))\n",
    "        x = F.relu(self.bn6(self.conv6(x)))\n",
    "        x = self.pool(x)\n",
    "\n",
    "\n",
    "        x = F.relu(self.bn7(self.conv7(x)))\n",
    "        x = self.adaptive_pool(x)\n",
    "\n",
    "\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.bn_fc1(self.fc1(x)))\n",
    "        x = self.dropout1(x)\n",
    "        x = F.relu(self.bn_fc2(self.fc2(x)))\n",
    "\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:00.838269Z",
     "iopub.status.busy": "2025-09-23T10:39:00.837992Z",
     "iopub.status.idle": "2025-09-23T10:39:00.842016Z",
     "shell.execute_reply": "2025-09-23T10:39:00.841465Z",
     "shell.execute_reply.started": "2025-09-23T10:39:00.838247Z"
    },
    "id": "fKFX-gLRddsE",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 64\n",
    "LEARNING_RATE = 0.01\n",
    "LOCAL_EPOCHS = 5\n",
    "NUM_OF_CLIENTS = 50\n",
    "COMM_ROUND = 30\n",
    "ALPHA = 0.5  \n",
    "FRAC = 0.5  "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "oJrL1U1Hh1yJ"
   },
   "source": [
    "---"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:05.910397Z",
     "iopub.status.busy": "2025-09-23T10:39:05.910079Z",
     "iopub.status.idle": "2025-09-23T10:39:05.925076Z",
     "shell.execute_reply": "2025-09-23T10:39:05.924383Z",
     "shell.execute_reply.started": "2025-09-23T10:39:05.910373Z"
    },
    "id": "CImsSomMh1yH",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def load_and_partition_data(num_clients=NUM_OF_CLIENTS, alpha=ALPHA, batch_size=BATCH_SIZE, frac=FRAC, rand_seed=42):\n",
    "\n",
    "    transform = transforms.Compose([\n",
    "        transforms.ToTensor(),\n",
    "        transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))\n",
    "    ])\n",
    "\n",
    "\n",
    "    torch.manual_seed(rand_seed)\n",
    "    np.random.seed(rand_seed)\n",
    "\n",
    "    full_dataset = torchvision.datasets.CIFAR10(root='./data', train=True, download=True, transform=transform)\n",
    "    test_dataset = torchvision.datasets.CIFAR10(root='./data', train=False, download=True, transform=transform)\n",
    "\n",
    "    y_train = np.array(full_dataset.targets)\n",
    "    y_test = np.array(test_dataset.targets)\n",
    "\n",
    "    num_classes = NUM_CLASSES\n",
    "    N = len(full_dataset)  \n",
    "    N_test = len(test_dataset) \n",
    "\n",
    "    net_dataidx_map = {}\n",
    "    net_dataidx_map_test = {}\n",
    "\n",
    "    min_size = 0\n",
    "    while min_size < 10: \n",
    "        idx_batch = [[] for _ in range(num_clients)]\n",
    "        idx_batch_test = [[] for _ in range(num_clients)]\n",
    "        for k in range(num_classes):\n",
    "            idx_k = np.where(y_train == k)[0]\n",
    "            idx_k_test = np.where(y_test == k)[0]\n",
    "            np.random.shuffle(idx_k)  \n",
    "            np.random.shuffle(idx_k_test)  \n",
    "            proportions = np.random.dirichlet(np.repeat(alpha, num_clients))\n",
    "            proportions_train = np.array([p * (len(idx_j) < N / num_clients) for p, idx_j in zip(proportions, idx_batch)])\n",
    "            proportions_test = np.array([p * (len(idx_j) < N_test / num_clients) for p, idx_j in zip(proportions, idx_batch_test)])\n",
    "            proportions_train = proportions_train / proportions_train.sum()  \n",
    "            proportions_test = proportions_test / proportions_test.sum()  \n",
    "            proportions_train = (np.cumsum(proportions_train) * len(idx_k)).astype(int)[:-1]\n",
    "            proportions_test = (np.cumsum(proportions_test) * len(idx_k_test)).astype(int)[:-1]\n",
    "            idx_batch = [idx_j + idx.tolist() for idx_j, idx in zip(idx_batch, np.split(idx_k, proportions_train))]\n",
    "            idx_batch_test = [idx_j + idx.tolist() for idx_j, idx in zip(idx_batch_test, np.split(idx_k_test, proportions_test))]\n",
    "        min_size = min([len(idx_j) for idx_j in idx_batch])  \n",
    "\n",
    "    for j in range(num_clients):\n",
    "        np.random.shuffle(idx_batch[j])\n",
    "        np.random.shuffle(idx_batch_test[j])\n",
    "        net_dataidx_map[j] = idx_batch[j]\n",
    "        net_dataidx_map_test[j] = idx_batch_test[j]\n",
    "\n",
    "    client_train_loaders = []\n",
    "    client_val_loaders = []\n",
    "    client_class_distributions = []\n",
    "\n",
    "    for i in range(num_clients):\n",
    "        np.random.seed(rand_seed + i)\n",
    "\n",
    "        num_data = len(net_dataidx_map[i])\n",
    "        frac_num_data = int(frac * num_data)\n",
    "        frac_indices = np.random.choice(num_data, frac_num_data, replace=False)\n",
    "        train_indices = [net_dataidx_map[i][j] for j in frac_indices]\n",
    "\n",
    "        num_data_test = len(net_dataidx_map_test[i])\n",
    "        frac_num_data_test = int(min(2 * frac, 1.0) * num_data_test)  \n",
    "        frac_indices_test = np.random.choice(num_data_test, frac_num_data_test, replace=False)\n",
    "        val_indices = [net_dataidx_map_test[i][j] for j in frac_indices_test]\n",
    "\n",
    "        client_labels = [y_train[idx] for idx in train_indices]\n",
    "        class_counts = Counter(client_labels)\n",
    "        distribution = {cls: class_counts.get(cls, 0) / len(client_labels) if len(client_labels) > 0 else 0 for cls in range(num_classes)}\n",
    "        client_class_distributions.append(distribution)\n",
    "\n",
    "        client_train_dataset = Subset(full_dataset, train_indices)\n",
    "        client_val_dataset = Subset(test_dataset, val_indices)\n",
    "\n",
    "        g_train = torch.Generator().manual_seed(rand_seed + i)\n",
    "        g_val = torch.Generator().manual_seed(rand_seed + i + num_clients)\n",
    "\n",
    "        train_loader = DataLoader(client_train_dataset, batch_size=batch_size,\n",
    "                                 shuffle=True, generator=g_train, drop_last=True)\n",
    "        val_loader = DataLoader(client_val_dataset, batch_size=batch_size,\n",
    "                                shuffle=True, generator=g_val, drop_last=True)\n",
    "\n",
    "        client_train_loaders.append(train_loader)\n",
    "        client_val_loaders.append(val_loader)\n",
    "\n",
    "    g_test = torch.Generator().manual_seed(rand_seed + 2 * num_clients + 1)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=True,\n",
    "                             generator=g_test, num_workers=2)\n",
    "\n",
    "    print(\"Data partitioning complete.\")\n",
    "    torch.manual_seed(rand_seed)\n",
    "    np.random.seed(rand_seed)\n",
    "\n",
    "    return client_train_loaders, client_val_loaders, test_loader, client_class_distributions"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "OOr1Qsu_S7GC"
   },
   "source": [
    "## Utility Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:07.608696Z",
     "iopub.status.busy": "2025-09-23T10:39:07.608075Z",
     "iopub.status.idle": "2025-09-23T10:39:07.618524Z",
     "shell.execute_reply": "2025-09-23T10:39:07.617917Z",
     "shell.execute_reply.started": "2025-09-23T10:39:07.608671Z"
    },
    "id": "f2GMhq3Qh1yJ",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def client_train(model, train_loader, optimizer, epochs, print_flag=True):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        running_loss = 0.0\n",
    "        for inputs, targets in train_loader:\n",
    "            inputs, targets = inputs.to(device), targets.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "            loss = F.cross_entropy(outputs, targets)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            running_loss += loss.item()\n",
    "\n",
    "        if print_flag:\n",
    "            print(f\"Epoch [{epoch+1}/{epochs}], Loss: {running_loss/len(train_loader):.4f}\")\n",
    "\n",
    "def aggregate_models(global_model, client_models, client_indices, train_loaders):\n",
    "    global_dict = global_model.state_dict()\n",
    "\n",
    "    n_samples = [len(train_loaders[idx].dataset) for idx in client_indices]\n",
    "    total_samples = sum(n_samples)\n",
    "\n",
    "    aggregated_dict = {}\n",
    "\n",
    "    for key in global_dict.keys():\n",
    "        aggregated_dict[key] = torch.zeros_like(global_dict[key], dtype=torch.float32)\n",
    "\n",
    "    for i, idx in enumerate(client_indices):\n",
    "        client_dict = client_models[idx].state_dict()\n",
    "        weight = n_samples[i] / total_samples\n",
    "\n",
    "        for key in global_dict.keys():\n",
    "            aggregated_dict[key] += client_dict[key].float() * weight\n",
    "\n",
    "    for key in global_dict.keys():\n",
    "        global_dict[key] = aggregated_dict[key].to(dtype=global_dict[key].dtype)\n",
    "\n",
    "    global_model.load_state_dict(global_dict)\n",
    "\n",
    "\n",
    "def evaluate_model(model, data_loader):\n",
    "\n",
    "    model.eval()\n",
    "    correct = 0\n",
    "    total = 0\n",
    "    with torch.no_grad():\n",
    "        for inputs, targets in data_loader:\n",
    "            inputs, targets = inputs.to(device), targets.to(device)\n",
    "            outputs = model(inputs)\n",
    "            _, predicted = torch.max(outputs, 1)\n",
    "            total += targets.size(0)\n",
    "            correct += (predicted == targets).sum().item()\n",
    "    return 100 * correct / total\n",
    "\n",
    "def client_train_with_temp(model, train_loader, optimizer, epochs, temperature=1.0, print_flag=True):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        running_loss = 0.0\n",
    "        for inputs, targets in train_loader:\n",
    "            inputs, targets = inputs.to(device), targets.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "\n",
    "            if temperature != 1.0:\n",
    "                log_probs = F.log_softmax(outputs / temperature, dim=1)\n",
    "                loss = F.nll_loss(log_probs, targets)\n",
    "            else:\n",
    "                loss = F.cross_entropy(outputs, targets)\n",
    "\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            running_loss += loss.item()\n",
    "\n",
    "        if print_flag:\n",
    "            print(f\"Epoch [{epoch+1}/{epochs}], Loss: {running_loss/len(train_loader):.4f}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "changed temp adjust factor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:11.420349Z",
     "iopub.status.busy": "2025-09-23T10:39:11.419604Z",
     "iopub.status.idle": "2025-09-23T10:39:11.435955Z",
     "shell.execute_reply": "2025-09-23T10:39:11.435415Z",
     "shell.execute_reply.started": "2025-09-23T10:39:11.420314Z"
    },
    "id": "g0f5rDJn68sE",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "class AdaptiveClientHyperparams:\n",
    "    def __init__(self, initial_lr=0.01, min_lr=0.0001, max_lr=0.05,\n",
    "                 initial_temp=0.5, min_temp=0.05, max_temp=1.0,\n",
    "                 patience=2, lr_decay_factor=0.7, temp_adjust_factor=0.95, scaling_factor=3):\n",
    "        self.lr = initial_lr\n",
    "        self.min_lr = min_lr\n",
    "        self.max_lr = max_lr\n",
    "        self.lr_decay_factor = lr_decay_factor\n",
    "        self.scaling_factor = scaling_factor\n",
    "\n",
    "        self.temp = initial_temp\n",
    "        self.min_temp = min_temp\n",
    "        self.max_temp = max_temp\n",
    "        self.temp_adjust_factor = temp_adjust_factor\n",
    "\n",
    "        self.patience = patience\n",
    "        self.performance_history = []\n",
    "        self.stagnation_count = 0\n",
    "        self.improvement_count = 0\n",
    "        self.het_score = 0.0    \n",
    "\n",
    "    def update_temp_from_heterogeneity(self, het_score):\n",
    "        self.het_score = het_score\n",
    "        self.temp = self.max_temp * math.exp(-self.scaling_factor * het_score) \n",
    "        self.temp = min(max(self.temp, self.min_temp), self.max_temp)\n",
    "\n",
    "    def record_performance(self, accuracy):\n",
    "        self.performance_history.append(accuracy)\n",
    "\n",
    "        if len(self.performance_history) >= 3:\n",
    "            if self.performance_history[-1] <= self.performance_history[-2]:\n",
    "                self.stagnation_count += 1\n",
    "                self.improvement_count = 0\n",
    "            else:\n",
    "                self.improvement_count += 1\n",
    "                self.stagnation_count = 0\n",
    "\n",
    "            if self.stagnation_count >= self.patience:\n",
    "                if self.temp > self.min_temp * 1.1:  \n",
    "                    self.temp *= self.temp_adjust_factor\n",
    "                    self.temp = max(self.temp, self.min_temp)\n",
    "                    self.stagnation_count = 0\n",
    "                    return True, \"decrease-temp\", self.temp\n",
    "\n",
    "        return False, \"unchanged\", None\n",
    "\n",
    "    def get_lr(self):\n",
    "        return self.lr\n",
    "\n",
    "    def get_temp(self):\n",
    "        return self.temp\n",
    "\n",
    "\n",
    "def calculate_heterogeneity_score(client_distribution, global_distribution):\n",
    "    score = 0\n",
    "    for cls in range(10):\n",
    "        client_prob = client_distribution.get(cls, 0)\n",
    "        global_prob = global_distribution.get(cls, 1/10)\n",
    "        if client_prob > 0 and global_prob > 0:\n",
    "            ratio = client_prob / global_prob\n",
    "            score += abs(ratio - 1)\n",
    "\n",
    "    score = min(score / 10, 1)\n",
    "    return score\n",
    "\n",
    "def calculate_global_distribution(client_class_distributions):\n",
    "    global_dist = {}\n",
    "    n_clients = len(client_class_distributions)\n",
    "\n",
    "    for cls in range(10):\n",
    "        global_dist[cls] = sum(dist.get(cls, 0) for dist in client_class_distributions) / n_clients\n",
    "\n",
    "    for cls in range(10):\n",
    "        if global_dist[cls] < 0.01:\n",
    "            global_dist[cls] = 0.01\n",
    "\n",
    "    total = sum(global_dist.values())\n",
    "    global_dist = {k: v/total for k, v in global_dist.items()}\n",
    "\n",
    "    return global_dist\n",
    "\n",
    "def client_train(model, train_loader, optimizer, epochs, print_flag=True):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        running_loss = 0.0\n",
    "        for inputs, targets in train_loader:\n",
    "            inputs, targets = inputs.to(device), targets.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "            loss = F.cross_entropy(outputs, targets)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            running_loss += loss.item()\n",
    "\n",
    "        if print_flag:\n",
    "            print(f\"Epoch [{epoch+1}/{epochs}], Loss: {running_loss/len(train_loader):.4f}\")\n",
    "\n",
    "def aggregate_models(global_model, client_models, client_indices, train_loaders):\n",
    "    \n",
    "    global_dict = global_model.state_dict()\n",
    "\n",
    "    n_samples = [len(train_loaders[idx].dataset) for idx in client_indices]\n",
    "    total_samples = sum(n_samples)\n",
    "\n",
    "    aggregated_dict = {}\n",
    "\n",
    "    for key in global_dict.keys():\n",
    "        aggregated_dict[key] = torch.zeros_like(global_dict[key], dtype=torch.float32)\n",
    "\n",
    "    for i, idx in enumerate(client_indices):\n",
    "        client_dict = client_models[idx].state_dict()\n",
    "        weight = n_samples[i] / total_samples\n",
    "\n",
    "        for key in global_dict.keys():\n",
    "            aggregated_dict[key] += client_dict[key].float() * weight\n",
    "\n",
    "    for key in global_dict.keys():\n",
    "        global_dict[key] = aggregated_dict[key].to(dtype=global_dict[key].dtype)\n",
    "\n",
    "    global_model.load_state_dict(global_dict)\n",
    "\n",
    "\n",
    "def evaluate_model(model, data_loader):\n",
    "\n",
    "    model.eval()\n",
    "    correct = 0\n",
    "    total = 0\n",
    "    with torch.no_grad():\n",
    "        for inputs, targets in data_loader:\n",
    "            inputs, targets = inputs.to(device), targets.to(device)\n",
    "            outputs = model(inputs)\n",
    "            _, predicted = torch.max(outputs, 1)\n",
    "            total += targets.size(0)\n",
    "            correct += (predicted == targets).sum().item()\n",
    "    return 100 * correct / total\n",
    "\n",
    "def client_train_with_temp(model, train_loader, optimizer, epochs, temperature=1.0, print_flag=True):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        running_loss = 0.0\n",
    "        for inputs, targets in train_loader:\n",
    "            inputs, targets = inputs.to(device), targets.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "\n",
    "            if temperature != 1.0:\n",
    "                log_probs = F.log_softmax(outputs / temperature, dim=1)\n",
    "                loss = F.nll_loss(log_probs, targets)\n",
    "            else:\n",
    "                loss = F.cross_entropy(outputs, targets)\n",
    "\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            running_loss += loss.item()\n",
    "\n",
    "        if print_flag:\n",
    "            print(f\"Epoch [{epoch+1}/{epochs}], Loss: {running_loss/len(train_loader):.4f}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "1-V6QoWgA2hB"
   },
   "source": [
    "---"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6VOgsXc-A2hB"
   },
   "source": [
    "**HYPERPARAMETERS**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:18.939505Z",
     "iopub.status.busy": "2025-09-23T10:39:18.939201Z",
     "iopub.status.idle": "2025-09-23T10:39:18.943457Z",
     "shell.execute_reply": "2025-09-23T10:39:18.942785Z",
     "shell.execute_reply.started": "2025-09-23T10:39:18.939481Z"
    },
    "id": "RlQUq8Ht61cg",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 64\n",
    "LEARNING_RATE = 0.01\n",
    "LOCAL_EPOCHS = 5\n",
    "NUM_OF_CLIENTS = 50\n",
    "COMM_ROUND = 30\n",
    "ALPHA = 0.5  \n",
    "FRAC = 0.5  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:29.330959Z",
     "iopub.status.busy": "2025-09-23T10:39:29.330718Z",
     "iopub.status.idle": "2025-09-23T10:39:29.337700Z",
     "shell.execute_reply": "2025-09-23T10:39:29.336835Z",
     "shell.execute_reply.started": "2025-09-23T10:39:29.330940Z"
    },
    "id": "48RvxVUtA2hB",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def run_experiment():\n",
    "    print(f\"\\n\\n{'='*80}\")\n",
    "    print(f\"{'='*80}\\n\")\n",
    "\n",
    "    model_results = {}\n",
    "\n",
    "    scaling_fact = np.arange(0.5, 4.0, 0.5).tolist()\n",
    "\n",
    "    for sf in scaling_fact:\n",
    "        print(f\"\\n\\n{'#'*50}\")\n",
    "        print(f\"# RUNNING FedChill with Scaling Factor {sf}\")\n",
    "        print(f\"{'#'*50}\\n\")\n",
    "\n",
    "        server_acc, client_acc, final_model = run_fedchill(scaling_factor=sf)\n",
    "\n",
    "        avg_client_acc = np.mean(client_acc, axis=0).tolist()\n",
    "        server_acc = server_acc[-1]\n",
    "\n",
    "        model_results[sf] = {\n",
    "            'server_acc': server_acc,\n",
    "            'client_acc': client_acc,\n",
    "            'final_model': final_model\n",
    "        }\n",
    "\n",
    "\n",
    "    return model_results\n",
    "\n",
    "def plot_model_comparison(results):\n",
    "    \"\"\"Bar chart: Server vs Client accuracy across scaling factors.\"\"\"\n",
    "    scaling_factors = list(results.keys())\n",
    "\n",
    "    \n",
    "    # server_acc = [data['server_acc'][-1] for data in results.values()]\n",
    "    # client_acc = [np.mean(data['client_acc'][-1]) if isinstance(data['client_acc'][-1], (list, np.ndarray))\n",
    "                  # else data['client_acc'][-1] for data in results.values()]\n",
    "\n",
    "    x = np.arange(len(scaling_factors))  \n",
    "    width = 0.35  \n",
    "\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    plt.bar(x - width/2, server_acc, width, label='Server Acc (%)')\n",
    "    plt.bar(x + width/2, client_acc, width, label='Average Client Acc (%)')\n",
    "\n",
    "    plt.xticks(x, [str(sf) for sf in scaling_factors])\n",
    "    plt.xlabel(\"Scaling Factor\")\n",
    "    plt.ylabel(\"Accuracy (%)\")\n",
    "    plt.title(\"Server vs Client Accuracy by Scaling Factor\")\n",
    "    plt.legend()\n",
    "    plt.grid(axis='y', linestyle='--', alpha=0.7)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\"scaling_factor_comparison.png\")\n",
    "    plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:38.104424Z",
     "iopub.status.busy": "2025-09-23T10:39:38.104144Z",
     "iopub.status.idle": "2025-09-23T10:39:38.114552Z",
     "shell.execute_reply": "2025-09-23T10:39:38.114016Z",
     "shell.execute_reply.started": "2025-09-23T10:39:38.104404Z"
    },
    "id": "ZGkxcCH6A2hC",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def run_fedchill(scaling_factor=3, model_class=SimpleCNN):\n",
    "    print_flag = False\n",
    "\n",
    "    client_train_loaders, client_val_loaders, test_loader, client_class_distributions = load_and_partition_data(\n",
    "        num_clients=NUM_OF_CLIENTS,\n",
    "        alpha=ALPHA,\n",
    "        batch_size=BATCH_SIZE,\n",
    "        frac=FRAC,\n",
    "        rand_seed=42\n",
    "    )\n",
    "    num_clients = len(client_train_loaders)\n",
    "\n",
    "    global_distribution = calculate_global_distribution(client_class_distributions)\n",
    "\n",
    "    client_params = [AdaptiveClientHyperparams(scaling_factor=scaling_factor) for _ in range(num_clients)]\n",
    "\n",
    "    for i, distribution in enumerate(client_class_distributions):\n",
    "        het_score = calculate_heterogeneity_score(distribution, global_distribution)\n",
    "        client_params[i].update_temp_from_heterogeneity(het_score)\n",
    "        print(f\"Client {i} - Het Score: {het_score:.4f}, Initial temp: {client_params[i].get_temp():.4f}\")\n",
    "\n",
    "    global_model = model_class().to(device)\n",
    "\n",
    "    round_server_acc_list = []\n",
    "    round_client_acc_list = [[] for _ in range(num_clients)]\n",
    "\n",
    "    client_temp_history = [[] for _ in range(num_clients)]\n",
    "    client_lr_history = [[] for _ in range(num_clients)]\n",
    "\n",
    "    client_models = [copy.deepcopy(global_model).to(device) for _ in range(num_clients)]\n",
    "    client_optimizers = [optim.SGD(model.parameters(), lr=client_params[i].get_lr()) for i, model in enumerate(client_models)]\n",
    "\n",
    "    for comm_round in range(COMM_ROUND):\n",
    "        print(f\"\\n{'='*20} COMMUNICATION ROUND {comm_round+1} {'='*20}\")\n",
    "\n",
    "        selected_clients = list(range(num_clients))\n",
    "\n",
    "        if comm_round == COMM_ROUND - 1:\n",
    "            print_flag = True\n",
    "            print(\"\\n--- LOCAL TRAINING OF CLIENTS ---\")\n",
    "\n",
    "        for client_idx in selected_clients:\n",
    "            client_models[client_idx].load_state_dict(global_model.state_dict())\n",
    "\n",
    "            curr_lr = client_params[client_idx].get_lr()\n",
    "            curr_temp = client_params[client_idx].get_temp()\n",
    "\n",
    "            client_temp_history[client_idx].append(curr_temp)\n",
    "            client_lr_history[client_idx].append(curr_lr)\n",
    "\n",
    "            client_optimizers[client_idx] = optim.SGD(client_models[client_idx].parameters(), lr=curr_lr)\n",
    "\n",
    "            if comm_round == COMM_ROUND - 1:\n",
    "                print(f\"\\n--- Client {client_idx} Local Training with T={curr_temp:.4f}, LR={curr_lr:.6f} ---\")\n",
    "\n",
    "            client_train_with_temp(\n",
    "                client_models[client_idx],\n",
    "                client_train_loaders[client_idx],\n",
    "                client_optimizers[client_idx],\n",
    "                LOCAL_EPOCHS,\n",
    "                temperature=curr_temp,\n",
    "                print_flag=print_flag\n",
    "            )\n",
    "\n",
    "            local_acc = evaluate_model(client_models[client_idx], client_val_loaders[client_idx])\n",
    "            if comm_round == COMM_ROUND - 1:\n",
    "                print(f\"Client {client_idx} Private Data Validation Accuracy: {local_acc:.2f}%\")\n",
    "\n",
    "            client_testset_acc = evaluate_model(client_models[client_idx], test_loader)\n",
    "            round_client_acc_list[client_idx].append(local_acc)\n",
    "\n",
    "            adjusted, param_type, new_value = client_params[client_idx].record_performance(local_acc)\n",
    "            if adjusted and (comm_round == COMM_ROUND - 1 or print_flag):\n",
    "                print(f\"Client {client_idx} - {param_type} to {new_value:.6f}\")\n",
    "\n",
    "        aggregate_models(global_model, client_models, selected_clients, client_train_loaders)\n",
    "\n",
    "        server_test_val_acc = evaluate_model(global_model, test_loader)\n",
    "        if comm_round == COMM_ROUND - 1:\n",
    "            print(f\"\\n--- Server Evaluation ---\")\n",
    "            print(f\"Server Test Data Validation Accuracy: {server_test_val_acc:.2f}%\")\n",
    "\n",
    "        round_server_acc_list.append(server_test_val_acc)\n",
    "\n",
    "    return round_server_acc_list, round_client_acc_list, global_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T10:39:47.078888Z",
     "iopub.status.busy": "2025-09-23T10:39:47.078338Z",
     "iopub.status.idle": "2025-09-23T18:56:01.360572Z",
     "shell.execute_reply": "2025-09-23T18:56:01.359181Z",
     "shell.execute_reply.started": "2025-09-23T10:39:47.078864Z"
    },
    "trusted": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "================================================================================\n",
      "================================================================================\n",
      "\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 0.5\n",
      "##################################################\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 170M/170M [00:01<00:00, 91.2MB/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.6294\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.7386\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.6445\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.7602\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.6806\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.7174\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.6905\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.7296\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.7514\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.6281\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.6865\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.6099\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.6431\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.6735\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.6813\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.6903\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.7619\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.7056\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.6179\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.7402\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.6466\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.6729\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.6574\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.7471\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.7049\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.6791\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.6891\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.6133\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.6203\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.7291\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.7193\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.6127\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.6436\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.7157\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.6524\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.6848\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.6143\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.7286\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.7169\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.6230\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.6494\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.6065\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.6627\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.6210\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.5396, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6832\n",
      "Epoch [2/5], Loss: 0.2659\n",
      "Epoch [3/5], Loss: 0.1179\n",
      "Epoch [4/5], Loss: 0.0919\n",
      "Epoch [5/5], Loss: 0.0635\n",
      "Client 0 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 1 Local Training with T=0.5200, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9092\n",
      "Epoch [2/5], Loss: 0.2606\n",
      "Epoch [3/5], Loss: 0.1209\n",
      "Epoch [4/5], Loss: 0.0507\n",
      "Epoch [5/5], Loss: 0.0534\n",
      "Client 1 Private Data Validation Accuracy: 80.73%\n",
      "\n",
      "--- Client 2 Local Training with T=0.7017, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6375\n",
      "Epoch [2/5], Loss: 0.2526\n",
      "Epoch [3/5], Loss: 0.1532\n",
      "Epoch [4/5], Loss: 0.1092\n",
      "Epoch [5/5], Loss: 0.0743\n",
      "Client 2 Private Data Validation Accuracy: 72.40%\n",
      "\n",
      "--- Client 3 Local Training with T=0.4987, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8034\n",
      "Epoch [2/5], Loss: 0.2464\n",
      "Epoch [3/5], Loss: 0.1006\n",
      "Epoch [4/5], Loss: 0.0802\n",
      "Epoch [5/5], Loss: 0.0366\n",
      "Client 3 Private Data Validation Accuracy: 75.52%\n",
      "\n",
      "--- Client 4 Local Training with T=0.5883, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8608\n",
      "Epoch [2/5], Loss: 0.3620\n",
      "Epoch [3/5], Loss: 0.1578\n",
      "Epoch [4/5], Loss: 0.1060\n",
      "Epoch [5/5], Loss: 0.0597\n",
      "Client 4 Private Data Validation Accuracy: 69.27%\n",
      "\n",
      "--- Client 5 Local Training with T=0.6143, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0087\n",
      "Epoch [2/5], Loss: 0.4140\n",
      "Epoch [3/5], Loss: 0.1951\n",
      "Epoch [4/5], Loss: 0.1364\n",
      "Epoch [5/5], Loss: 0.0757\n",
      "Client 5 Private Data Validation Accuracy: 69.53%\n",
      "Client 5 - decrease-temp to 0.583571\n",
      "\n",
      "--- Client 6 Local Training with T=0.5200, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6995\n",
      "Epoch [2/5], Loss: 0.2143\n",
      "Epoch [3/5], Loss: 0.1064\n",
      "Epoch [4/5], Loss: 0.0801\n",
      "Epoch [5/5], Loss: 0.0416\n",
      "Client 6 Private Data Validation Accuracy: 76.17%\n",
      "\n",
      "--- Client 7 Local Training with T=0.6815, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8327\n",
      "Epoch [2/5], Loss: 0.2268\n",
      "Epoch [3/5], Loss: 0.0877\n",
      "Epoch [4/5], Loss: 0.0541\n",
      "Epoch [5/5], Loss: 0.0421\n",
      "Client 7 Private Data Validation Accuracy: 85.42%\n",
      "\n",
      "--- Client 8 Local Training with T=0.5343, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6631\n",
      "Epoch [2/5], Loss: 0.1345\n",
      "Epoch [3/5], Loss: 0.0841\n",
      "Epoch [4/5], Loss: 0.0315\n",
      "Epoch [5/5], Loss: 0.0292\n",
      "Client 8 Private Data Validation Accuracy: 85.42%\n",
      "\n",
      "--- Client 9 Local Training with T=0.6585, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1806\n",
      "Epoch [2/5], Loss: 0.4489\n",
      "Epoch [3/5], Loss: 0.2611\n",
      "Epoch [4/5], Loss: 0.1753\n",
      "Epoch [5/5], Loss: 0.1134\n",
      "Client 9 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 10 Local Training with T=0.6782, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2412\n",
      "Epoch [2/5], Loss: 0.6375\n",
      "Epoch [3/5], Loss: 0.3697\n",
      "Epoch [4/5], Loss: 0.2092\n",
      "Epoch [5/5], Loss: 0.1571\n",
      "Client 10 Private Data Validation Accuracy: 58.59%\n",
      "\n",
      "--- Client 11 Local Training with T=0.5669, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8806\n",
      "Epoch [2/5], Loss: 0.2276\n",
      "Epoch [3/5], Loss: 0.1048\n",
      "Epoch [4/5], Loss: 0.0621\n",
      "Epoch [5/5], Loss: 0.0421\n",
      "Client 11 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Client 12 Local Training with T=0.5886, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9237\n",
      "Epoch [2/5], Loss: 0.1923\n",
      "Epoch [3/5], Loss: 0.0859\n",
      "Epoch [4/5], Loss: 0.0419\n",
      "Epoch [5/5], Loss: 0.0304\n",
      "Client 12 Private Data Validation Accuracy: 83.85%\n",
      "\n",
      "--- Client 13 Local Training with T=0.4483, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0381\n",
      "Epoch [2/5], Loss: 0.3093\n",
      "Epoch [3/5], Loss: 0.1177\n",
      "Epoch [4/5], Loss: 0.0501\n",
      "Epoch [5/5], Loss: 0.0403\n",
      "Client 13 Private Data Validation Accuracy: 77.60%\n",
      "\n",
      "--- Client 14 Local Training with T=0.4976, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1855\n",
      "Epoch [2/5], Loss: 0.3554\n",
      "Epoch [3/5], Loss: 0.1719\n",
      "Epoch [4/5], Loss: 0.0946\n",
      "Epoch [5/5], Loss: 0.0625\n",
      "Client 14 Private Data Validation Accuracy: 77.60%\n",
      "\n",
      "--- Client 15 Local Training with T=0.4693, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7074\n",
      "Epoch [2/5], Loss: 0.2254\n",
      "Epoch [3/5], Loss: 0.0864\n",
      "Epoch [4/5], Loss: 0.0647\n",
      "Epoch [5/5], Loss: 0.0281\n",
      "Client 15 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 16 Local Training with T=0.5774, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0027\n",
      "Epoch [2/5], Loss: 0.4618\n",
      "Epoch [3/5], Loss: 0.1860\n",
      "Epoch [4/5], Loss: 0.1258\n",
      "Epoch [5/5], Loss: 0.0673\n",
      "Client 16 Private Data Validation Accuracy: 82.81%\n",
      "\n",
      "--- Client 17 Local Training with T=0.5549, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0505\n",
      "Epoch [2/5], Loss: 0.3774\n",
      "Epoch [3/5], Loss: 0.1640\n",
      "Epoch [4/5], Loss: 0.0908\n",
      "Epoch [5/5], Loss: 0.0721\n",
      "Client 17 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 18 Local Training with T=0.5623, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8665\n",
      "Epoch [2/5], Loss: 0.3436\n",
      "Epoch [3/5], Loss: 0.1828\n",
      "Epoch [4/5], Loss: 0.0988\n",
      "Epoch [5/5], Loss: 0.0861\n",
      "Client 18 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 19 Local Training with T=0.6065, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6594\n",
      "Epoch [2/5], Loss: 0.2548\n",
      "Epoch [3/5], Loss: 0.1207\n",
      "Epoch [4/5], Loss: 0.0632\n",
      "Epoch [5/5], Loss: 0.0446\n",
      "Client 19 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 20 Local Training with T=0.6876, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7575\n",
      "Epoch [2/5], Loss: 0.3360\n",
      "Epoch [3/5], Loss: 0.1656\n",
      "Epoch [4/5], Loss: 0.1185\n",
      "Epoch [5/5], Loss: 0.0863\n",
      "Client 20 Private Data Validation Accuracy: 71.09%\n",
      "\n",
      "--- Client 21 Local Training with T=0.5460, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9081\n",
      "Epoch [2/5], Loss: 0.3948\n",
      "Epoch [3/5], Loss: 0.2517\n",
      "Epoch [4/5], Loss: 0.1367\n",
      "Epoch [5/5], Loss: 0.0956\n",
      "Client 21 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 22 Local Training with T=0.5298, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7670\n",
      "Epoch [2/5], Loss: 0.1945\n",
      "Epoch [3/5], Loss: 0.0925\n",
      "Epoch [4/5], Loss: 0.0888\n",
      "Epoch [5/5], Loss: 0.0453\n",
      "Client 22 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 23 Local Training with T=0.5728, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4696\n",
      "Epoch [2/5], Loss: 0.6646\n",
      "Epoch [3/5], Loss: 0.2988\n",
      "Epoch [4/5], Loss: 0.1560\n",
      "Epoch [5/5], Loss: 0.1059\n",
      "Client 23 Private Data Validation Accuracy: 54.69%\n",
      "Client 23 - decrease-temp to 0.544126\n",
      "\n",
      "--- Client 24 Local Training with T=0.4753, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.5284\n",
      "Epoch [2/5], Loss: 0.5939\n",
      "Epoch [3/5], Loss: 0.2368\n",
      "Epoch [4/5], Loss: 0.1431\n",
      "Epoch [5/5], Loss: 0.0769\n",
      "Client 24 Private Data Validation Accuracy: 59.90%\n",
      "\n",
      "--- Client 25 Local Training with T=0.5769, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4069\n",
      "Epoch [2/5], Loss: 0.5781\n",
      "Epoch [3/5], Loss: 0.2247\n",
      "Epoch [4/5], Loss: 0.1791\n",
      "Epoch [5/5], Loss: 0.1087\n",
      "Client 25 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 26 Local Training with T=0.6246, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6570\n",
      "Epoch [2/5], Loss: 0.1945\n",
      "Epoch [3/5], Loss: 0.0990\n",
      "Epoch [4/5], Loss: 0.0837\n",
      "Epoch [5/5], Loss: 0.0486\n",
      "Client 26 Private Data Validation Accuracy: 81.77%\n",
      "\n",
      "--- Client 27 Local Training with T=0.6742, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9276\n",
      "Epoch [2/5], Loss: 0.4350\n",
      "Epoch [3/5], Loss: 0.2283\n",
      "Epoch [4/5], Loss: 0.1467\n",
      "Epoch [5/5], Loss: 0.1060\n",
      "Client 27 Private Data Validation Accuracy: 55.21%\n",
      "\n",
      "--- Client 28 Local Training with T=0.6043, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7395\n",
      "Epoch [2/5], Loss: 0.2069\n",
      "Epoch [3/5], Loss: 0.0939\n",
      "Epoch [4/5], Loss: 0.0574\n",
      "Epoch [5/5], Loss: 0.0450\n",
      "Client 28 Private Data Validation Accuracy: 80.73%\n",
      "Client 28 - decrease-temp to 0.574106\n",
      "\n",
      "--- Client 29 Local Training with T=0.5822, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6087\n",
      "Epoch [2/5], Loss: 0.2845\n",
      "Epoch [3/5], Loss: 0.1439\n",
      "Epoch [4/5], Loss: 0.0743\n",
      "Epoch [5/5], Loss: 0.0561\n",
      "Client 29 Private Data Validation Accuracy: 74.22%\n",
      "\n",
      "--- Client 30 Local Training with T=0.5332, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5645\n",
      "Epoch [2/5], Loss: 0.2188\n",
      "Epoch [3/5], Loss: 0.1178\n",
      "Epoch [4/5], Loss: 0.0665\n",
      "Epoch [5/5], Loss: 0.0472\n",
      "Client 30 Private Data Validation Accuracy: 73.44%\n",
      "Client 30 - decrease-temp to 0.506561\n",
      "\n",
      "--- Client 31 Local Training with T=0.4995, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2909\n",
      "Epoch [2/5], Loss: 0.3896\n",
      "Epoch [3/5], Loss: 0.2043\n",
      "Epoch [4/5], Loss: 0.0961\n",
      "Epoch [5/5], Loss: 0.0697\n",
      "Client 31 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 32 Local Training with T=0.5893, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9814\n",
      "Epoch [2/5], Loss: 0.2813\n",
      "Epoch [3/5], Loss: 0.1147\n",
      "Epoch [4/5], Loss: 0.0745\n",
      "Epoch [5/5], Loss: 0.0590\n",
      "Client 32 Private Data Validation Accuracy: 79.69%\n",
      "\n",
      "--- Client 33 Local Training with T=0.5938, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7993\n",
      "Epoch [2/5], Loss: 0.2805\n",
      "Epoch [3/5], Loss: 0.1204\n",
      "Epoch [4/5], Loss: 0.0933\n",
      "Epoch [5/5], Loss: 0.0664\n",
      "Client 33 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 34 Local Training with T=0.6491, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8320\n",
      "Epoch [2/5], Loss: 0.2511\n",
      "Epoch [3/5], Loss: 0.1001\n",
      "Epoch [4/5], Loss: 0.0494\n",
      "Epoch [5/5], Loss: 0.0413\n",
      "Client 34 Private Data Validation Accuracy: 81.77%\n",
      "\n",
      "--- Client 35 Local Training with T=0.4991, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3223\n",
      "Epoch [2/5], Loss: 0.3653\n",
      "Epoch [3/5], Loss: 0.1270\n",
      "Epoch [4/5], Loss: 0.0610\n",
      "Epoch [5/5], Loss: 0.0548\n",
      "Client 35 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 36 Local Training with T=0.5809, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8401\n",
      "Epoch [2/5], Loss: 0.3187\n",
      "Epoch [3/5], Loss: 0.1683\n",
      "Epoch [4/5], Loss: 0.0869\n",
      "Epoch [5/5], Loss: 0.0735\n",
      "Client 36 Private Data Validation Accuracy: 84.38%\n",
      "\n",
      "--- Client 37 Local Training with T=0.5474, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6863\n",
      "Epoch [2/5], Loss: 0.1967\n",
      "Epoch [3/5], Loss: 0.0751\n",
      "Epoch [4/5], Loss: 0.0447\n",
      "Epoch [5/5], Loss: 0.0356\n",
      "Client 37 Private Data Validation Accuracy: 86.98%\n",
      "\n",
      "--- Client 38 Local Training with T=0.5829, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0373\n",
      "Epoch [2/5], Loss: 0.4137\n",
      "Epoch [3/5], Loss: 0.2141\n",
      "Epoch [4/5], Loss: 0.1267\n",
      "Epoch [5/5], Loss: 0.0885\n",
      "Client 38 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 39 Local Training with T=0.4796, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7587\n",
      "Epoch [2/5], Loss: 0.0687\n",
      "Epoch [3/5], Loss: 0.0332\n",
      "Epoch [4/5], Loss: 0.0170\n",
      "Epoch [5/5], Loss: 0.0230\n",
      "Client 39 Private Data Validation Accuracy: 92.19%\n",
      "\n",
      "--- Client 40 Local Training with T=0.4940, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0972\n",
      "Epoch [2/5], Loss: 0.3113\n",
      "Epoch [3/5], Loss: 0.2179\n",
      "Epoch [4/5], Loss: 0.0936\n",
      "Epoch [5/5], Loss: 0.0447\n",
      "Client 40 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 41 Local Training with T=0.6180, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7635\n",
      "Epoch [2/5], Loss: 0.2905\n",
      "Epoch [3/5], Loss: 0.1414\n",
      "Epoch [4/5], Loss: 0.1007\n",
      "Epoch [5/5], Loss: 0.0788\n",
      "Client 41 Private Data Validation Accuracy: 72.40%\n",
      "\n",
      "--- Client 42 Local Training with T=0.5836, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9749\n",
      "Epoch [2/5], Loss: 0.3915\n",
      "Epoch [3/5], Loss: 0.1938\n",
      "Epoch [4/5], Loss: 0.1023\n",
      "Epoch [5/5], Loss: 0.0552\n",
      "Client 42 Private Data Validation Accuracy: 74.48%\n",
      "\n",
      "--- Client 43 Local Training with T=0.5934, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3719\n",
      "Epoch [2/5], Loss: 0.8253\n",
      "Epoch [3/5], Loss: 0.3465\n",
      "Epoch [4/5], Loss: 0.1592\n",
      "Epoch [5/5], Loss: 0.1411\n",
      "Client 43 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 44 Local Training with T=0.5547, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2780\n",
      "Epoch [2/5], Loss: 0.5193\n",
      "Epoch [3/5], Loss: 0.3033\n",
      "Epoch [4/5], Loss: 0.1372\n",
      "Epoch [5/5], Loss: 0.0710\n",
      "Client 44 Private Data Validation Accuracy: 65.10%\n",
      "\n",
      "--- Client 45 Local Training with T=0.5075, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6090\n",
      "Epoch [2/5], Loss: 0.1745\n",
      "Epoch [3/5], Loss: 0.0869\n",
      "Epoch [4/5], Loss: 0.0579\n",
      "Epoch [5/5], Loss: 0.0391\n",
      "Client 45 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 46 Local Training with T=0.5289, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0950\n",
      "Epoch [2/5], Loss: 0.3646\n",
      "Epoch [3/5], Loss: 0.1535\n",
      "Epoch [4/5], Loss: 0.0934\n",
      "Epoch [5/5], Loss: 0.0587\n",
      "Client 46 Private Data Validation Accuracy: 64.06%\n",
      "\n",
      "--- Client 47 Local Training with T=0.5200, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4154\n",
      "Epoch [2/5], Loss: 0.2608\n",
      "Epoch [3/5], Loss: 0.1144\n",
      "Epoch [4/5], Loss: 0.0753\n",
      "Epoch [5/5], Loss: 0.0509\n",
      "Client 47 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 48 Local Training with T=0.5981, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7540\n",
      "Epoch [2/5], Loss: 0.2277\n",
      "Epoch [3/5], Loss: 0.1137\n",
      "Epoch [4/5], Loss: 0.0759\n",
      "Epoch [5/5], Loss: 0.0594\n",
      "Client 48 Private Data Validation Accuracy: 72.27%\n",
      "\n",
      "--- Client 49 Local Training with T=0.5324, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4287\n",
      "Epoch [2/5], Loss: 0.4812\n",
      "Epoch [3/5], Loss: 0.2389\n",
      "Epoch [4/5], Loss: 0.1159\n",
      "Epoch [5/5], Loss: 0.0792\n",
      "Client 49 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 60.13%\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 1.0\n",
      "##################################################\n",
      "\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.3962\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.5456\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.4154\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.5780\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.4633\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.5147\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.4767\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.5323\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.5647\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.3945\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.4713\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.3719\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.4136\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.4536\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.4641\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.4765\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.5804\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.4979\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.3818\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.5479\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.4181\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.4527\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.4322\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.5581\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.4968\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.4612\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.4749\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.3761\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.3848\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.5315\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.5173\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.3754\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.4142\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.5122\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.4257\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.4689\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.3773\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.5308\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.5140\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.3882\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.4217\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.3679\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.4391\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.3856\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.3227, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6900\n",
      "Epoch [2/5], Loss: 0.2537\n",
      "Epoch [3/5], Loss: 0.1321\n",
      "Epoch [4/5], Loss: 0.0851\n",
      "Epoch [5/5], Loss: 0.0583\n",
      "Client 0 Private Data Validation Accuracy: 71.09%\n",
      "\n",
      "--- Client 1 Local Training with T=0.3154, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7769\n",
      "Epoch [2/5], Loss: 0.2026\n",
      "Epoch [3/5], Loss: 0.0649\n",
      "Epoch [4/5], Loss: 0.0328\n",
      "Epoch [5/5], Loss: 0.0400\n",
      "Client 1 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 2 Local Training with T=0.5183, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5749\n",
      "Epoch [2/5], Loss: 0.2335\n",
      "Epoch [3/5], Loss: 0.1286\n",
      "Epoch [4/5], Loss: 0.0981\n",
      "Epoch [5/5], Loss: 0.0622\n",
      "Client 2 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 3 Local Training with T=0.3215, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7342\n",
      "Epoch [2/5], Loss: 0.2457\n",
      "Epoch [3/5], Loss: 0.0783\n",
      "Epoch [4/5], Loss: 0.0632\n",
      "Epoch [5/5], Loss: 0.0299\n",
      "Client 3 Private Data Validation Accuracy: 73.96%\n",
      "Client 3 - decrease-temp to 0.305385\n",
      "\n",
      "--- Client 4 Local Training with T=0.5491, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7602\n",
      "Epoch [2/5], Loss: 0.3115\n",
      "Epoch [3/5], Loss: 0.1545\n",
      "Epoch [4/5], Loss: 0.1187\n",
      "Epoch [5/5], Loss: 0.0717\n",
      "Client 4 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 5 Local Training with T=0.3773, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9427\n",
      "Epoch [2/5], Loss: 0.3125\n",
      "Epoch [3/5], Loss: 0.1944\n",
      "Epoch [4/5], Loss: 0.1152\n",
      "Epoch [5/5], Loss: 0.0571\n",
      "Client 5 Private Data Validation Accuracy: 72.66%\n",
      "\n",
      "--- Client 6 Local Training with T=0.3154, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7604\n",
      "Epoch [2/5], Loss: 0.2140\n",
      "Epoch [3/5], Loss: 0.0830\n",
      "Epoch [4/5], Loss: 0.0761\n",
      "Epoch [5/5], Loss: 0.0443\n",
      "Client 6 Private Data Validation Accuracy: 77.34%\n",
      "\n",
      "--- Client 7 Local Training with T=0.4192, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6766\n",
      "Epoch [2/5], Loss: 0.1396\n",
      "Epoch [3/5], Loss: 0.0657\n",
      "Epoch [4/5], Loss: 0.0370\n",
      "Epoch [5/5], Loss: 0.0228\n",
      "Client 7 Private Data Validation Accuracy: 83.85%\n",
      "\n",
      "--- Client 8 Local Training with T=0.4303, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5621\n",
      "Epoch [2/5], Loss: 0.1069\n",
      "Epoch [3/5], Loss: 0.0801\n",
      "Epoch [4/5], Loss: 0.0363\n",
      "Epoch [5/5], Loss: 0.0308\n",
      "Client 8 Private Data Validation Accuracy: 83.85%\n",
      "\n",
      "--- Client 9 Local Training with T=0.5057, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0832\n",
      "Epoch [2/5], Loss: 0.4092\n",
      "Epoch [3/5], Loss: 0.2386\n",
      "Epoch [4/5], Loss: 0.1582\n",
      "Epoch [5/5], Loss: 0.1046\n",
      "Client 9 Private Data Validation Accuracy: 58.59%\n",
      "\n",
      "--- Client 10 Local Training with T=0.4841, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1850\n",
      "Epoch [2/5], Loss: 0.5525\n",
      "Epoch [3/5], Loss: 0.3087\n",
      "Epoch [4/5], Loss: 0.1847\n",
      "Epoch [5/5], Loss: 0.1292\n",
      "Client 10 Private Data Validation Accuracy: 62.50%\n",
      "Client 10 - decrease-temp to 0.459914\n",
      "\n",
      "--- Client 11 Local Training with T=0.3748, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7401\n",
      "Epoch [2/5], Loss: 0.2219\n",
      "Epoch [3/5], Loss: 0.0883\n",
      "Epoch [4/5], Loss: 0.0564\n",
      "Epoch [5/5], Loss: 0.0245\n",
      "Client 11 Private Data Validation Accuracy: 77.34%\n",
      "Client 11 - decrease-temp to 0.356039\n",
      "\n",
      "--- Client 12 Local Training with T=0.3838, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7682\n",
      "Epoch [2/5], Loss: 0.1695\n",
      "Epoch [3/5], Loss: 0.0888\n",
      "Epoch [4/5], Loss: 0.0339\n",
      "Epoch [5/5], Loss: 0.0239\n",
      "Client 12 Private Data Validation Accuracy: 85.42%\n",
      "\n",
      "--- Client 13 Local Training with T=0.3029, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9209\n",
      "Epoch [2/5], Loss: 0.2874\n",
      "Epoch [3/5], Loss: 0.1084\n",
      "Epoch [4/5], Loss: 0.0378\n",
      "Epoch [5/5], Loss: 0.0450\n",
      "Client 13 Private Data Validation Accuracy: 78.65%\n",
      "\n",
      "--- Client 14 Local Training with T=0.3369, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0076\n",
      "Epoch [2/5], Loss: 0.3300\n",
      "Epoch [3/5], Loss: 0.1632\n",
      "Epoch [4/5], Loss: 0.0689\n",
      "Epoch [5/5], Loss: 0.0423\n",
      "Client 14 Private Data Validation Accuracy: 71.35%\n",
      "Client 14 - decrease-temp to 0.320048\n",
      "\n",
      "--- Client 15 Local Training with T=0.2847, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7043\n",
      "Epoch [2/5], Loss: 0.2492\n",
      "Epoch [3/5], Loss: 0.0913\n",
      "Epoch [4/5], Loss: 0.0745\n",
      "Epoch [5/5], Loss: 0.0319\n",
      "Client 15 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 16 Local Training with T=0.3889, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9094\n",
      "Epoch [2/5], Loss: 0.3960\n",
      "Epoch [3/5], Loss: 0.1170\n",
      "Epoch [4/5], Loss: 0.1009\n",
      "Epoch [5/5], Loss: 0.0538\n",
      "Client 16 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 17 Local Training with T=0.4189, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0167\n",
      "Epoch [2/5], Loss: 0.3623\n",
      "Epoch [3/5], Loss: 0.1661\n",
      "Epoch [4/5], Loss: 0.0727\n",
      "Epoch [5/5], Loss: 0.0594\n",
      "Client 17 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 18 Local Training with T=0.4086, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7696\n",
      "Epoch [2/5], Loss: 0.2785\n",
      "Epoch [3/5], Loss: 0.1306\n",
      "Epoch [4/5], Loss: 0.0684\n",
      "Epoch [5/5], Loss: 0.0578\n",
      "Client 18 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 19 Local Training with T=0.3320, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6096\n",
      "Epoch [2/5], Loss: 0.2089\n",
      "Epoch [3/5], Loss: 0.0904\n",
      "Epoch [4/5], Loss: 0.0457\n",
      "Epoch [5/5], Loss: 0.0359\n",
      "Client 19 Private Data Validation Accuracy: 79.30%\n",
      "\n",
      "--- Client 20 Local Training with T=0.5238, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6850\n",
      "Epoch [2/5], Loss: 0.2695\n",
      "Epoch [3/5], Loss: 0.1463\n",
      "Epoch [4/5], Loss: 0.0930\n",
      "Epoch [5/5], Loss: 0.0740\n",
      "Client 20 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 21 Local Training with T=0.4493, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8015\n",
      "Epoch [2/5], Loss: 0.3270\n",
      "Epoch [3/5], Loss: 0.2165\n",
      "Epoch [4/5], Loss: 0.1065\n",
      "Epoch [5/5], Loss: 0.0857\n",
      "Client 21 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Client 22 Local Training with T=0.3446, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6269\n",
      "Epoch [2/5], Loss: 0.1544\n",
      "Epoch [3/5], Loss: 0.0593\n",
      "Epoch [4/5], Loss: 0.0469\n",
      "Epoch [5/5], Loss: 0.0564\n",
      "Client 22 Private Data Validation Accuracy: 76.04%\n",
      "\n",
      "--- Client 23 Local Training with T=0.4240, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3348\n",
      "Epoch [2/5], Loss: 0.5367\n",
      "Epoch [3/5], Loss: 0.2422\n",
      "Epoch [4/5], Loss: 0.1457\n",
      "Epoch [5/5], Loss: 0.0999\n",
      "Client 23 Private Data Validation Accuracy: 59.38%\n",
      "Client 23 - decrease-temp to 0.402771\n",
      "\n",
      "--- Client 24 Local Training with T=0.3585, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1986\n",
      "Epoch [2/5], Loss: 0.4737\n",
      "Epoch [3/5], Loss: 0.1992\n",
      "Epoch [4/5], Loss: 0.0924\n",
      "Epoch [5/5], Loss: 0.0662\n",
      "Client 24 Private Data Validation Accuracy: 63.54%\n",
      "\n",
      "--- Client 25 Local Training with T=0.3688, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.5371\n",
      "Epoch [2/5], Loss: 0.4696\n",
      "Epoch [3/5], Loss: 0.1826\n",
      "Epoch [4/5], Loss: 0.1256\n",
      "Epoch [5/5], Loss: 0.0678\n",
      "Client 25 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 26 Local Training with T=0.3344, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5493\n",
      "Epoch [2/5], Loss: 0.2132\n",
      "Epoch [3/5], Loss: 0.1022\n",
      "Epoch [4/5], Loss: 0.0898\n",
      "Epoch [5/5], Loss: 0.0282\n",
      "Client 26 Private Data Validation Accuracy: 77.08%\n",
      "\n",
      "--- Client 27 Local Training with T=0.4785, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8880\n",
      "Epoch [2/5], Loss: 0.3942\n",
      "Epoch [3/5], Loss: 0.1907\n",
      "Epoch [4/5], Loss: 0.1077\n",
      "Epoch [5/5], Loss: 0.0951\n",
      "Client 27 Private Data Validation Accuracy: 58.85%\n",
      "\n",
      "--- Client 28 Local Training with T=0.4047, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6075\n",
      "Epoch [2/5], Loss: 0.1805\n",
      "Epoch [3/5], Loss: 0.0913\n",
      "Epoch [4/5], Loss: 0.0526\n",
      "Epoch [5/5], Loss: 0.0310\n",
      "Client 28 Private Data Validation Accuracy: 82.29%\n",
      "\n",
      "--- Client 29 Local Training with T=0.4162, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5592\n",
      "Epoch [2/5], Loss: 0.2395\n",
      "Epoch [3/5], Loss: 0.0950\n",
      "Epoch [4/5], Loss: 0.0572\n",
      "Epoch [5/5], Loss: 0.0513\n",
      "Client 29 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 30 Local Training with T=0.3868, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4965\n",
      "Epoch [2/5], Loss: 0.1798\n",
      "Epoch [3/5], Loss: 0.1027\n",
      "Epoch [4/5], Loss: 0.0549\n",
      "Epoch [5/5], Loss: 0.0372\n",
      "Client 30 Private Data Validation Accuracy: 73.75%\n",
      "\n",
      "--- Client 31 Local Training with T=0.3063, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2268\n",
      "Epoch [2/5], Loss: 0.3452\n",
      "Epoch [3/5], Loss: 0.1537\n",
      "Epoch [4/5], Loss: 0.0857\n",
      "Epoch [5/5], Loss: 0.0610\n",
      "Client 31 Private Data Validation Accuracy: 79.69%\n",
      "\n",
      "--- Client 32 Local Training with T=0.2977, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0023\n",
      "Epoch [2/5], Loss: 0.2740\n",
      "Epoch [3/5], Loss: 0.1084\n",
      "Epoch [4/5], Loss: 0.0537\n",
      "Epoch [5/5], Loss: 0.0318\n",
      "Client 32 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 33 Local Training with T=0.4557, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6880\n",
      "Epoch [2/5], Loss: 0.2433\n",
      "Epoch [3/5], Loss: 0.1008\n",
      "Epoch [4/5], Loss: 0.0855\n",
      "Epoch [5/5], Loss: 0.0520\n",
      "Client 33 Private Data Validation Accuracy: 66.41%\n",
      "\n",
      "--- Client 34 Local Training with T=0.4435, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6660\n",
      "Epoch [2/5], Loss: 0.1652\n",
      "Epoch [3/5], Loss: 0.0695\n",
      "Epoch [4/5], Loss: 0.0430\n",
      "Epoch [5/5], Loss: 0.0311\n",
      "Client 34 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 35 Local Training with T=0.2760, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6185\n",
      "Epoch [2/5], Loss: 0.3620\n",
      "Epoch [3/5], Loss: 0.1459\n",
      "Epoch [4/5], Loss: 0.0539\n",
      "Epoch [5/5], Loss: 0.0481\n",
      "Client 35 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 36 Local Training with T=0.3551, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8335\n",
      "Epoch [2/5], Loss: 0.3247\n",
      "Epoch [3/5], Loss: 0.1257\n",
      "Epoch [4/5], Loss: 0.0565\n",
      "Epoch [5/5], Loss: 0.0396\n",
      "Client 36 Private Data Validation Accuracy: 83.59%\n",
      "\n",
      "--- Client 37 Local Training with T=0.3154, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6670\n",
      "Epoch [2/5], Loss: 0.1828\n",
      "Epoch [3/5], Loss: 0.0808\n",
      "Epoch [4/5], Loss: 0.0220\n",
      "Epoch [5/5], Loss: 0.0213\n",
      "Client 37 Private Data Validation Accuracy: 86.98%\n",
      "\n",
      "--- Client 38 Local Training with T=0.4622, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9252\n",
      "Epoch [2/5], Loss: 0.3566\n",
      "Epoch [3/5], Loss: 0.2020\n",
      "Epoch [4/5], Loss: 0.1269\n",
      "Epoch [5/5], Loss: 0.0953\n",
      "Client 38 Private Data Validation Accuracy: 82.03%\n",
      "\n",
      "--- Client 39 Local Training with T=0.3467, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6116\n",
      "Epoch [2/5], Loss: 0.0666\n",
      "Epoch [3/5], Loss: 0.0275\n",
      "Epoch [4/5], Loss: 0.0130\n",
      "Epoch [5/5], Loss: 0.0180\n",
      "Client 39 Private Data Validation Accuracy: 89.06%\n",
      "\n",
      "--- Client 40 Local Training with T=0.3154, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0286\n",
      "Epoch [2/5], Loss: 0.2646\n",
      "Epoch [3/5], Loss: 0.1468\n",
      "Epoch [4/5], Loss: 0.0786\n",
      "Epoch [5/5], Loss: 0.0593\n",
      "Client 40 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 41 Local Training with T=0.3819, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7231\n",
      "Epoch [2/5], Loss: 0.2163\n",
      "Epoch [3/5], Loss: 0.0913\n",
      "Epoch [4/5], Loss: 0.0738\n",
      "Epoch [5/5], Loss: 0.0492\n",
      "Client 41 Private Data Validation Accuracy: 72.40%\n",
      "\n",
      "--- Client 42 Local Training with T=0.2774, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0002\n",
      "Epoch [2/5], Loss: 0.4196\n",
      "Epoch [3/5], Loss: 0.3495\n",
      "Epoch [4/5], Loss: 0.1197\n",
      "Epoch [5/5], Loss: 0.0511\n",
      "Client 42 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 43 Local Training with T=0.4323, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3802\n",
      "Epoch [2/5], Loss: 0.7308\n",
      "Epoch [3/5], Loss: 0.2739\n",
      "Epoch [4/5], Loss: 0.1167\n",
      "Epoch [5/5], Loss: 0.0959\n",
      "Client 43 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 44 Local Training with T=0.4186, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0824\n",
      "Epoch [2/5], Loss: 0.3725\n",
      "Epoch [3/5], Loss: 0.2246\n",
      "Epoch [4/5], Loss: 0.1090\n",
      "Epoch [5/5], Loss: 0.0587\n",
      "Client 44 Private Data Validation Accuracy: 67.71%\n",
      "\n",
      "--- Client 45 Local Training with T=0.3503, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5078\n",
      "Epoch [2/5], Loss: 0.1486\n",
      "Epoch [3/5], Loss: 0.0758\n",
      "Epoch [4/5], Loss: 0.0513\n",
      "Epoch [5/5], Loss: 0.0273\n",
      "Client 45 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 46 Local Training with T=0.3263, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9746\n",
      "Epoch [2/5], Loss: 0.3356\n",
      "Epoch [3/5], Loss: 0.1382\n",
      "Epoch [4/5], Loss: 0.0969\n",
      "Epoch [5/5], Loss: 0.0502\n",
      "Client 46 Private Data Validation Accuracy: 66.67%\n",
      "Client 46 - decrease-temp to 0.310003\n",
      "\n",
      "--- Client 47 Local Training with T=0.3320, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2807\n",
      "Epoch [2/5], Loss: 0.1537\n",
      "Epoch [3/5], Loss: 0.0709\n",
      "Epoch [4/5], Loss: 0.0389\n",
      "Epoch [5/5], Loss: 0.0372\n",
      "Client 47 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 48 Local Training with T=0.3765, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6756\n",
      "Epoch [2/5], Loss: 0.1907\n",
      "Epoch [3/5], Loss: 0.1054\n",
      "Epoch [4/5], Loss: 0.0611\n",
      "Epoch [5/5], Loss: 0.0556\n",
      "Client 48 Private Data Validation Accuracy: 72.27%\n",
      "\n",
      "--- Client 49 Local Training with T=0.2984, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3472\n",
      "Epoch [2/5], Loss: 0.4243\n",
      "Epoch [3/5], Loss: 0.2019\n",
      "Epoch [4/5], Loss: 0.0726\n",
      "Epoch [5/5], Loss: 0.0381\n",
      "Client 49 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 60.76%\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 1.5\n",
      "##################################################\n",
      "\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.2493\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.4030\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.2678\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.4394\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.3153\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.3692\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.3292\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.3884\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.4243\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.2478\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.3235\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.2268\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.2660\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.3055\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.3162\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.3290\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.4422\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.3513\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.2359\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.4056\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.2703\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.3046\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.2842\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.4170\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.3502\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.3132\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.3272\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.2306\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.2387\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.3875\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.3721\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.2300\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.2666\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.3665\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.2777\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.3211\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.2318\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.3867\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.3685\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.2418\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.2739\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.2231\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.2910\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.2395\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.2031, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9513\n",
      "Epoch [2/5], Loss: 0.3792\n",
      "Epoch [3/5], Loss: 0.1307\n",
      "Epoch [4/5], Loss: 0.1080\n",
      "Epoch [5/5], Loss: 0.0591\n",
      "Client 0 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 1 Local Training with T=0.2014, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8996\n",
      "Epoch [2/5], Loss: 0.2216\n",
      "Epoch [3/5], Loss: 0.0610\n",
      "Epoch [4/5], Loss: 0.0238\n",
      "Epoch [5/5], Loss: 0.0309\n",
      "Client 1 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 2 Local Training with T=0.3455, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5372\n",
      "Epoch [2/5], Loss: 0.2089\n",
      "Epoch [3/5], Loss: 0.1082\n",
      "Epoch [4/5], Loss: 0.0693\n",
      "Epoch [5/5], Loss: 0.0475\n",
      "Client 2 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 3 Local Training with T=0.2417, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7188\n",
      "Epoch [2/5], Loss: 0.2307\n",
      "Epoch [3/5], Loss: 0.0748\n",
      "Epoch [4/5], Loss: 0.0557\n",
      "Epoch [5/5], Loss: 0.0221\n",
      "Client 3 Private Data Validation Accuracy: 75.52%\n",
      "Client 3 - decrease-temp to 0.229578\n",
      "\n",
      "--- Client 4 Local Training with T=0.3579, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6955\n",
      "Epoch [2/5], Loss: 0.2882\n",
      "Epoch [3/5], Loss: 0.1235\n",
      "Epoch [4/5], Loss: 0.0931\n",
      "Epoch [5/5], Loss: 0.0524\n",
      "Client 4 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 5 Local Training with T=0.2704, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9386\n",
      "Epoch [2/5], Loss: 0.2872\n",
      "Epoch [3/5], Loss: 0.1369\n",
      "Epoch [4/5], Loss: 0.0735\n",
      "Epoch [5/5], Loss: 0.0419\n",
      "Client 5 Private Data Validation Accuracy: 74.22%\n",
      "\n",
      "--- Client 6 Local Training with T=0.1727, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9896\n",
      "Epoch [2/5], Loss: 0.3938\n",
      "Epoch [3/5], Loss: 0.1714\n",
      "Epoch [4/5], Loss: 0.1207\n",
      "Epoch [5/5], Loss: 0.0389\n",
      "Client 6 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 7 Local Training with T=0.3166, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5412\n",
      "Epoch [2/5], Loss: 0.1164\n",
      "Epoch [3/5], Loss: 0.0633\n",
      "Epoch [4/5], Loss: 0.0352\n",
      "Epoch [5/5], Loss: 0.0228\n",
      "Client 7 Private Data Validation Accuracy: 82.81%\n",
      "\n",
      "--- Client 8 Local Training with T=0.3127, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5055\n",
      "Epoch [2/5], Loss: 0.0988\n",
      "Epoch [3/5], Loss: 0.0792\n",
      "Epoch [4/5], Loss: 0.0258\n",
      "Epoch [5/5], Loss: 0.0224\n",
      "Client 8 Private Data Validation Accuracy: 85.94%\n",
      "\n",
      "--- Client 9 Local Training with T=0.3330, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0000\n",
      "Epoch [2/5], Loss: 0.3780\n",
      "Epoch [3/5], Loss: 0.1987\n",
      "Epoch [4/5], Loss: 0.1360\n",
      "Epoch [5/5], Loss: 0.0771\n",
      "Client 9 Private Data Validation Accuracy: 58.59%\n",
      "\n",
      "--- Client 10 Local Training with T=0.3283, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0649\n",
      "Epoch [2/5], Loss: 0.5375\n",
      "Epoch [3/5], Loss: 0.2788\n",
      "Epoch [4/5], Loss: 0.1372\n",
      "Epoch [5/5], Loss: 0.0958\n",
      "Client 10 Private Data Validation Accuracy: 62.50%\n",
      "\n",
      "--- Client 11 Local Training with T=0.2124, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8618\n",
      "Epoch [2/5], Loss: 0.3736\n",
      "Epoch [3/5], Loss: 0.0795\n",
      "Epoch [4/5], Loss: 0.0448\n",
      "Epoch [5/5], Loss: 0.0209\n",
      "Client 11 Private Data Validation Accuracy: 74.61%\n",
      "Client 11 - decrease-temp to 0.201823\n",
      "\n",
      "--- Client 12 Local Training with T=0.2635, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6625\n",
      "Epoch [2/5], Loss: 0.1591\n",
      "Epoch [3/5], Loss: 0.0668\n",
      "Epoch [4/5], Loss: 0.0314\n",
      "Epoch [5/5], Loss: 0.0223\n",
      "Client 12 Private Data Validation Accuracy: 85.94%\n",
      "\n",
      "--- Client 13 Local Training with T=0.1848, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8773\n",
      "Epoch [2/5], Loss: 0.4106\n",
      "Epoch [3/5], Loss: 0.2188\n",
      "Epoch [4/5], Loss: 0.0474\n",
      "Epoch [5/5], Loss: 0.0406\n",
      "Client 13 Private Data Validation Accuracy: 77.60%\n",
      "\n",
      "--- Client 14 Local Training with T=0.2167, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0367\n",
      "Epoch [2/5], Loss: 0.2710\n",
      "Epoch [3/5], Loss: 0.1710\n",
      "Epoch [4/5], Loss: 0.0743\n",
      "Epoch [5/5], Loss: 0.0319\n",
      "Client 14 Private Data Validation Accuracy: 74.48%\n",
      "\n",
      "--- Client 15 Local Training with T=0.1817, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8686\n",
      "Epoch [2/5], Loss: 0.2915\n",
      "Epoch [3/5], Loss: 0.1371\n",
      "Epoch [4/5], Loss: 0.0791\n",
      "Epoch [5/5], Loss: 0.0318\n",
      "Client 15 Private Data Validation Accuracy: 74.61%\n",
      "\n",
      "--- Client 16 Local Training with T=0.2619, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8359\n",
      "Epoch [2/5], Loss: 0.3448\n",
      "Epoch [3/5], Loss: 0.1448\n",
      "Epoch [4/5], Loss: 0.0961\n",
      "Epoch [5/5], Loss: 0.0451\n",
      "Client 16 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 17 Local Training with T=0.2853, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9878\n",
      "Epoch [2/5], Loss: 0.3530\n",
      "Epoch [3/5], Loss: 0.1595\n",
      "Epoch [4/5], Loss: 0.0558\n",
      "Epoch [5/5], Loss: 0.0593\n",
      "Client 17 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 18 Local Training with T=0.2545, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7698\n",
      "Epoch [2/5], Loss: 0.2622\n",
      "Epoch [3/5], Loss: 0.1210\n",
      "Epoch [4/5], Loss: 0.0605\n",
      "Epoch [5/5], Loss: 0.0525\n",
      "Client 18 Private Data Validation Accuracy: 71.35%\n",
      "Client 18 - decrease-temp to 0.241812\n",
      "\n",
      "--- Client 19 Local Training with T=0.1913, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7921\n",
      "Epoch [2/5], Loss: 0.2918\n",
      "Epoch [3/5], Loss: 0.1144\n",
      "Epoch [4/5], Loss: 0.0586\n",
      "Epoch [5/5], Loss: 0.0368\n",
      "Client 19 Private Data Validation Accuracy: 75.78%\n",
      "\n",
      "--- Client 20 Local Training with T=0.3991, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5949\n",
      "Epoch [2/5], Loss: 0.2464\n",
      "Epoch [3/5], Loss: 0.1342\n",
      "Epoch [4/5], Loss: 0.0790\n",
      "Epoch [5/5], Loss: 0.0749\n",
      "Client 20 Private Data Validation Accuracy: 71.48%\n",
      "Client 20 - decrease-temp to 0.379146\n",
      "\n",
      "--- Client 21 Local Training with T=0.3338, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7350\n",
      "Epoch [2/5], Loss: 0.2763\n",
      "Epoch [3/5], Loss: 0.1960\n",
      "Epoch [4/5], Loss: 0.1068\n",
      "Epoch [5/5], Loss: 0.0673\n",
      "Client 21 Private Data Validation Accuracy: 68.75%\n",
      "Client 21 - decrease-temp to 0.317064\n",
      "\n",
      "--- Client 22 Local Training with T=0.2129, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7218\n",
      "Epoch [2/5], Loss: 0.1692\n",
      "Epoch [3/5], Loss: 0.0956\n",
      "Epoch [4/5], Loss: 0.0603\n",
      "Epoch [5/5], Loss: 0.0691\n",
      "Client 22 Private Data Validation Accuracy: 80.73%\n",
      "\n",
      "--- Client 23 Local Training with T=0.3138, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2166\n",
      "Epoch [2/5], Loss: 0.4713\n",
      "Epoch [3/5], Loss: 0.2051\n",
      "Epoch [4/5], Loss: 0.1390\n",
      "Epoch [5/5], Loss: 0.0832\n",
      "Client 23 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 24 Local Training with T=0.2318, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2914\n",
      "Epoch [2/5], Loss: 0.4919\n",
      "Epoch [3/5], Loss: 0.1803\n",
      "Epoch [4/5], Loss: 0.1428\n",
      "Epoch [5/5], Loss: 0.0863\n",
      "Client 24 Private Data Validation Accuracy: 63.02%\n",
      "\n",
      "--- Client 25 Local Training with T=0.2357, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6503\n",
      "Epoch [2/5], Loss: 0.3990\n",
      "Epoch [3/5], Loss: 0.2035\n",
      "Epoch [4/5], Loss: 0.1690\n",
      "Epoch [5/5], Loss: 0.0593\n",
      "Client 25 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 26 Local Training with T=0.2315, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5817\n",
      "Epoch [2/5], Loss: 0.1876\n",
      "Epoch [3/5], Loss: 0.0796\n",
      "Epoch [4/5], Loss: 0.0771\n",
      "Epoch [5/5], Loss: 0.0338\n",
      "Client 26 Private Data Validation Accuracy: 77.08%\n",
      "Client 26 - decrease-temp to 0.219880\n",
      "\n",
      "--- Client 27 Local Training with T=0.3396, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7625\n",
      "Epoch [2/5], Loss: 0.3273\n",
      "Epoch [3/5], Loss: 0.1849\n",
      "Epoch [4/5], Loss: 0.0895\n",
      "Epoch [5/5], Loss: 0.0765\n",
      "Client 27 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 28 Local Training with T=0.3160, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5624\n",
      "Epoch [2/5], Loss: 0.1434\n",
      "Epoch [3/5], Loss: 0.0698\n",
      "Epoch [4/5], Loss: 0.0448\n",
      "Epoch [5/5], Loss: 0.0273\n",
      "Client 28 Private Data Validation Accuracy: 83.33%\n",
      "\n",
      "--- Client 29 Local Training with T=0.2685, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5122\n",
      "Epoch [2/5], Loss: 0.2206\n",
      "Epoch [3/5], Loss: 0.0994\n",
      "Epoch [4/5], Loss: 0.0555\n",
      "Epoch [5/5], Loss: 0.0402\n",
      "Client 29 Private Data Validation Accuracy: 70.70%\n",
      "\n",
      "--- Client 30 Local Training with T=0.2806, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4654\n",
      "Epoch [2/5], Loss: 0.1780\n",
      "Epoch [3/5], Loss: 0.0940\n",
      "Epoch [4/5], Loss: 0.0666\n",
      "Epoch [5/5], Loss: 0.0401\n",
      "Client 30 Private Data Validation Accuracy: 72.50%\n",
      "\n",
      "--- Client 31 Local Training with T=0.1695, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.5497\n",
      "Epoch [2/5], Loss: 0.5485\n",
      "Epoch [3/5], Loss: 0.2926\n",
      "Epoch [4/5], Loss: 0.1322\n",
      "Epoch [5/5], Loss: 0.0540\n",
      "Client 31 Private Data Validation Accuracy: 76.56%\n",
      "Client 31 - decrease-temp to 0.161062\n",
      "\n",
      "--- Client 32 Local Training with T=0.1944, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1712\n",
      "Epoch [2/5], Loss: 0.4639\n",
      "Epoch [3/5], Loss: 0.1823\n",
      "Epoch [4/5], Loss: 0.0653\n",
      "Epoch [5/5], Loss: 0.0280\n",
      "Client 32 Private Data Validation Accuracy: 78.91%\n",
      "\n",
      "--- Client 33 Local Training with T=0.3156, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6729\n",
      "Epoch [2/5], Loss: 0.2272\n",
      "Epoch [3/5], Loss: 0.1057\n",
      "Epoch [4/5], Loss: 0.0736\n",
      "Epoch [5/5], Loss: 0.0404\n",
      "Client 33 Private Data Validation Accuracy: 69.53%\n",
      "\n",
      "--- Client 34 Local Training with T=0.3190, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5729\n",
      "Epoch [2/5], Loss: 0.1453\n",
      "Epoch [3/5], Loss: 0.0684\n",
      "Epoch [4/5], Loss: 0.0319\n",
      "Epoch [5/5], Loss: 0.0251\n",
      "Client 34 Private Data Validation Accuracy: 84.90%\n",
      "\n",
      "--- Client 35 Local Training with T=0.1972, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.5891\n",
      "Epoch [2/5], Loss: 0.4865\n",
      "Epoch [3/5], Loss: 0.1496\n",
      "Epoch [4/5], Loss: 0.0404\n",
      "Epoch [5/5], Loss: 0.0253\n",
      "Client 35 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 36 Local Training with T=0.2406, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8866\n",
      "Epoch [2/5], Loss: 0.3041\n",
      "Epoch [3/5], Loss: 0.0876\n",
      "Epoch [4/5], Loss: 0.0641\n",
      "Epoch [5/5], Loss: 0.0375\n",
      "Client 36 Private Data Validation Accuracy: 82.81%\n",
      "\n",
      "--- Client 37 Local Training with T=0.2120, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5844\n",
      "Epoch [2/5], Loss: 0.1988\n",
      "Epoch [3/5], Loss: 0.0619\n",
      "Epoch [4/5], Loss: 0.0328\n",
      "Epoch [5/5], Loss: 0.0220\n",
      "Client 37 Private Data Validation Accuracy: 87.50%\n",
      "\n",
      "--- Client 38 Local Training with T=0.3308, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8757\n",
      "Epoch [2/5], Loss: 0.3301\n",
      "Epoch [3/5], Loss: 0.1767\n",
      "Epoch [4/5], Loss: 0.0980\n",
      "Epoch [5/5], Loss: 0.0773\n",
      "Client 38 Private Data Validation Accuracy: 80.47%\n",
      "\n",
      "--- Client 39 Local Training with T=0.2149, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7014\n",
      "Epoch [2/5], Loss: 0.0491\n",
      "Epoch [3/5], Loss: 0.0166\n",
      "Epoch [4/5], Loss: 0.0086\n",
      "Epoch [5/5], Loss: 0.0169\n",
      "Client 39 Private Data Validation Accuracy: 94.79%\n",
      "\n",
      "--- Client 40 Local Training with T=0.1913, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2535\n",
      "Epoch [2/5], Loss: 0.6294\n",
      "Epoch [3/5], Loss: 0.2826\n",
      "Epoch [4/5], Loss: 0.1184\n",
      "Epoch [5/5], Loss: 0.0459\n",
      "Client 40 Private Data Validation Accuracy: 75.00%\n",
      "Client 40 - decrease-temp to 0.181741\n",
      "\n",
      "--- Client 41 Local Training with T=0.2898, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6679\n",
      "Epoch [2/5], Loss: 0.1988\n",
      "Epoch [3/5], Loss: 0.0812\n",
      "Epoch [4/5], Loss: 0.0767\n",
      "Epoch [5/5], Loss: 0.0512\n",
      "Client 41 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 42 Local Training with T=0.1987, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9205\n",
      "Epoch [2/5], Loss: 0.3769\n",
      "Epoch [3/5], Loss: 0.3432\n",
      "Epoch [4/5], Loss: 0.1470\n",
      "Epoch [5/5], Loss: 0.0545\n",
      "Client 42 Private Data Validation Accuracy: 69.27%\n",
      "\n",
      "--- Client 43 Local Training with T=0.3316, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3790\n",
      "Epoch [2/5], Loss: 0.6870\n",
      "Epoch [3/5], Loss: 0.2489\n",
      "Epoch [4/5], Loss: 0.1197\n",
      "Epoch [5/5], Loss: 0.0910\n",
      "Client 43 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 44 Local Training with T=0.3001, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0004\n",
      "Epoch [2/5], Loss: 0.3375\n",
      "Epoch [3/5], Loss: 0.1934\n",
      "Epoch [4/5], Loss: 0.1183\n",
      "Epoch [5/5], Loss: 0.0662\n",
      "Client 44 Private Data Validation Accuracy: 62.50%\n",
      "\n",
      "--- Client 45 Local Training with T=0.2074, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5684\n",
      "Epoch [2/5], Loss: 0.1999\n",
      "Epoch [3/5], Loss: 0.0883\n",
      "Epoch [4/5], Loss: 0.0471\n",
      "Epoch [5/5], Loss: 0.0345\n",
      "Client 45 Private Data Validation Accuracy: 77.73%\n",
      "\n",
      "--- Client 46 Local Training with T=0.2348, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8783\n",
      "Epoch [2/5], Loss: 0.2927\n",
      "Epoch [3/5], Loss: 0.1713\n",
      "Epoch [4/5], Loss: 0.0727\n",
      "Epoch [5/5], Loss: 0.0547\n",
      "Client 46 Private Data Validation Accuracy: 69.27%\n",
      "\n",
      "--- Client 47 Local Training with T=0.1913, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.5055\n",
      "Epoch [2/5], Loss: 0.2572\n",
      "Epoch [3/5], Loss: 0.0460\n",
      "Epoch [4/5], Loss: 0.0415\n",
      "Epoch [5/5], Loss: 0.0291\n",
      "Client 47 Private Data Validation Accuracy: 77.34%\n",
      "\n",
      "--- Client 48 Local Training with T=0.2252, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7922\n",
      "Epoch [2/5], Loss: 0.2117\n",
      "Epoch [3/5], Loss: 0.1091\n",
      "Epoch [4/5], Loss: 0.0577\n",
      "Epoch [5/5], Loss: 0.0456\n",
      "Client 48 Private Data Validation Accuracy: 75.00%\n",
      "\n",
      "--- Client 49 Local Training with T=0.1951, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3742\n",
      "Epoch [2/5], Loss: 0.2745\n",
      "Epoch [3/5], Loss: 0.2449\n",
      "Epoch [4/5], Loss: 0.0475\n",
      "Epoch [5/5], Loss: 0.0404\n",
      "Client 49 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 61.40%\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 2.0\n",
      "##################################################\n",
      "\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.1569\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.2977\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.1726\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.3340\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.2146\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.2649\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.2273\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.2834\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.3188\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.1556\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.2221\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.1383\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.1711\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.2057\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.2154\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.2271\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.3369\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.2479\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.1458\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.3002\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.1748\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.2050\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.1868\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.3115\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.2468\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.2127\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.2255\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.1414\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.1480\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.2825\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.2676\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.1410\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.1716\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.2623\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.1812\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.2199\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.1424\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.2817\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.2642\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.1507\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.1778\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.1928\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.1487\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.1416, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3913\n",
      "Epoch [2/5], Loss: 0.4184\n",
      "Epoch [3/5], Loss: 0.1506\n",
      "Epoch [4/5], Loss: 0.0799\n",
      "Epoch [5/5], Loss: 0.0700\n",
      "Client 0 Private Data Validation Accuracy: 69.14%\n",
      "\n",
      "--- Client 1 Local Training with T=0.0945, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.8295\n",
      "Epoch [2/5], Loss: 1.8731\n",
      "Epoch [3/5], Loss: 0.3578\n",
      "Epoch [4/5], Loss: 0.0912\n",
      "Epoch [5/5], Loss: 0.0598\n",
      "Client 1 Private Data Validation Accuracy: 71.88%\n",
      "Client 1 - decrease-temp to 0.089784\n",
      "\n",
      "--- Client 2 Local Training with T=0.2424, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5236\n",
      "Epoch [2/5], Loss: 0.1868\n",
      "Epoch [3/5], Loss: 0.1124\n",
      "Epoch [4/5], Loss: 0.0619\n",
      "Epoch [5/5], Loss: 0.0421\n",
      "Client 2 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 3 Local Training with T=0.1558, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9299\n",
      "Epoch [2/5], Loss: 0.3056\n",
      "Epoch [3/5], Loss: 0.1723\n",
      "Epoch [4/5], Loss: 0.0825\n",
      "Epoch [5/5], Loss: 0.0298\n",
      "Client 3 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 4 Local Training with T=0.2864, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6771\n",
      "Epoch [2/5], Loss: 0.2602\n",
      "Epoch [3/5], Loss: 0.1273\n",
      "Epoch [4/5], Loss: 0.0817\n",
      "Epoch [5/5], Loss: 0.0537\n",
      "Client 4 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 5 Local Training with T=0.2039, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0738\n",
      "Epoch [2/5], Loss: 0.2958\n",
      "Epoch [3/5], Loss: 0.1645\n",
      "Epoch [4/5], Loss: 0.0756\n",
      "Epoch [5/5], Loss: 0.0417\n",
      "Client 5 Private Data Validation Accuracy: 75.78%\n",
      "\n",
      "--- Client 6 Local Training with T=0.1102, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2863\n",
      "Epoch [2/5], Loss: 0.2491\n",
      "Epoch [3/5], Loss: 0.1846\n",
      "Epoch [4/5], Loss: 0.1434\n",
      "Epoch [5/5], Loss: 0.0574\n",
      "Client 6 Private Data Validation Accuracy: 70.70%\n",
      "\n",
      "--- Client 7 Local Training with T=0.2517, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5498\n",
      "Epoch [2/5], Loss: 0.1325\n",
      "Epoch [3/5], Loss: 0.0623\n",
      "Epoch [4/5], Loss: 0.0371\n",
      "Epoch [5/5], Loss: 0.0226\n",
      "Client 7 Private Data Validation Accuracy: 81.77%\n",
      "\n",
      "--- Client 8 Local Training with T=0.1949, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5094\n",
      "Epoch [2/5], Loss: 0.0924\n",
      "Epoch [3/5], Loss: 0.0940\n",
      "Epoch [4/5], Loss: 0.0186\n",
      "Epoch [5/5], Loss: 0.0157\n",
      "Client 8 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 9 Local Training with T=0.2430, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9281\n",
      "Epoch [2/5], Loss: 0.3941\n",
      "Epoch [3/5], Loss: 0.1876\n",
      "Epoch [4/5], Loss: 0.1445\n",
      "Epoch [5/5], Loss: 0.0759\n",
      "Client 9 Private Data Validation Accuracy: 55.47%\n",
      "\n",
      "--- Client 10 Local Training with T=0.2467, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1597\n",
      "Epoch [2/5], Loss: 0.5617\n",
      "Epoch [3/5], Loss: 0.2460\n",
      "Epoch [4/5], Loss: 0.1478\n",
      "Epoch [5/5], Loss: 0.0956\n",
      "Client 10 Private Data Validation Accuracy: 66.41%\n",
      "\n",
      "--- Client 11 Local Training with T=0.1334, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.7226\n",
      "Epoch [2/5], Loss: 0.6054\n",
      "Epoch [3/5], Loss: 0.2496\n",
      "Epoch [4/5], Loss: 0.1119\n",
      "Epoch [5/5], Loss: 0.0477\n",
      "Client 11 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 12 Local Training with T=0.2004, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7748\n",
      "Epoch [2/5], Loss: 0.1348\n",
      "Epoch [3/5], Loss: 0.0687\n",
      "Epoch [4/5], Loss: 0.0431\n",
      "Epoch [5/5], Loss: 0.0409\n",
      "Client 12 Private Data Validation Accuracy: 84.38%\n",
      "\n",
      "--- Client 13 Local Training with T=0.1070, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.1174\n",
      "Epoch [2/5], Loss: 0.7539\n",
      "Epoch [3/5], Loss: 0.2234\n",
      "Epoch [4/5], Loss: 0.0947\n",
      "Epoch [5/5], Loss: 0.1028\n",
      "Client 13 Private Data Validation Accuracy: 77.08%\n",
      "\n",
      "--- Client 14 Local Training with T=0.1625, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3665\n",
      "Epoch [2/5], Loss: 0.4950\n",
      "Epoch [3/5], Loss: 0.1752\n",
      "Epoch [4/5], Loss: 0.0916\n",
      "Epoch [5/5], Loss: 0.0763\n",
      "Client 14 Private Data Validation Accuracy: 75.52%\n",
      "\n",
      "--- Client 15 Local Training with T=0.1160, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3281\n",
      "Epoch [2/5], Loss: 0.2915\n",
      "Epoch [3/5], Loss: 0.1079\n",
      "Epoch [4/5], Loss: 0.0579\n",
      "Epoch [5/5], Loss: 0.0301\n",
      "Client 15 Private Data Validation Accuracy: 75.78%\n",
      "\n",
      "--- Client 16 Local Training with T=0.1764, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9149\n",
      "Epoch [2/5], Loss: 0.6045\n",
      "Epoch [3/5], Loss: 0.1242\n",
      "Epoch [4/5], Loss: 0.1000\n",
      "Epoch [5/5], Loss: 0.0460\n",
      "Client 16 Private Data Validation Accuracy: 82.81%\n",
      "\n",
      "--- Client 17 Local Training with T=0.1583, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1236\n",
      "Epoch [2/5], Loss: 0.5530\n",
      "Epoch [3/5], Loss: 0.1270\n",
      "Epoch [4/5], Loss: 0.0585\n",
      "Epoch [5/5], Loss: 0.0405\n",
      "Client 17 Private Data Validation Accuracy: 79.69%\n",
      "\n",
      "--- Client 18 Local Training with T=0.1850, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7365\n",
      "Epoch [2/5], Loss: 0.2993\n",
      "Epoch [3/5], Loss: 0.1131\n",
      "Epoch [4/5], Loss: 0.0778\n",
      "Epoch [5/5], Loss: 0.0737\n",
      "Client 18 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 19 Local Training with T=0.1102, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3625\n",
      "Epoch [2/5], Loss: 0.6668\n",
      "Epoch [3/5], Loss: 0.2382\n",
      "Epoch [4/5], Loss: 0.1302\n",
      "Epoch [5/5], Loss: 0.0555\n",
      "Client 19 Private Data Validation Accuracy: 78.91%\n",
      "\n",
      "--- Client 20 Local Training with T=0.2744, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6155\n",
      "Epoch [2/5], Loss: 0.2228\n",
      "Epoch [3/5], Loss: 0.1219\n",
      "Epoch [4/5], Loss: 0.0775\n",
      "Epoch [5/5], Loss: 0.0518\n",
      "Client 20 Private Data Validation Accuracy: 69.92%\n",
      "\n",
      "--- Client 21 Local Training with T=0.2125, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8085\n",
      "Epoch [2/5], Loss: 0.3169\n",
      "Epoch [3/5], Loss: 0.1762\n",
      "Epoch [4/5], Loss: 0.0893\n",
      "Epoch [5/5], Loss: 0.0526\n",
      "Client 21 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 22 Local Training with T=0.1187, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.9409\n",
      "Epoch [2/5], Loss: 1.4289\n",
      "Epoch [3/5], Loss: 0.3115\n",
      "Epoch [4/5], Loss: 0.1439\n",
      "Epoch [5/5], Loss: 0.1059\n",
      "Client 22 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 23 Local Training with T=0.2709, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1034\n",
      "Epoch [2/5], Loss: 0.4977\n",
      "Epoch [3/5], Loss: 0.2092\n",
      "Epoch [4/5], Loss: 0.1401\n",
      "Epoch [5/5], Loss: 0.1026\n",
      "Client 23 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 24 Local Training with T=0.1499, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6799\n",
      "Epoch [2/5], Loss: 1.4954\n",
      "Epoch [3/5], Loss: 0.3408\n",
      "Epoch [4/5], Loss: 0.2276\n",
      "Epoch [5/5], Loss: 0.1482\n",
      "Client 24 Private Data Validation Accuracy: 69.79%\n",
      "\n",
      "--- Client 25 Local Training with T=0.1670, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.0345\n",
      "Epoch [2/5], Loss: 0.5004\n",
      "Epoch [3/5], Loss: 0.2162\n",
      "Epoch [4/5], Loss: 0.0978\n",
      "Epoch [5/5], Loss: 0.0929\n",
      "Client 25 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 26 Local Training with T=0.1602, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5209\n",
      "Epoch [2/5], Loss: 0.1843\n",
      "Epoch [3/5], Loss: 0.0994\n",
      "Epoch [4/5], Loss: 0.1130\n",
      "Epoch [5/5], Loss: 0.0424\n",
      "Client 26 Private Data Validation Accuracy: 79.17%\n",
      "Client 26 - decrease-temp to 0.152166\n",
      "\n",
      "--- Client 27 Local Training with T=0.2671, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8175\n",
      "Epoch [2/5], Loss: 0.3070\n",
      "Epoch [3/5], Loss: 0.1644\n",
      "Epoch [4/5], Loss: 0.1002\n",
      "Epoch [5/5], Loss: 0.0769\n",
      "Client 27 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 28 Local Training with T=0.2345, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5079\n",
      "Epoch [2/5], Loss: 0.1281\n",
      "Epoch [3/5], Loss: 0.0599\n",
      "Epoch [4/5], Loss: 0.0329\n",
      "Epoch [5/5], Loss: 0.0256\n",
      "Client 28 Private Data Validation Accuracy: 82.29%\n",
      "\n",
      "--- Client 29 Local Training with T=0.1919, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5247\n",
      "Epoch [2/5], Loss: 0.2221\n",
      "Epoch [3/5], Loss: 0.1063\n",
      "Epoch [4/5], Loss: 0.0475\n",
      "Epoch [5/5], Loss: 0.0338\n",
      "Client 29 Private Data Validation Accuracy: 74.22%\n",
      "\n",
      "--- Client 30 Local Training with T=0.2035, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4732\n",
      "Epoch [2/5], Loss: 0.1679\n",
      "Epoch [3/5], Loss: 0.0936\n",
      "Epoch [4/5], Loss: 0.0416\n",
      "Epoch [5/5], Loss: 0.0339\n",
      "Client 30 Private Data Validation Accuracy: 71.56%\n",
      "\n",
      "--- Client 31 Local Training with T=0.1213, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6749\n",
      "Epoch [2/5], Loss: 0.9115\n",
      "Epoch [3/5], Loss: 0.2947\n",
      "Epoch [4/5], Loss: 0.2138\n",
      "Epoch [5/5], Loss: 0.0484\n",
      "Client 31 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 32 Local Training with T=0.1206, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.6264\n",
      "Epoch [2/5], Loss: 1.7023\n",
      "Epoch [3/5], Loss: 1.6177\n",
      "Epoch [4/5], Loss: 0.2238\n",
      "Epoch [5/5], Loss: 0.1065\n",
      "Client 32 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 33 Local Training with T=0.2186, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6770\n",
      "Epoch [2/5], Loss: 0.2391\n",
      "Epoch [3/5], Loss: 0.0977\n",
      "Epoch [4/5], Loss: 0.0606\n",
      "Epoch [5/5], Loss: 0.0321\n",
      "Client 33 Private Data Validation Accuracy: 67.58%\n",
      "\n",
      "--- Client 34 Local Training with T=0.2295, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6135\n",
      "Epoch [2/5], Loss: 0.1342\n",
      "Epoch [3/5], Loss: 0.0771\n",
      "Epoch [4/5], Loss: 0.0301\n",
      "Epoch [5/5], Loss: 0.0244\n",
      "Client 34 Private Data Validation Accuracy: 82.81%\n",
      "\n",
      "--- Client 35 Local Training with T=0.1339, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6543\n",
      "Epoch [2/5], Loss: 0.5314\n",
      "Epoch [3/5], Loss: 0.1718\n",
      "Epoch [4/5], Loss: 0.0647\n",
      "Epoch [5/5], Loss: 0.0710\n",
      "Client 35 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 36 Local Training with T=0.1328, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6661\n",
      "Epoch [2/5], Loss: 0.6035\n",
      "Epoch [3/5], Loss: 0.1149\n",
      "Epoch [4/5], Loss: 0.0776\n",
      "Epoch [5/5], Loss: 0.1064\n",
      "Client 36 Private Data Validation Accuracy: 69.53%\n",
      "\n",
      "--- Client 37 Local Training with T=0.1286, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8295\n",
      "Epoch [2/5], Loss: 0.2492\n",
      "Epoch [3/5], Loss: 0.0960\n",
      "Epoch [4/5], Loss: 0.0386\n",
      "Epoch [5/5], Loss: 0.0439\n",
      "Client 37 Private Data Validation Accuracy: 86.46%\n",
      "\n",
      "--- Client 38 Local Training with T=0.2030, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1318\n",
      "Epoch [2/5], Loss: 0.4576\n",
      "Epoch [3/5], Loss: 0.1852\n",
      "Epoch [4/5], Loss: 0.0871\n",
      "Epoch [5/5], Loss: 0.0604\n",
      "Client 38 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 39 Local Training with T=0.1476, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2788\n",
      "Epoch [2/5], Loss: 0.0947\n",
      "Epoch [3/5], Loss: 0.0273\n",
      "Epoch [4/5], Loss: 0.0086\n",
      "Epoch [5/5], Loss: 0.0587\n",
      "Client 39 Private Data Validation Accuracy: 93.75%\n",
      "\n",
      "--- Client 40 Local Training with T=0.1160, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.8325\n",
      "Epoch [2/5], Loss: 0.6658\n",
      "Epoch [3/5], Loss: 0.3258\n",
      "Epoch [4/5], Loss: 0.2033\n",
      "Epoch [5/5], Loss: 0.1407\n",
      "Client 40 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 41 Local Training with T=0.1885, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7528\n",
      "Epoch [2/5], Loss: 0.2182\n",
      "Epoch [3/5], Loss: 0.1035\n",
      "Epoch [4/5], Loss: 0.0784\n",
      "Epoch [5/5], Loss: 0.0534\n",
      "Client 41 Private Data Validation Accuracy: 67.71%\n",
      "\n",
      "--- Client 42 Local Training with T=0.1160, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4837\n",
      "Epoch [2/5], Loss: 2.7336\n",
      "Epoch [3/5], Loss: 1.7218\n",
      "Epoch [4/5], Loss: 0.4082\n",
      "Epoch [5/5], Loss: 0.1548\n",
      "Client 42 Private Data Validation Accuracy: 69.79%\n",
      "\n",
      "--- Client 43 Local Training with T=0.2416, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2207\n",
      "Epoch [2/5], Loss: 0.6204\n",
      "Epoch [3/5], Loss: 0.2836\n",
      "Epoch [4/5], Loss: 0.1336\n",
      "Epoch [5/5], Loss: 0.0935\n",
      "Client 43 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 44 Local Training with T=0.2265, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9576\n",
      "Epoch [2/5], Loss: 0.4141\n",
      "Epoch [3/5], Loss: 0.2078\n",
      "Epoch [4/5], Loss: 0.1179\n",
      "Epoch [5/5], Loss: 0.0690\n",
      "Client 44 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 45 Local Training with T=0.1227, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0692\n",
      "Epoch [2/5], Loss: 0.2695\n",
      "Epoch [3/5], Loss: 0.1576\n",
      "Epoch [4/5], Loss: 0.0627\n",
      "Epoch [5/5], Loss: 0.0327\n",
      "Client 45 Private Data Validation Accuracy: 73.05%\n",
      "\n",
      "--- Client 46 Local Training with T=0.1449, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8867\n",
      "Epoch [2/5], Loss: 0.4374\n",
      "Epoch [3/5], Loss: 0.1821\n",
      "Epoch [4/5], Loss: 0.1981\n",
      "Epoch [5/5], Loss: 0.0567\n",
      "Client 46 Private Data Validation Accuracy: 65.10%\n",
      "\n",
      "--- Client 47 Local Training with T=0.1221, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.8745\n",
      "Epoch [2/5], Loss: 0.5245\n",
      "Epoch [3/5], Loss: 0.1150\n",
      "Epoch [4/5], Loss: 0.0527\n",
      "Epoch [5/5], Loss: 0.0338\n",
      "Client 47 Private Data Validation Accuracy: 75.78%\n",
      "\n",
      "--- Client 48 Local Training with T=0.1653, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0048\n",
      "Epoch [2/5], Loss: 0.2883\n",
      "Epoch [3/5], Loss: 0.1050\n",
      "Epoch [4/5], Loss: 0.0551\n",
      "Epoch [5/5], Loss: 0.0357\n",
      "Client 48 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 49 Local Training with T=0.1211, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.9977\n",
      "Epoch [2/5], Loss: 0.5427\n",
      "Epoch [3/5], Loss: 0.3057\n",
      "Epoch [4/5], Loss: 0.0758\n",
      "Epoch [5/5], Loss: 0.0204\n",
      "Client 49 Private Data Validation Accuracy: 68.75%\n",
      "Client 49 - decrease-temp to 0.115079\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 62.70%\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 2.5\n",
      "##################################################\n",
      "\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.0988\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.2199\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.1112\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.2539\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.1461\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.1900\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.1569\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.2068\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.2396\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.0978\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.1525\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.0844\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.1100\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.1386\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.1467\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.1568\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.2567\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.1749\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.0901\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.2222\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.1130\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.1379\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.1228\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.2327\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.1740\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.1444\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.1554\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.0867\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.0918\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.2060\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.1925\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.0864\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.1104\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.1877\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.1182\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.1506\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.0875\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.2053\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.1894\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.0939\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.1155\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.0821\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.1278\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.0924\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.0847, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.8644\n",
      "Epoch [2/5], Loss: 0.5249\n",
      "Epoch [3/5], Loss: 0.2552\n",
      "Epoch [4/5], Loss: 0.2327\n",
      "Epoch [5/5], Loss: 0.1474\n",
      "Client 0 Private Data Validation Accuracy: 70.31%\n",
      "Client 0 - decrease-temp to 0.080454\n",
      "\n",
      "--- Client 1 Local Training with T=0.0741, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6809\n",
      "Epoch [2/5], Loss: 0.4032\n",
      "Epoch [3/5], Loss: 0.1823\n",
      "Epoch [4/5], Loss: 0.1241\n",
      "Epoch [5/5], Loss: 0.0865\n",
      "Client 1 Private Data Validation Accuracy: 79.17%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1984, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6717\n",
      "Epoch [2/5], Loss: 0.2651\n",
      "Epoch [3/5], Loss: 0.1521\n",
      "Epoch [4/5], Loss: 0.0962\n",
      "Epoch [5/5], Loss: 0.0452\n",
      "Client 2 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 3 Local Training with T=0.0954, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1896\n",
      "Epoch [2/5], Loss: 0.5390\n",
      "Epoch [3/5], Loss: 0.2905\n",
      "Epoch [4/5], Loss: 0.1437\n",
      "Epoch [5/5], Loss: 0.1336\n",
      "Client 3 Private Data Validation Accuracy: 77.08%\n",
      "\n",
      "--- Client 4 Local Training with T=0.2068, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7269\n",
      "Epoch [2/5], Loss: 0.3432\n",
      "Epoch [3/5], Loss: 0.1296\n",
      "Epoch [4/5], Loss: 0.0826\n",
      "Epoch [5/5], Loss: 0.0680\n",
      "Client 4 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 5 Local Training with T=0.1190, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1680\n",
      "Epoch [2/5], Loss: 0.3393\n",
      "Epoch [3/5], Loss: 0.2182\n",
      "Epoch [4/5], Loss: 0.1274\n",
      "Epoch [5/5], Loss: 0.0887\n",
      "Client 5 Private Data Validation Accuracy: 74.22%\n",
      "\n",
      "--- Client 6 Local Training with T=0.0741, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6677\n",
      "Epoch [2/5], Loss: 0.4005\n",
      "Epoch [3/5], Loss: 0.2673\n",
      "Epoch [4/5], Loss: 0.1900\n",
      "Epoch [5/5], Loss: 0.0840\n",
      "Client 6 Private Data Validation Accuracy: 76.17%\n",
      "\n",
      "--- Client 7 Local Training with T=0.1715, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5618\n",
      "Epoch [2/5], Loss: 0.1761\n",
      "Epoch [3/5], Loss: 0.0707\n",
      "Epoch [4/5], Loss: 0.0381\n",
      "Epoch [5/5], Loss: 0.0274\n",
      "Client 7 Private Data Validation Accuracy: 86.46%\n",
      "\n",
      "--- Client 8 Local Training with T=0.1278, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4648\n",
      "Epoch [2/5], Loss: 0.1428\n",
      "Epoch [3/5], Loss: 0.0847\n",
      "Epoch [4/5], Loss: 0.0302\n",
      "Epoch [5/5], Loss: 0.0377\n",
      "Client 8 Private Data Validation Accuracy: 82.81%\n",
      "\n",
      "--- Client 9 Local Training with T=0.1773, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0567\n",
      "Epoch [2/5], Loss: 0.4719\n",
      "Epoch [3/5], Loss: 0.2545\n",
      "Epoch [4/5], Loss: 0.1433\n",
      "Epoch [5/5], Loss: 0.0847\n",
      "Client 9 Private Data Validation Accuracy: 55.47%\n",
      "\n",
      "--- Client 10 Local Training with T=0.2162, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1018\n",
      "Epoch [2/5], Loss: 0.6615\n",
      "Epoch [3/5], Loss: 0.3344\n",
      "Epoch [4/5], Loss: 0.2036\n",
      "Epoch [5/5], Loss: 0.1455\n",
      "Client 10 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Client 11 Local Training with T=0.0838, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.4890\n",
      "Epoch [2/5], Loss: 0.8652\n",
      "Epoch [3/5], Loss: 0.3460\n",
      "Epoch [4/5], Loss: 0.2329\n",
      "Epoch [5/5], Loss: 0.1019\n",
      "Client 11 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 12 Local Training with T=0.1180, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8003\n",
      "Epoch [2/5], Loss: 0.1972\n",
      "Epoch [3/5], Loss: 0.1109\n",
      "Epoch [4/5], Loss: 0.0591\n",
      "Epoch [5/5], Loss: 0.0831\n",
      "Client 12 Private Data Validation Accuracy: 77.08%\n",
      "\n",
      "--- Client 13 Local Training with T=0.0801, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1100\n",
      "Epoch [2/5], Loss: 0.4508\n",
      "Epoch [3/5], Loss: 0.1597\n",
      "Epoch [4/5], Loss: 0.1028\n",
      "Epoch [5/5], Loss: 0.0682\n",
      "Client 13 Private Data Validation Accuracy: 77.08%\n",
      "\n",
      "--- Client 14 Local Training with T=0.0943, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.8126\n",
      "Epoch [2/5], Loss: 0.6717\n",
      "Epoch [3/5], Loss: 0.3224\n",
      "Epoch [4/5], Loss: 0.2150\n",
      "Epoch [5/5], Loss: 0.1534\n",
      "Client 14 Private Data Validation Accuracy: 72.92%\n",
      "\n",
      "--- Client 15 Local Training with T=0.0704, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0840\n",
      "Epoch [2/5], Loss: 0.3382\n",
      "Epoch [3/5], Loss: 0.2717\n",
      "Epoch [4/5], Loss: 0.2273\n",
      "Epoch [5/5], Loss: 0.1560\n",
      "Client 15 Private Data Validation Accuracy: 65.23%\n",
      "Client 15 - decrease-temp to 0.066859\n",
      "\n",
      "--- Client 16 Local Training with T=0.1072, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8807\n",
      "Epoch [2/5], Loss: 0.5242\n",
      "Epoch [3/5], Loss: 0.1729\n",
      "Epoch [4/5], Loss: 0.1284\n",
      "Epoch [5/5], Loss: 0.1514\n",
      "Client 16 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 17 Local Training with T=0.1258, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0480\n",
      "Epoch [2/5], Loss: 0.3625\n",
      "Epoch [3/5], Loss: 0.2300\n",
      "Epoch [4/5], Loss: 0.1365\n",
      "Epoch [5/5], Loss: 0.0580\n",
      "Client 17 Private Data Validation Accuracy: 76.56%\n",
      "Client 17 - decrease-temp to 0.119518\n",
      "\n",
      "--- Client 18 Local Training with T=0.1213, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8312\n",
      "Epoch [2/5], Loss: 0.3890\n",
      "Epoch [3/5], Loss: 0.3036\n",
      "Epoch [4/5], Loss: 0.1433\n",
      "Epoch [5/5], Loss: 0.1113\n",
      "Client 18 Private Data Validation Accuracy: 66.15%\n",
      "\n",
      "--- Client 19 Local Training with T=0.0669, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6831\n",
      "Epoch [2/5], Loss: 0.8292\n",
      "Epoch [3/5], Loss: 0.4707\n",
      "Epoch [4/5], Loss: 0.2350\n",
      "Epoch [5/5], Loss: 0.0944\n",
      "Client 19 Private Data Validation Accuracy: 73.83%\n",
      "\n",
      "--- Client 20 Local Training with T=0.2317, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7210\n",
      "Epoch [2/5], Loss: 0.2849\n",
      "Epoch [3/5], Loss: 0.1632\n",
      "Epoch [4/5], Loss: 0.0944\n",
      "Epoch [5/5], Loss: 0.0700\n",
      "Client 20 Private Data Validation Accuracy: 70.70%\n",
      "\n",
      "--- Client 21 Local Training with T=0.1500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8066\n",
      "Epoch [2/5], Loss: 0.4307\n",
      "Epoch [3/5], Loss: 0.2710\n",
      "Epoch [4/5], Loss: 0.1538\n",
      "Epoch [5/5], Loss: 0.0630\n",
      "Client 21 Private Data Validation Accuracy: 67.71%\n",
      "Client 21 - decrease-temp to 0.142471\n",
      "\n",
      "--- Client 22 Local Training with T=0.0734, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 4.0129\n",
      "Epoch [2/5], Loss: 0.8012\n",
      "Epoch [3/5], Loss: 0.3440\n",
      "Epoch [4/5], Loss: 0.3458\n",
      "Epoch [5/5], Loss: 0.2230\n",
      "Client 22 Private Data Validation Accuracy: 75.52%\n",
      "Client 22 - decrease-temp to 0.069697\n",
      "\n",
      "--- Client 23 Local Training with T=0.1810, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1991\n",
      "Epoch [2/5], Loss: 0.6661\n",
      "Epoch [3/5], Loss: 0.3355\n",
      "Epoch [4/5], Loss: 0.2228\n",
      "Epoch [5/5], Loss: 0.1271\n",
      "Client 23 Private Data Validation Accuracy: 57.81%\n",
      "\n",
      "--- Client 24 Local Training with T=0.0969, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 3.6211\n",
      "Epoch [2/5], Loss: 1.8185\n",
      "Epoch [3/5], Loss: 0.5877\n",
      "Epoch [4/5], Loss: 0.3826\n",
      "Epoch [5/5], Loss: 0.3687\n",
      "Client 24 Private Data Validation Accuracy: 69.27%\n",
      "\n",
      "--- Client 25 Local Training with T=0.1245, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6571\n",
      "Epoch [2/5], Loss: 0.6523\n",
      "Epoch [3/5], Loss: 0.3103\n",
      "Epoch [4/5], Loss: 0.2145\n",
      "Epoch [5/5], Loss: 0.0989\n",
      "Client 25 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 26 Local Training with T=0.1053, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7589\n",
      "Epoch [2/5], Loss: 0.3127\n",
      "Epoch [3/5], Loss: 0.1656\n",
      "Epoch [4/5], Loss: 0.1127\n",
      "Epoch [5/5], Loss: 0.0755\n",
      "Client 26 Private Data Validation Accuracy: 80.21%\n",
      "Client 26 - decrease-temp to 0.100040\n",
      "\n",
      "--- Client 27 Local Training with T=0.2211, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8601\n",
      "Epoch [2/5], Loss: 0.3994\n",
      "Epoch [3/5], Loss: 0.1989\n",
      "Epoch [4/5], Loss: 0.1118\n",
      "Epoch [5/5], Loss: 0.0827\n",
      "Client 27 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 28 Local Training with T=0.1653, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6343\n",
      "Epoch [2/5], Loss: 0.1773\n",
      "Epoch [3/5], Loss: 0.1046\n",
      "Epoch [4/5], Loss: 0.0540\n",
      "Epoch [5/5], Loss: 0.0339\n",
      "Client 28 Private Data Validation Accuracy: 83.85%\n",
      "\n",
      "--- Client 29 Local Training with T=0.1176, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6450\n",
      "Epoch [2/5], Loss: 0.3377\n",
      "Epoch [3/5], Loss: 0.1613\n",
      "Epoch [4/5], Loss: 0.0833\n",
      "Epoch [5/5], Loss: 0.0591\n",
      "Client 29 Private Data Validation Accuracy: 74.61%\n",
      "\n",
      "--- Client 30 Local Training with T=0.1266, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6305\n",
      "Epoch [2/5], Loss: 0.2835\n",
      "Epoch [3/5], Loss: 0.1215\n",
      "Epoch [4/5], Loss: 0.1366\n",
      "Epoch [5/5], Loss: 0.0841\n",
      "Client 30 Private Data Validation Accuracy: 71.56%\n",
      "\n",
      "--- Client 31 Local Training with T=0.0783, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3163\n",
      "Epoch [2/5], Loss: 0.8011\n",
      "Epoch [3/5], Loss: 0.2643\n",
      "Epoch [4/5], Loss: 0.2349\n",
      "Epoch [5/5], Loss: 0.0732\n",
      "Client 31 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 32 Local Training with T=0.0748, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 3.2506\n",
      "Epoch [2/5], Loss: 1.3213\n",
      "Epoch [3/5], Loss: 0.4326\n",
      "Epoch [4/5], Loss: 0.1662\n",
      "Epoch [5/5], Loss: 0.0911\n",
      "Client 32 Private Data Validation Accuracy: 72.66%\n",
      "Client 32 - decrease-temp to 0.071058\n",
      "\n",
      "--- Client 33 Local Training with T=0.1766, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6730\n",
      "Epoch [2/5], Loss: 0.2662\n",
      "Epoch [3/5], Loss: 0.1549\n",
      "Epoch [4/5], Loss: 0.0841\n",
      "Epoch [5/5], Loss: 0.0629\n",
      "Client 33 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 34 Local Training with T=0.1650, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5558\n",
      "Epoch [2/5], Loss: 0.1803\n",
      "Epoch [3/5], Loss: 0.0897\n",
      "Epoch [4/5], Loss: 0.0495\n",
      "Epoch [5/5], Loss: 0.0514\n",
      "Client 34 Private Data Validation Accuracy: 83.85%\n",
      "Client 34 - decrease-temp to 0.156788\n",
      "\n",
      "--- Client 35 Local Training with T=0.0740, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.4462\n",
      "Epoch [2/5], Loss: 1.0861\n",
      "Epoch [3/5], Loss: 0.6926\n",
      "Epoch [4/5], Loss: 0.2350\n",
      "Epoch [5/5], Loss: 0.0999\n",
      "Client 35 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 36 Local Training with T=0.0899, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0979\n",
      "Epoch [2/5], Loss: 0.5330\n",
      "Epoch [3/5], Loss: 0.1821\n",
      "Epoch [4/5], Loss: 0.1004\n",
      "Epoch [5/5], Loss: 0.0874\n",
      "Client 36 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 37 Local Training with T=0.0669, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0558\n",
      "Epoch [2/5], Loss: 1.2814\n",
      "Epoch [3/5], Loss: 0.4420\n",
      "Epoch [4/5], Loss: 0.1409\n",
      "Epoch [5/5], Loss: 0.1121\n",
      "Client 37 Private Data Validation Accuracy: 88.54%\n",
      "\n",
      "--- Client 38 Local Training with T=0.1610, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9703\n",
      "Epoch [2/5], Loss: 0.6180\n",
      "Epoch [3/5], Loss: 0.2519\n",
      "Epoch [4/5], Loss: 0.1353\n",
      "Epoch [5/5], Loss: 0.0601\n",
      "Client 38 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 39 Local Training with T=0.1014, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9062\n",
      "Epoch [2/5], Loss: 0.0832\n",
      "Epoch [3/5], Loss: 0.0520\n",
      "Epoch [4/5], Loss: 0.0310\n",
      "Epoch [5/5], Loss: 0.0376\n",
      "Client 39 Private Data Validation Accuracy: 90.10%\n",
      "\n",
      "--- Client 40 Local Training with T=0.0704, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 3.0696\n",
      "Epoch [2/5], Loss: 0.7927\n",
      "Epoch [3/5], Loss: 0.6513\n",
      "Epoch [4/5], Loss: 0.2849\n",
      "Epoch [5/5], Loss: 0.1729\n",
      "Client 40 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 41 Local Training with T=0.1226, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6727\n",
      "Epoch [2/5], Loss: 0.4431\n",
      "Epoch [3/5], Loss: 0.1670\n",
      "Epoch [4/5], Loss: 0.1269\n",
      "Epoch [5/5], Loss: 0.0447\n",
      "Client 41 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 42 Local Training with T=0.0789, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.9292\n",
      "Epoch [2/5], Loss: 0.7525\n",
      "Epoch [3/5], Loss: 0.6492\n",
      "Epoch [4/5], Loss: 0.3441\n",
      "Epoch [5/5], Loss: 0.1991\n",
      "Client 42 Private Data Validation Accuracy: 72.40%\n",
      "\n",
      "--- Client 43 Local Training with T=0.1760, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3030\n",
      "Epoch [2/5], Loss: 0.6860\n",
      "Epoch [3/5], Loss: 0.5002\n",
      "Epoch [4/5], Loss: 0.2650\n",
      "Epoch [5/5], Loss: 0.1654\n",
      "Client 43 Private Data Validation Accuracy: 62.50%\n",
      "\n",
      "--- Client 44 Local Training with T=0.1624, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9613\n",
      "Epoch [2/5], Loss: 0.4058\n",
      "Epoch [3/5], Loss: 0.2649\n",
      "Epoch [4/5], Loss: 0.1952\n",
      "Epoch [5/5], Loss: 0.1149\n",
      "Client 44 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Client 45 Local Training with T=0.0847, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0122\n",
      "Epoch [2/5], Loss: 0.3278\n",
      "Epoch [3/5], Loss: 0.1586\n",
      "Epoch [4/5], Loss: 0.0981\n",
      "Epoch [5/5], Loss: 0.0692\n",
      "Client 45 Private Data Validation Accuracy: 78.52%\n",
      "\n",
      "--- Client 46 Local Training with T=0.0941, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6758\n",
      "Epoch [2/5], Loss: 0.6755\n",
      "Epoch [3/5], Loss: 0.2636\n",
      "Epoch [4/5], Loss: 0.2538\n",
      "Epoch [5/5], Loss: 0.1239\n",
      "Client 46 Private Data Validation Accuracy: 72.40%\n",
      "\n",
      "--- Client 47 Local Training with T=0.0669, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 6.0252\n",
      "Epoch [2/5], Loss: 1.0584\n",
      "Epoch [3/5], Loss: 0.4691\n",
      "Epoch [4/5], Loss: 0.4021\n",
      "Epoch [5/5], Loss: 0.2980\n",
      "Client 47 Private Data Validation Accuracy: 71.09%\n",
      "\n",
      "--- Client 48 Local Training with T=0.1041, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6684\n",
      "Epoch [2/5], Loss: 0.3203\n",
      "Epoch [3/5], Loss: 0.2406\n",
      "Epoch [4/5], Loss: 0.1061\n",
      "Epoch [5/5], Loss: 0.1129\n",
      "Client 48 Private Data Validation Accuracy: 69.53%\n",
      "Client 48 - decrease-temp to 0.098888\n",
      "\n",
      "--- Client 49 Local Training with T=0.0834, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.8750\n",
      "Epoch [2/5], Loss: 1.0415\n",
      "Epoch [3/5], Loss: 0.3125\n",
      "Epoch [4/5], Loss: 0.1075\n",
      "Epoch [5/5], Loss: 0.0542\n",
      "Client 49 Private Data Validation Accuracy: 79.69%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 61.11%\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 3.0\n",
      "##################################################\n",
      "\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.0622\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.1624\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.0717\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.1931\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.0994\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.1363\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.1084\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.1509\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.1800\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.0614\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.1047\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.0515\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.0708\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.0933\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.1000\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.1082\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.1956\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.1234\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.0557\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.1645\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.0731\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.0928\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.0807\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.1739\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.1226\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.0981\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.1071\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.0532\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.0570\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.1502\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.1385\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.0529\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.0711\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.1344\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.0771\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.1031\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.0537\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.1495\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.1358\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.0585\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.0750\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.0847\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.0574\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.0533, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.7047\n",
      "Epoch [2/5], Loss: 0.6112\n",
      "Epoch [3/5], Loss: 0.3294\n",
      "Epoch [4/5], Loss: 0.1785\n",
      "Epoch [5/5], Loss: 0.1514\n",
      "Client 0 Private Data Validation Accuracy: 71.48%\n",
      "\n",
      "--- Client 1 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1925\n",
      "Epoch [2/5], Loss: 0.3057\n",
      "Epoch [3/5], Loss: 0.1953\n",
      "Epoch [4/5], Loss: 0.2356\n",
      "Epoch [5/5], Loss: 0.1349\n",
      "Client 1 Private Data Validation Accuracy: 80.73%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1257, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6585\n",
      "Epoch [2/5], Loss: 0.3315\n",
      "Epoch [3/5], Loss: 0.2234\n",
      "Epoch [4/5], Loss: 0.2217\n",
      "Epoch [5/5], Loss: 0.1119\n",
      "Client 2 Private Data Validation Accuracy: 75.52%\n",
      "\n",
      "--- Client 3 Local Training with T=0.0615, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9127\n",
      "Epoch [2/5], Loss: 0.4382\n",
      "Epoch [3/5], Loss: 0.2819\n",
      "Epoch [4/5], Loss: 0.2354\n",
      "Epoch [5/5], Loss: 0.1613\n",
      "Client 3 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 4 Local Training with T=0.1655, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8702\n",
      "Epoch [2/5], Loss: 0.4685\n",
      "Epoch [3/5], Loss: 0.2699\n",
      "Epoch [4/5], Loss: 0.1794\n",
      "Epoch [5/5], Loss: 0.0993\n",
      "Client 4 Private Data Validation Accuracy: 68.23%\n",
      "\n",
      "--- Client 5 Local Training with T=0.0853, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0395\n",
      "Epoch [2/5], Loss: 0.4400\n",
      "Epoch [3/5], Loss: 0.3246\n",
      "Epoch [4/5], Loss: 0.2340\n",
      "Epoch [5/5], Loss: 0.1424\n",
      "Client 5 Private Data Validation Accuracy: 72.66%\n",
      "\n",
      "--- Client 6 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3820\n",
      "Epoch [2/5], Loss: 0.4943\n",
      "Epoch [3/5], Loss: 0.2899\n",
      "Epoch [4/5], Loss: 0.2468\n",
      "Epoch [5/5], Loss: 0.1895\n",
      "Client 6 Private Data Validation Accuracy: 71.09%\n",
      "\n",
      "--- Client 7 Local Training with T=0.1111, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6005\n",
      "Epoch [2/5], Loss: 0.1918\n",
      "Epoch [3/5], Loss: 0.1079\n",
      "Epoch [4/5], Loss: 0.0768\n",
      "Epoch [5/5], Loss: 0.0445\n",
      "Client 7 Private Data Validation Accuracy: 80.73%\n",
      "\n",
      "--- Client 8 Local Training with T=0.0978, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4905\n",
      "Epoch [2/5], Loss: 0.1731\n",
      "Epoch [3/5], Loss: 0.0969\n",
      "Epoch [4/5], Loss: 0.0489\n",
      "Epoch [5/5], Loss: 0.0370\n",
      "Client 8 Private Data Validation Accuracy: 85.94%\n",
      "\n",
      "--- Client 9 Local Training with T=0.1293, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1764\n",
      "Epoch [2/5], Loss: 0.6674\n",
      "Epoch [3/5], Loss: 0.3982\n",
      "Epoch [4/5], Loss: 0.2078\n",
      "Epoch [5/5], Loss: 0.1865\n",
      "Client 9 Private Data Validation Accuracy: 50.78%\n",
      "Client 9 - decrease-temp to 0.122878\n",
      "\n",
      "--- Client 10 Local Training with T=0.1800, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1488\n",
      "Epoch [2/5], Loss: 0.7365\n",
      "Epoch [3/5], Loss: 0.4389\n",
      "Epoch [4/5], Loss: 0.2896\n",
      "Epoch [5/5], Loss: 0.1840\n",
      "Client 10 Private Data Validation Accuracy: 63.28%\n",
      "\n",
      "--- Client 11 Local Training with T=0.0526, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.0795\n",
      "Epoch [2/5], Loss: 0.4893\n",
      "Epoch [3/5], Loss: 0.2624\n",
      "Epoch [4/5], Loss: 0.2301\n",
      "Epoch [5/5], Loss: 0.2626\n",
      "Client 11 Private Data Validation Accuracy: 75.78%\n",
      "\n",
      "--- Client 12 Local Training with T=0.0810, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6892\n",
      "Epoch [2/5], Loss: 0.2317\n",
      "Epoch [3/5], Loss: 0.1016\n",
      "Epoch [4/5], Loss: 0.0914\n",
      "Epoch [5/5], Loss: 0.0577\n",
      "Client 12 Private Data Validation Accuracy: 80.73%\n",
      "\n",
      "--- Client 13 Local Training with T=0.0515, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3263\n",
      "Epoch [2/5], Loss: 0.4269\n",
      "Epoch [3/5], Loss: 0.2072\n",
      "Epoch [4/5], Loss: 0.1144\n",
      "Epoch [5/5], Loss: 0.1082\n",
      "Client 13 Private Data Validation Accuracy: 80.73%\n",
      "\n",
      "--- Client 14 Local Training with T=0.0607, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 5.0168\n",
      "Epoch [2/5], Loss: 1.5362\n",
      "Epoch [3/5], Loss: 1.1814\n",
      "Epoch [4/5], Loss: 0.6274\n",
      "Epoch [5/5], Loss: 0.4734\n",
      "Client 14 Private Data Validation Accuracy: 71.35%\n",
      "\n",
      "--- Client 15 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0777\n",
      "Epoch [2/5], Loss: 0.3947\n",
      "Epoch [3/5], Loss: 0.2905\n",
      "Epoch [4/5], Loss: 0.2069\n",
      "Epoch [5/5], Loss: 0.1317\n",
      "Client 15 Private Data Validation Accuracy: 72.27%\n",
      "\n",
      "--- Client 16 Local Training with T=0.0760, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9923\n",
      "Epoch [2/5], Loss: 0.4481\n",
      "Epoch [3/5], Loss: 0.2448\n",
      "Epoch [4/5], Loss: 0.1998\n",
      "Epoch [5/5], Loss: 0.1132\n",
      "Client 16 Private Data Validation Accuracy: 81.25%\n",
      "\n",
      "--- Client 17 Local Training with T=0.0857, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0468\n",
      "Epoch [2/5], Loss: 0.4079\n",
      "Epoch [3/5], Loss: 0.2632\n",
      "Epoch [4/5], Loss: 0.1382\n",
      "Epoch [5/5], Loss: 0.0869\n",
      "Client 17 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 18 Local Training with T=0.0977, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8624\n",
      "Epoch [2/5], Loss: 0.4265\n",
      "Epoch [3/5], Loss: 0.2969\n",
      "Epoch [4/5], Loss: 0.2286\n",
      "Epoch [5/5], Loss: 0.1394\n",
      "Client 18 Private Data Validation Accuracy: 71.35%\n",
      "\n",
      "--- Client 19 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2775\n",
      "Epoch [2/5], Loss: 0.5336\n",
      "Epoch [3/5], Loss: 0.2637\n",
      "Epoch [4/5], Loss: 0.1753\n",
      "Epoch [5/5], Loss: 0.2055\n",
      "Client 19 Private Data Validation Accuracy: 76.95%\n",
      "\n",
      "--- Client 20 Local Training with T=0.1593, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8480\n",
      "Epoch [2/5], Loss: 0.4784\n",
      "Epoch [3/5], Loss: 0.2766\n",
      "Epoch [4/5], Loss: 0.1965\n",
      "Epoch [5/5], Loss: 0.1170\n",
      "Client 20 Private Data Validation Accuracy: 66.80%\n",
      "\n",
      "--- Client 21 Local Training with T=0.1058, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8976\n",
      "Epoch [2/5], Loss: 0.4198\n",
      "Epoch [3/5], Loss: 0.2677\n",
      "Epoch [4/5], Loss: 0.2237\n",
      "Epoch [5/5], Loss: 0.0933\n",
      "Client 21 Private Data Validation Accuracy: 65.10%\n",
      "\n",
      "--- Client 22 Local Training with T=0.0529, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.3879\n",
      "Epoch [2/5], Loss: 0.5152\n",
      "Epoch [3/5], Loss: 0.3748\n",
      "Epoch [4/5], Loss: 0.2585\n",
      "Epoch [5/5], Loss: 0.1372\n",
      "Client 22 Private Data Validation Accuracy: 78.65%\n",
      "\n",
      "--- Client 23 Local Training with T=0.1563, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2866\n",
      "Epoch [2/5], Loss: 0.7640\n",
      "Epoch [3/5], Loss: 0.4997\n",
      "Epoch [4/5], Loss: 0.3354\n",
      "Epoch [5/5], Loss: 0.1848\n",
      "Client 23 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 24 Local Training with T=0.0660, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.9973\n",
      "Epoch [2/5], Loss: 0.9907\n",
      "Epoch [3/5], Loss: 0.4883\n",
      "Epoch [4/5], Loss: 0.3846\n",
      "Epoch [5/5], Loss: 0.3673\n",
      "Client 24 Private Data Validation Accuracy: 66.67%\n",
      "\n",
      "--- Client 25 Local Training with T=0.0718, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.5392\n",
      "Epoch [2/5], Loss: 0.5203\n",
      "Epoch [3/5], Loss: 0.2664\n",
      "Epoch [4/5], Loss: 0.1671\n",
      "Epoch [5/5], Loss: 0.1280\n",
      "Client 25 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 26 Local Training with T=0.0658, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7916\n",
      "Epoch [2/5], Loss: 0.4156\n",
      "Epoch [3/5], Loss: 0.2354\n",
      "Epoch [4/5], Loss: 0.2037\n",
      "Epoch [5/5], Loss: 0.1412\n",
      "Client 26 Private Data Validation Accuracy: 79.17%\n",
      "\n",
      "--- Client 27 Local Training with T=0.1345, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0249\n",
      "Epoch [2/5], Loss: 0.4958\n",
      "Epoch [3/5], Loss: 0.3522\n",
      "Epoch [4/5], Loss: 0.2564\n",
      "Epoch [5/5], Loss: 0.1718\n",
      "Client 27 Private Data Validation Accuracy: 54.17%\n",
      "\n",
      "--- Client 28 Local Training with T=0.1051, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8112\n",
      "Epoch [2/5], Loss: 0.2773\n",
      "Epoch [3/5], Loss: 0.1914\n",
      "Epoch [4/5], Loss: 0.0999\n",
      "Epoch [5/5], Loss: 0.1001\n",
      "Client 28 Private Data Validation Accuracy: 79.17%\n",
      "\n",
      "--- Client 29 Local Training with T=0.0799, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6581\n",
      "Epoch [2/5], Loss: 0.3858\n",
      "Epoch [3/5], Loss: 0.3193\n",
      "Epoch [4/5], Loss: 0.1928\n",
      "Epoch [5/5], Loss: 0.1859\n",
      "Client 29 Private Data Validation Accuracy: 71.09%\n",
      "\n",
      "--- Client 30 Local Training with T=0.0872, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6274\n",
      "Epoch [2/5], Loss: 0.2968\n",
      "Epoch [3/5], Loss: 0.2156\n",
      "Epoch [4/5], Loss: 0.2408\n",
      "Epoch [5/5], Loss: 0.1245\n",
      "Client 30 Private Data Validation Accuracy: 68.44%\n",
      "Client 30 - decrease-temp to 0.082862\n",
      "\n",
      "--- Client 31 Local Training with T=0.0532, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1733\n",
      "Epoch [2/5], Loss: 0.4627\n",
      "Epoch [3/5], Loss: 0.2478\n",
      "Epoch [4/5], Loss: 0.1961\n",
      "Epoch [5/5], Loss: 0.1289\n",
      "Client 31 Private Data Validation Accuracy: 87.50%\n",
      "\n",
      "--- Client 32 Local Training with T=0.0541, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2643\n",
      "Epoch [2/5], Loss: 0.5756\n",
      "Epoch [3/5], Loss: 0.2139\n",
      "Epoch [4/5], Loss: 0.1944\n",
      "Epoch [5/5], Loss: 0.1460\n",
      "Client 32 Private Data Validation Accuracy: 72.66%\n",
      "\n",
      "--- Client 33 Local Training with T=0.1223, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7913\n",
      "Epoch [2/5], Loss: 0.3450\n",
      "Epoch [3/5], Loss: 0.2127\n",
      "Epoch [4/5], Loss: 0.1685\n",
      "Epoch [5/5], Loss: 0.1954\n",
      "Client 33 Private Data Validation Accuracy: 64.45%\n",
      "\n",
      "--- Client 34 Local Training with T=0.1250, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5907\n",
      "Epoch [2/5], Loss: 0.2225\n",
      "Epoch [3/5], Loss: 0.1176\n",
      "Epoch [4/5], Loss: 0.0767\n",
      "Epoch [5/5], Loss: 0.0438\n",
      "Client 34 Private Data Validation Accuracy: 83.33%\n",
      "\n",
      "--- Client 35 Local Training with T=0.0529, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.9550\n",
      "Epoch [2/5], Loss: 0.5952\n",
      "Epoch [3/5], Loss: 0.4097\n",
      "Epoch [4/5], Loss: 0.2552\n",
      "Epoch [5/5], Loss: 0.1737\n",
      "Client 35 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Client 36 Local Training with T=0.0550, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1175\n",
      "Epoch [2/5], Loss: 0.6438\n",
      "Epoch [3/5], Loss: 0.2624\n",
      "Epoch [4/5], Loss: 0.1843\n",
      "Epoch [5/5], Loss: 0.1693\n",
      "Client 36 Private Data Validation Accuracy: 78.91%\n",
      "\n",
      "--- Client 37 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0710\n",
      "Epoch [2/5], Loss: 0.4998\n",
      "Epoch [3/5], Loss: 0.1726\n",
      "Epoch [4/5], Loss: 0.1386\n",
      "Epoch [5/5], Loss: 0.1011\n",
      "Client 37 Private Data Validation Accuracy: 88.54%\n",
      "\n",
      "--- Client 38 Local Training with T=0.1213, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0059\n",
      "Epoch [2/5], Loss: 0.5556\n",
      "Epoch [3/5], Loss: 0.4267\n",
      "Epoch [4/5], Loss: 0.2325\n",
      "Epoch [5/5], Loss: 0.1367\n",
      "Client 38 Private Data Validation Accuracy: 71.88%\n",
      "Client 38 - decrease-temp to 0.115193\n",
      "\n",
      "--- Client 39 Local Training with T=0.0696, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7351\n",
      "Epoch [2/5], Loss: 0.1119\n",
      "Epoch [3/5], Loss: 0.0616\n",
      "Epoch [4/5], Loss: 0.0283\n",
      "Epoch [5/5], Loss: 0.0537\n",
      "Client 39 Private Data Validation Accuracy: 89.58%\n",
      "\n",
      "--- Client 40 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.0162\n",
      "Epoch [2/5], Loss: 0.8865\n",
      "Epoch [3/5], Loss: 0.4726\n",
      "Epoch [4/5], Loss: 0.2747\n",
      "Epoch [5/5], Loss: 0.1472\n",
      "Client 40 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 41 Local Training with T=0.0840, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6794\n",
      "Epoch [2/5], Loss: 0.3724\n",
      "Epoch [3/5], Loss: 0.2213\n",
      "Epoch [4/5], Loss: 0.1601\n",
      "Epoch [5/5], Loss: 0.1112\n",
      "Client 41 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 42 Local Training with T=0.0537, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1318\n",
      "Epoch [2/5], Loss: 0.8250\n",
      "Epoch [3/5], Loss: 0.5038\n",
      "Epoch [4/5], Loss: 0.2636\n",
      "Epoch [5/5], Loss: 0.2824\n",
      "Client 42 Private Data Validation Accuracy: 70.31%\n",
      "\n",
      "--- Client 43 Local Training with T=0.1218, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3608\n",
      "Epoch [2/5], Loss: 0.7778\n",
      "Epoch [3/5], Loss: 0.5123\n",
      "Epoch [4/5], Loss: 0.2708\n",
      "Epoch [5/5], Loss: 0.1974\n",
      "Client 43 Private Data Validation Accuracy: 67.19%\n",
      "Client 43 - decrease-temp to 0.115714\n",
      "\n",
      "--- Client 44 Local Training with T=0.1051, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0238\n",
      "Epoch [2/5], Loss: 0.4669\n",
      "Epoch [3/5], Loss: 0.3410\n",
      "Epoch [4/5], Loss: 0.2489\n",
      "Epoch [5/5], Loss: 0.1851\n",
      "Client 44 Private Data Validation Accuracy: 66.67%\n",
      "\n",
      "--- Client 45 Local Training with T=0.0528, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0455\n",
      "Epoch [2/5], Loss: 0.3098\n",
      "Epoch [3/5], Loss: 0.1687\n",
      "Epoch [4/5], Loss: 0.1021\n",
      "Epoch [5/5], Loss: 0.0939\n",
      "Client 45 Private Data Validation Accuracy: 78.52%\n",
      "\n",
      "--- Client 46 Local Training with T=0.0643, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0566\n",
      "Epoch [2/5], Loss: 0.4887\n",
      "Epoch [3/5], Loss: 0.2776\n",
      "Epoch [4/5], Loss: 0.2867\n",
      "Epoch [5/5], Loss: 0.1441\n",
      "Client 46 Private Data Validation Accuracy: 70.83%\n",
      "\n",
      "--- Client 47 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.8614\n",
      "Epoch [2/5], Loss: 0.5520\n",
      "Epoch [3/5], Loss: 0.3627\n",
      "Epoch [4/5], Loss: 0.2397\n",
      "Epoch [5/5], Loss: 0.1517\n",
      "Client 47 Private Data Validation Accuracy: 80.47%\n",
      "\n",
      "--- Client 48 Local Training with T=0.0690, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2104\n",
      "Epoch [2/5], Loss: 0.5699\n",
      "Epoch [3/5], Loss: 0.2598\n",
      "Epoch [4/5], Loss: 0.1634\n",
      "Epoch [5/5], Loss: 0.1000\n",
      "Client 48 Private Data Validation Accuracy: 73.83%\n",
      "\n",
      "--- Client 49 Local Training with T=0.0545, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6749\n",
      "Epoch [2/5], Loss: 0.6483\n",
      "Epoch [3/5], Loss: 0.3820\n",
      "Epoch [4/5], Loss: 0.2257\n",
      "Epoch [5/5], Loss: 0.1933\n",
      "Client 49 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 58.41%\n",
      "\n",
      "\n",
      "##################################################\n",
      "# RUNNING FedChill with Scaling Factor 3.5\n",
      "##################################################\n",
      "\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9260, Initial temp: 0.0500\n",
      "Client 1 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 2 - Het Score: 0.6059, Initial temp: 0.1199\n",
      "Client 3 - Het Score: 0.8784, Initial temp: 0.0500\n",
      "Client 4 - Het Score: 0.5483, Initial temp: 0.1468\n",
      "Client 5 - Het Score: 0.7694, Initial temp: 0.0677\n",
      "Client 6 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 7 - Het Score: 0.6642, Initial temp: 0.0978\n",
      "Client 8 - Het Score: 0.7408, Initial temp: 0.0748\n",
      "Client 9 - Het Score: 0.6305, Initial temp: 0.1101\n",
      "Client 10 - Het Score: 0.5715, Initial temp: 0.1353\n",
      "Client 11 - Het Score: 0.9301, Initial temp: 0.0500\n",
      "Client 12 - Het Score: 0.7524, Initial temp: 0.0718\n",
      "Client 13 - Het Score: 0.9890, Initial temp: 0.0500\n",
      "Client 14 - Het Score: 0.8828, Initial temp: 0.0500\n",
      "Client 15 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 16 - Het Score: 0.7906, Initial temp: 0.0628\n",
      "Client 17 - Het Score: 0.7676, Initial temp: 0.0681\n",
      "Client 18 - Het Score: 0.7412, Initial temp: 0.0747\n",
      "Client 19 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 20 - Het Score: 0.5440, Initial temp: 0.1490\n",
      "Client 21 - Het Score: 0.6974, Initial temp: 0.0871\n",
      "Client 22 - Het Score: 0.9629, Initial temp: 0.0500\n",
      "Client 23 - Het Score: 0.6016, Initial temp: 0.1218\n",
      "Client 24 - Het Score: 0.8720, Initial temp: 0.0500\n",
      "Client 25 - Het Score: 0.7924, Initial temp: 0.0624\n",
      "Client 26 - Het Score: 0.8388, Initial temp: 0.0531\n",
      "Client 27 - Het Score: 0.5832, Initial temp: 0.1299\n",
      "Client 28 - Het Score: 0.6995, Initial temp: 0.0864\n",
      "Client 29 - Het Score: 0.7740, Initial temp: 0.0666\n",
      "Client 30 - Het Score: 0.7447, Initial temp: 0.0738\n",
      "Client 31 - Het Score: 0.9779, Initial temp: 0.0500\n",
      "Client 32 - Het Score: 0.9551, Initial temp: 0.0500\n",
      "Client 33 - Het Score: 0.6320, Initial temp: 0.1095\n",
      "Client 34 - Het Score: 0.6591, Initial temp: 0.0996\n",
      "Client 35 - Het Score: 0.9797, Initial temp: 0.0500\n",
      "Client 36 - Het Score: 0.8813, Initial temp: 0.0500\n",
      "Client 37 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 38 - Het Score: 0.6691, Initial temp: 0.0962\n",
      "Client 39 - Het Score: 0.8541, Initial temp: 0.0503\n",
      "Client 40 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 41 - Het Score: 0.7574, Initial temp: 0.0706\n",
      "Client 42 - Het Score: 0.9746, Initial temp: 0.0500\n",
      "Client 43 - Het Score: 0.6334, Initial temp: 0.1090\n",
      "Client 44 - Het Score: 0.6656, Initial temp: 0.0973\n",
      "Client 45 - Het Score: 0.9463, Initial temp: 0.0500\n",
      "Client 46 - Het Score: 0.8634, Initial temp: 0.0500\n",
      "Client 47 - Het Score: 1.0000, Initial temp: 0.0500\n",
      "Client 48 - Het Score: 0.8229, Initial temp: 0.0561\n",
      "Client 49 - Het Score: 0.9528, Initial temp: 0.0500\n",
      "\n",
      "==================== COMMUNICATION ROUND 1 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 2 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 3 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 4 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 5 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 6 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 7 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 8 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 9 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 10 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 11 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 12 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 13 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 14 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 15 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 16 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 17 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 18 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 19 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 20 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 21 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 22 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 23 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 24 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 25 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 26 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 27 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 28 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 29 ====================\n",
      "\n",
      "==================== COMMUNICATION ROUND 30 ====================\n",
      "\n",
      "--- LOCAL TRAINING OF CLIENTS ---\n",
      "\n",
      "--- Client 0 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0567\n",
      "Epoch [2/5], Loss: 0.5079\n",
      "Epoch [3/5], Loss: 0.5339\n",
      "Epoch [4/5], Loss: 0.3336\n",
      "Epoch [5/5], Loss: 0.3688\n",
      "Client 0 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Client 1 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3096\n",
      "Epoch [2/5], Loss: 0.3934\n",
      "Epoch [3/5], Loss: 0.2870\n",
      "Epoch [4/5], Loss: 0.1958\n",
      "Epoch [5/5], Loss: 0.1424\n",
      "Client 1 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1140, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7237\n",
      "Epoch [2/5], Loss: 0.4907\n",
      "Epoch [3/5], Loss: 0.3459\n",
      "Epoch [4/5], Loss: 0.2782\n",
      "Epoch [5/5], Loss: 0.1386\n",
      "Client 2 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 3 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0742\n",
      "Epoch [2/5], Loss: 0.5712\n",
      "Epoch [3/5], Loss: 0.2854\n",
      "Epoch [4/5], Loss: 0.2050\n",
      "Epoch [5/5], Loss: 0.1519\n",
      "Client 3 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 4 Local Training with T=0.1258, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8870\n",
      "Epoch [2/5], Loss: 0.5030\n",
      "Epoch [3/5], Loss: 0.3631\n",
      "Epoch [4/5], Loss: 0.2290\n",
      "Epoch [5/5], Loss: 0.1915\n",
      "Client 4 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Client 5 Local Training with T=0.0551, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4831\n",
      "Epoch [2/5], Loss: 0.6319\n",
      "Epoch [3/5], Loss: 0.3299\n",
      "Epoch [4/5], Loss: 0.2216\n",
      "Epoch [5/5], Loss: 0.1794\n",
      "Client 5 Private Data Validation Accuracy: 64.84%\n",
      "Client 5 - decrease-temp to 0.052370\n",
      "\n",
      "--- Client 6 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3773\n",
      "Epoch [2/5], Loss: 0.3974\n",
      "Epoch [3/5], Loss: 0.2756\n",
      "Epoch [4/5], Loss: 0.2285\n",
      "Epoch [5/5], Loss: 0.1555\n",
      "Client 6 Private Data Validation Accuracy: 76.17%\n",
      "\n",
      "--- Client 7 Local Training with T=0.0839, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6613\n",
      "Epoch [2/5], Loss: 0.2578\n",
      "Epoch [3/5], Loss: 0.1228\n",
      "Epoch [4/5], Loss: 0.1233\n",
      "Epoch [5/5], Loss: 0.1079\n",
      "Client 7 Private Data Validation Accuracy: 81.77%\n",
      "\n",
      "--- Client 8 Local Training with T=0.0609, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5880\n",
      "Epoch [2/5], Loss: 0.2370\n",
      "Epoch [3/5], Loss: 0.2168\n",
      "Epoch [4/5], Loss: 0.0961\n",
      "Epoch [5/5], Loss: 0.0865\n",
      "Client 8 Private Data Validation Accuracy: 85.42%\n",
      "\n",
      "--- Client 9 Local Training with T=0.0993, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1919\n",
      "Epoch [2/5], Loss: 0.6810\n",
      "Epoch [3/5], Loss: 0.3826\n",
      "Epoch [4/5], Loss: 0.2849\n",
      "Epoch [5/5], Loss: 0.1575\n",
      "Client 9 Private Data Validation Accuracy: 56.25%\n",
      "\n",
      "--- Client 10 Local Training with T=0.1102, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2095\n",
      "Epoch [2/5], Loss: 0.8314\n",
      "Epoch [3/5], Loss: 0.5257\n",
      "Epoch [4/5], Loss: 0.2787\n",
      "Epoch [5/5], Loss: 0.2907\n",
      "Client 10 Private Data Validation Accuracy: 58.59%\n",
      "\n",
      "--- Client 11 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6373\n",
      "Epoch [2/5], Loss: 0.7407\n",
      "Epoch [3/5], Loss: 0.2796\n",
      "Epoch [4/5], Loss: 0.2025\n",
      "Epoch [5/5], Loss: 0.1361\n",
      "Client 11 Private Data Validation Accuracy: 74.22%\n",
      "\n",
      "--- Client 12 Local Training with T=0.0585, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.6421\n",
      "Epoch [2/5], Loss: 0.3722\n",
      "Epoch [3/5], Loss: 0.2097\n",
      "Epoch [4/5], Loss: 0.1364\n",
      "Epoch [5/5], Loss: 0.0956\n",
      "Client 12 Private Data Validation Accuracy: 82.29%\n",
      "\n",
      "--- Client 13 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1228\n",
      "Epoch [2/5], Loss: 0.4755\n",
      "Epoch [3/5], Loss: 0.2289\n",
      "Epoch [4/5], Loss: 0.2081\n",
      "Epoch [5/5], Loss: 0.1546\n",
      "Client 13 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 14 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3096\n",
      "Epoch [2/5], Loss: 0.4722\n",
      "Epoch [3/5], Loss: 0.2652\n",
      "Epoch [4/5], Loss: 0.2220\n",
      "Epoch [5/5], Loss: 0.1608\n",
      "Client 14 Private Data Validation Accuracy: 73.96%\n",
      "\n",
      "--- Client 15 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8448\n",
      "Epoch [2/5], Loss: 0.2813\n",
      "Epoch [3/5], Loss: 0.2207\n",
      "Epoch [4/5], Loss: 0.1555\n",
      "Epoch [5/5], Loss: 0.1504\n",
      "Client 15 Private Data Validation Accuracy: 72.66%\n",
      "\n",
      "--- Client 16 Local Training with T=0.0539, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1390\n",
      "Epoch [2/5], Loss: 0.5971\n",
      "Epoch [3/5], Loss: 0.3027\n",
      "Epoch [4/5], Loss: 0.2458\n",
      "Epoch [5/5], Loss: 0.2463\n",
      "Client 16 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 17 Local Training with T=0.0555, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1730\n",
      "Epoch [2/5], Loss: 0.5015\n",
      "Epoch [3/5], Loss: 0.3517\n",
      "Epoch [4/5], Loss: 0.2152\n",
      "Epoch [5/5], Loss: 0.1742\n",
      "Client 17 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 18 Local Training with T=0.0578, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0049\n",
      "Epoch [2/5], Loss: 0.5221\n",
      "Epoch [3/5], Loss: 0.3363\n",
      "Epoch [4/5], Loss: 0.3798\n",
      "Epoch [5/5], Loss: 0.2353\n",
      "Client 18 Private Data Validation Accuracy: 69.27%\n",
      "\n",
      "--- Client 19 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7941\n",
      "Epoch [2/5], Loss: 0.4548\n",
      "Epoch [3/5], Loss: 0.2614\n",
      "Epoch [4/5], Loss: 0.1977\n",
      "Epoch [5/5], Loss: 0.1530\n",
      "Client 19 Private Data Validation Accuracy: 76.17%\n",
      "\n",
      "--- Client 20 Local Training with T=0.1153, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7921\n",
      "Epoch [2/5], Loss: 0.4740\n",
      "Epoch [3/5], Loss: 0.2695\n",
      "Epoch [4/5], Loss: 0.1921\n",
      "Epoch [5/5], Loss: 0.1809\n",
      "Client 20 Private Data Validation Accuracy: 69.14%\n",
      "\n",
      "--- Client 21 Local Training with T=0.0747, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8749\n",
      "Epoch [2/5], Loss: 0.4489\n",
      "Epoch [3/5], Loss: 0.4242\n",
      "Epoch [4/5], Loss: 0.2743\n",
      "Epoch [5/5], Loss: 0.1582\n",
      "Client 21 Private Data Validation Accuracy: 67.71%\n",
      "\n",
      "--- Client 22 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0317\n",
      "Epoch [2/5], Loss: 0.4452\n",
      "Epoch [3/5], Loss: 0.2927\n",
      "Epoch [4/5], Loss: 0.1523\n",
      "Epoch [5/5], Loss: 0.1448\n",
      "Client 22 Private Data Validation Accuracy: 84.38%\n",
      "\n",
      "--- Client 23 Local Training with T=0.1044, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3646\n",
      "Epoch [2/5], Loss: 0.6913\n",
      "Epoch [3/5], Loss: 0.5402\n",
      "Epoch [4/5], Loss: 0.3776\n",
      "Epoch [5/5], Loss: 0.2871\n",
      "Client 23 Private Data Validation Accuracy: 46.88%\n",
      "\n",
      "--- Client 24 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4356\n",
      "Epoch [2/5], Loss: 0.8414\n",
      "Epoch [3/5], Loss: 0.4604\n",
      "Epoch [4/5], Loss: 0.4946\n",
      "Epoch [5/5], Loss: 0.4244\n",
      "Client 24 Private Data Validation Accuracy: 67.71%\n",
      "\n",
      "--- Client 25 Local Training with T=0.0535, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 3.4674\n",
      "Epoch [2/5], Loss: 0.8834\n",
      "Epoch [3/5], Loss: 0.4539\n",
      "Epoch [4/5], Loss: 0.2996\n",
      "Epoch [5/5], Loss: 0.2193\n",
      "Client 25 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 26 Local Training with T=0.0531, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8548\n",
      "Epoch [2/5], Loss: 0.2936\n",
      "Epoch [3/5], Loss: 0.1907\n",
      "Epoch [4/5], Loss: 0.1736\n",
      "Epoch [5/5], Loss: 0.1685\n",
      "Client 26 Private Data Validation Accuracy: 78.65%\n",
      "\n",
      "--- Client 27 Local Training with T=0.1114, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0118\n",
      "Epoch [2/5], Loss: 0.5891\n",
      "Epoch [3/5], Loss: 0.4898\n",
      "Epoch [4/5], Loss: 0.2804\n",
      "Epoch [5/5], Loss: 0.2816\n",
      "Client 27 Private Data Validation Accuracy: 52.08%\n",
      "\n",
      "--- Client 28 Local Training with T=0.0741, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7221\n",
      "Epoch [2/5], Loss: 0.2369\n",
      "Epoch [3/5], Loss: 0.1363\n",
      "Epoch [4/5], Loss: 0.0773\n",
      "Epoch [5/5], Loss: 0.0645\n",
      "Client 28 Private Data Validation Accuracy: 76.04%\n",
      "Client 28 - decrease-temp to 0.070401\n",
      "\n",
      "--- Client 29 Local Training with T=0.0542, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8957\n",
      "Epoch [2/5], Loss: 0.5426\n",
      "Epoch [3/5], Loss: 0.3645\n",
      "Epoch [4/5], Loss: 0.2002\n",
      "Epoch [5/5], Loss: 0.1613\n",
      "Client 29 Private Data Validation Accuracy: 71.48%\n",
      "\n",
      "--- Client 30 Local Training with T=0.0601, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7385\n",
      "Epoch [2/5], Loss: 0.4864\n",
      "Epoch [3/5], Loss: 0.2561\n",
      "Epoch [4/5], Loss: 0.2493\n",
      "Epoch [5/5], Loss: 0.2133\n",
      "Client 30 Private Data Validation Accuracy: 58.44%\n",
      "\n",
      "--- Client 31 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 3.1823\n",
      "Epoch [2/5], Loss: 0.7864\n",
      "Epoch [3/5], Loss: 0.5023\n",
      "Epoch [4/5], Loss: 0.3405\n",
      "Epoch [5/5], Loss: 0.2269\n",
      "Client 31 Private Data Validation Accuracy: 84.38%\n",
      "\n",
      "--- Client 32 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9950\n",
      "Epoch [2/5], Loss: 0.3150\n",
      "Epoch [3/5], Loss: 0.2557\n",
      "Epoch [4/5], Loss: 0.2153\n",
      "Epoch [5/5], Loss: 0.1915\n",
      "Client 32 Private Data Validation Accuracy: 71.88%\n",
      "\n",
      "--- Client 33 Local Training with T=0.1040, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7847\n",
      "Epoch [2/5], Loss: 0.4419\n",
      "Epoch [3/5], Loss: 0.2323\n",
      "Epoch [4/5], Loss: 0.2265\n",
      "Epoch [5/5], Loss: 0.1704\n",
      "Client 33 Private Data Validation Accuracy: 64.84%\n",
      "\n",
      "--- Client 34 Local Training with T=0.0811, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7253\n",
      "Epoch [2/5], Loss: 0.2799\n",
      "Epoch [3/5], Loss: 0.1749\n",
      "Epoch [4/5], Loss: 0.1119\n",
      "Epoch [5/5], Loss: 0.1210\n",
      "Client 34 Private Data Validation Accuracy: 77.08%\n",
      "Client 34 - decrease-temp to 0.077056\n",
      "\n",
      "--- Client 35 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4792\n",
      "Epoch [2/5], Loss: 0.4325\n",
      "Epoch [3/5], Loss: 0.3077\n",
      "Epoch [4/5], Loss: 0.2392\n",
      "Epoch [5/5], Loss: 0.1836\n",
      "Client 35 Private Data Validation Accuracy: 84.38%\n",
      "\n",
      "--- Client 36 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0953\n",
      "Epoch [2/5], Loss: 0.6629\n",
      "Epoch [3/5], Loss: 0.3037\n",
      "Epoch [4/5], Loss: 0.1509\n",
      "Epoch [5/5], Loss: 0.1809\n",
      "Client 36 Private Data Validation Accuracy: 74.22%\n",
      "\n",
      "--- Client 37 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.8263\n",
      "Epoch [2/5], Loss: 0.4011\n",
      "Epoch [3/5], Loss: 0.1740\n",
      "Epoch [4/5], Loss: 0.1222\n",
      "Epoch [5/5], Loss: 0.0708\n",
      "Client 37 Private Data Validation Accuracy: 86.46%\n",
      "\n",
      "--- Client 38 Local Training with T=0.0744, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1799\n",
      "Epoch [2/5], Loss: 0.9875\n",
      "Epoch [3/5], Loss: 0.3591\n",
      "Epoch [4/5], Loss: 0.2006\n",
      "Epoch [5/5], Loss: 0.1864\n",
      "Client 38 Private Data Validation Accuracy: 71.09%\n",
      "\n",
      "--- Client 39 Local Training with T=0.0503, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1837\n",
      "Epoch [2/5], Loss: 0.2146\n",
      "Epoch [3/5], Loss: 0.0833\n",
      "Epoch [4/5], Loss: 0.0792\n",
      "Epoch [5/5], Loss: 0.0756\n",
      "Client 39 Private Data Validation Accuracy: 92.71%\n",
      "\n",
      "--- Client 40 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0656\n",
      "Epoch [2/5], Loss: 0.4890\n",
      "Epoch [3/5], Loss: 0.4782\n",
      "Epoch [4/5], Loss: 0.1596\n",
      "Epoch [5/5], Loss: 0.1214\n",
      "Client 40 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 41 Local Training with T=0.0605, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.7940\n",
      "Epoch [2/5], Loss: 0.5144\n",
      "Epoch [3/5], Loss: 0.3182\n",
      "Epoch [4/5], Loss: 0.2175\n",
      "Epoch [5/5], Loss: 0.1623\n",
      "Client 41 Private Data Validation Accuracy: 68.75%\n",
      "\n",
      "--- Client 42 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.7803\n",
      "Epoch [2/5], Loss: 0.5072\n",
      "Epoch [3/5], Loss: 0.5562\n",
      "Epoch [4/5], Loss: 0.3165\n",
      "Epoch [5/5], Loss: 0.2309\n",
      "Client 42 Private Data Validation Accuracy: 73.44%\n",
      "\n",
      "--- Client 43 Local Training with T=0.0934, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.7519\n",
      "Epoch [2/5], Loss: 0.9654\n",
      "Epoch [3/5], Loss: 0.6995\n",
      "Epoch [4/5], Loss: 0.4813\n",
      "Epoch [5/5], Loss: 0.3328\n",
      "Client 43 Private Data Validation Accuracy: 64.06%\n",
      "\n",
      "--- Client 44 Local Training with T=0.0835, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0523\n",
      "Epoch [2/5], Loss: 0.5471\n",
      "Epoch [3/5], Loss: 0.4335\n",
      "Epoch [4/5], Loss: 0.2890\n",
      "Epoch [5/5], Loss: 0.2104\n",
      "Client 44 Private Data Validation Accuracy: 66.15%\n",
      "\n",
      "--- Client 45 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6926\n",
      "Epoch [2/5], Loss: 0.3371\n",
      "Epoch [3/5], Loss: 0.2797\n",
      "Epoch [4/5], Loss: 0.2567\n",
      "Epoch [5/5], Loss: 0.1853\n",
      "Client 45 Private Data Validation Accuracy: 78.91%\n",
      "\n",
      "--- Client 46 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1929\n",
      "Epoch [2/5], Loss: 0.5267\n",
      "Epoch [3/5], Loss: 0.3080\n",
      "Epoch [4/5], Loss: 0.2949\n",
      "Epoch [5/5], Loss: 0.2249\n",
      "Client 46 Private Data Validation Accuracy: 64.58%\n",
      "\n",
      "--- Client 47 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 2.1381\n",
      "Epoch [2/5], Loss: 0.5539\n",
      "Epoch [3/5], Loss: 0.2789\n",
      "Epoch [4/5], Loss: 0.2491\n",
      "Epoch [5/5], Loss: 0.1802\n",
      "Client 47 Private Data Validation Accuracy: 77.34%\n",
      "\n",
      "--- Client 48 Local Training with T=0.0533, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3825\n",
      "Epoch [2/5], Loss: 0.3846\n",
      "Epoch [3/5], Loss: 0.2580\n",
      "Epoch [4/5], Loss: 0.2320\n",
      "Epoch [5/5], Loss: 0.2423\n",
      "Client 48 Private Data Validation Accuracy: 69.14%\n",
      "\n",
      "--- Client 49 Local Training with T=0.0500, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.8841\n",
      "Epoch [2/5], Loss: 1.0714\n",
      "Epoch [3/5], Loss: 0.4509\n",
      "Epoch [4/5], Loss: 0.1732\n",
      "Epoch [5/5], Loss: 0.1383\n",
      "Client 49 Private Data Validation Accuracy: 78.12%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 57.75%\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'server_acc' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_36/2023819718.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mresults\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mrun_experiment\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mplot_model_comparison\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mresults\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mresults\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/tmp/ipykernel_36/285767418.py\u001b[0m in \u001b[0;36mplot_model_comparison\u001b[0;34m(results)\u001b[0m\n\u001b[1;32m     39\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     40\u001b[0m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfigure\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfigsize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m6\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 41\u001b[0;31m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbar\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mwidth\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mserver_acc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mwidth\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'Server Acc (%)'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     42\u001b[0m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbar\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mwidth\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mclient_acc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mwidth\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'Average Client Acc (%)'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'server_acc' is not defined"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 1000x600 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "results = run_experiment()\n",
    "plot_model_comparison(results)\n",
    "\n",
    "print(results)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "nYAg_h1n7NAt"
   },
   "source": [
    "---"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "provenance": []
  },
  "kaggle": {
   "accelerator": "nvidiaTeslaT4",
   "dataSources": [],
   "dockerImageVersionId": 31090,
   "isGpuEnabled": true,
   "isInternetEnabled": true,
   "language": "python",
   "sourceType": "notebook"
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
