{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "vgUXRKpJh1yE"
   },
   "source": [
    "# FedChill Component Wise Analysis\n",
    "\n",
    "\n",
    "**Note:** non-IID partitioning framework and evaluation metrics shall be kept constant across all the baseline model development.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "execution": {
     "iopub.execute_input": "2025-07-18T15:38:14.495426Z",
     "iopub.status.busy": "2025-07-18T15:38:14.495171Z",
     "iopub.status.idle": "2025-07-18T15:38:21.528769Z",
     "shell.execute_reply": "2025-07-18T15:38:21.528135Z",
     "shell.execute_reply.started": "2025-07-18T15:38:14.495406Z"
    },
    "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-07-18T15:40:21.090429Z",
     "iopub.status.busy": "2025-07-18T15:40:21.090020Z",
     "iopub.status.idle": "2025-07-18T15:40:21.094255Z",
     "shell.execute_reply": "2025-07-18T15:40:21.093364Z",
     "shell.execute_reply.started": "2025-07-18T15:40:21.090405Z"
    },
    "id": "hHTqcMmPeQ1c",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "NUM_CLASSES = 10 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:23.268077Z",
     "iopub.status.busy": "2025-07-18T15:40:23.267276Z",
     "iopub.status.idle": "2025-07-18T15:40:23.292991Z",
     "shell.execute_reply": "2025-07-18T15:40:23.292102Z",
     "shell.execute_reply.started": "2025-07-18T15:40:23.268041Z"
    },
    "id": "wbTcHg2oA2g8",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "class SmallCNN(nn.Module):\n",
    "    def __init__(self, num_classes=NUM_CLASSES, seed=42):\n",
    "        super(SmallCNN, self).__init__()\n",
    "\n",
    "        torch.manual_seed(seed)\n",
    "\n",
    "        self.conv1 = nn.Conv2d(3, 32, 3, padding=1)\n",
    "        self.bn1 = nn.BatchNorm2d(32)\n",
    "        self.conv2 = nn.Conv2d(32, 32, 3, padding=1)\n",
    "        self.bn2 = nn.BatchNorm2d(32)\n",
    "\n",
    "        self.conv3 = nn.Conv2d(32, 64, 3, padding=1)\n",
    "        self.bn3 = nn.BatchNorm2d(64)\n",
    "        self.conv4 = nn.Conv2d(64, 64, 3, padding=1)\n",
    "        self.bn4 = nn.BatchNorm2d(64)\n",
    "\n",
    "        self.conv5 = nn.Conv2d(64, 128, 3, padding=1)\n",
    "        self.bn5 = nn.BatchNorm2d(128)\n",
    "        self.conv6 = nn.Conv2d(128, 128, 3, padding=1)\n",
    "        self.bn6 = nn.BatchNorm2d(128)\n",
    "\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.adaptive_pool = nn.AdaptiveAvgPool2d((2, 2))\n",
    "\n",
    "        self.fc1 = nn.Linear(128 * 2 * 2, 512)\n",
    "        self.bn_fc1 = nn.BatchNorm1d(512)\n",
    "        self.dropout1 = nn.Dropout(0.5)\n",
    "\n",
    "        self.fc2 = nn.Linear(512, 256)\n",
    "        self.bn_fc2 = nn.BatchNorm1d(256)\n",
    "        self.dropout2 = nn.Dropout(0.3)\n",
    "\n",
    "        self.fc3 = nn.Linear(256, 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",
    "    def forward(self, x):\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.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",
    "        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.adaptive_pool(x)\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": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:28.055475Z",
     "iopub.status.busy": "2025-07-18T15:40:28.055233Z",
     "iopub.status.idle": "2025-07-18T15:40:28.069704Z",
     "shell.execute_reply": "2025-07-18T15:40:28.069007Z",
     "shell.execute_reply.started": "2025-07-18T15:40:28.055458Z"
    },
    "id": "gVCZKSAhh1yH",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "class MedCNN(nn.Module):\n",
    "    def __init__(self, num_classes=NUM_CLASSES, seed=42):\n",
    "        super(MedCNN, 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",
    "        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": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:32.333564Z",
     "iopub.status.busy": "2025-07-18T15:40:32.333333Z",
     "iopub.status.idle": "2025-07-18T15:40:32.346670Z",
     "shell.execute_reply": "2025-07-18T15:40:32.346014Z",
     "shell.execute_reply.started": "2025-07-18T15:40:32.333549Z"
    },
    "id": "ytqUW1TwA2g9",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "class LargeCNN(nn.Module):\n",
    "    def __init__(self, num_classes=NUM_CLASSES, seed=42):\n",
    "        super(LargeCNN, self).__init__()\n",
    "        torch.manual_seed(seed)\n",
    "\n",
    "        self.conv1 = nn.Conv2d(3, 80, 3, padding=1)\n",
    "        self.bn1 = nn.BatchNorm2d(80)\n",
    "        self.conv2 = nn.Conv2d(80, 80, 3, padding=1)\n",
    "        self.bn2 = nn.BatchNorm2d(80)\n",
    "        self.conv3 = nn.Conv2d(80, 80, 3, padding=1)\n",
    "        self.bn3 = nn.BatchNorm2d(80)\n",
    "\n",
    "        self.conv4 = nn.Conv2d(80, 160, 3, padding=1)\n",
    "        self.bn4 = nn.BatchNorm2d(160)\n",
    "        self.conv5 = nn.Conv2d(160, 160, 3, padding=1)\n",
    "        self.bn5 = nn.BatchNorm2d(160)\n",
    "        self.conv6 = nn.Conv2d(160, 160, 3, padding=1)\n",
    "        self.bn6 = nn.BatchNorm2d(160)\n",
    "\n",
    "        self.conv7 = nn.Conv2d(160, 320, 3, padding=1)\n",
    "        self.bn7 = nn.BatchNorm2d(320)\n",
    "        self.conv8 = nn.Conv2d(320, 320, 3, padding=1)\n",
    "        self.bn8 = nn.BatchNorm2d(320)\n",
    "        self.conv9 = nn.Conv2d(320, 320, 3, padding=1)\n",
    "        self.bn9 = nn.BatchNorm2d(320)\n",
    "\n",
    "        self.conv10 = nn.Conv2d(320, 640, 3, padding=1)\n",
    "        self.bn10 = nn.BatchNorm2d(640)\n",
    "        self.conv11 = nn.Conv2d(640, 640, 3, padding=1)\n",
    "        self.bn11 = nn.BatchNorm2d(640)\n",
    "\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.adaptive_pool = nn.AdaptiveAvgPool2d((2, 2))\n",
    "\n",
    "        self.fc1 = nn.Linear(640 * 2 * 2, 1536)\n",
    "        self.bn_fc1 = nn.BatchNorm1d(1536)\n",
    "        self.dropout1 = nn.Dropout(0.5)\n",
    "\n",
    "        self.fc2 = nn.Linear(1536, 768)\n",
    "        self.bn_fc2 = nn.BatchNorm1d(768)\n",
    "        self.dropout2 = nn.Dropout(0.4)\n",
    "\n",
    "        self.fc3 = nn.Linear(768, 384)\n",
    "        self.bn_fc3 = nn.BatchNorm1d(384)\n",
    "        self.dropout3 = nn.Dropout(0.3)\n",
    "\n",
    "        self.fc4 = nn.Linear(384, num_classes)\n",
    "\n",
    "        self._initialize_weights()\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",
    "    def forward(self, x):\n",
    "        x = F.relu(self.bn1(self.conv1(x)))\n",
    "        x = F.relu(self.bn2(self.conv2(x)))\n",
    "        x = F.relu(self.bn3(self.conv3(x)))\n",
    "        x = self.pool(x)\n",
    "\n",
    "        x = F.relu(self.bn4(self.conv4(x)))\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 = F.relu(self.bn8(self.conv8(x)))\n",
    "        x = F.relu(self.bn9(self.conv9(x)))\n",
    "        x = self.pool(x)\n",
    "\n",
    "        x = F.relu(self.bn10(self.conv10(x)))\n",
    "        x = F.relu(self.bn11(self.conv11(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 = F.relu(self.bn_fc3(self.fc3(x)))\n",
    "        x = self.dropout3(x)\n",
    "\n",
    "        return self.fc4(x)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:37.340764Z",
     "iopub.status.busy": "2025-07-18T15:40:37.340085Z",
     "iopub.status.idle": "2025-07-18T15:40:37.873688Z",
     "shell.execute_reply": "2025-07-18T15:40:37.872873Z",
     "shell.execute_reply.started": "2025-07-18T15:40:37.340730Z"
    },
    "id": "qhChMfBTA2g-",
    "outputId": "d4204026-6fe8-42c4-b711-a9d34025647e",
    "trusted": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SmallCNN parameters: 685,994\n",
      "MediumCNN parameters: 4,959,562\n",
      "LargeCNN parameters: 13,954,474\n"
     ]
    }
   ],
   "source": [
    "def count_parameters(model):\n",
    "    return sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "\n",
    "small_model = SmallCNN().to(device)\n",
    "med_model = MedCNN().to(device)\n",
    "large_model = LargeCNN().to(device)\n",
    "\n",
    "small_params = count_parameters(small_model)\n",
    "medium_params = count_parameters(med_model)\n",
    "large_params = count_parameters(large_model)\n",
    "\n",
    "print(f\"SmallCNN parameters: {small_params:,}\")\n",
    "print(f\"MediumCNN parameters: {medium_params:,}\")\n",
    "print(f\"LargeCNN parameters: {large_params:,}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:41.438185Z",
     "iopub.status.busy": "2025-07-18T15:40:41.437901Z",
     "iopub.status.idle": "2025-07-18T15:40:41.442154Z",
     "shell.execute_reply": "2025-07-18T15:40:41.441471Z",
     "shell.execute_reply.started": "2025-07-18T15:40:41.438165Z"
    },
    "id": "fKFX-gLRddsE",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 64\n",
    "LEARNING_RATE = 0.01\n",
    "LOCAL_EPOCHS = 5\n",
    "NUM_OF_CLIENTS = 10\n",
    "COMM_ROUND = 30\n",
    "ALPHA = 0.5  \n",
    "FRAC = 0.1   "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "oJrL1U1Hh1yJ"
   },
   "source": [
    "---"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:44.893713Z",
     "iopub.status.busy": "2025-07-18T15:40:44.893440Z",
     "iopub.status.idle": "2025-07-18T15:40:44.908905Z",
     "shell.execute_reply": "2025-07-18T15:40:44.908348Z",
     "shell.execute_reply.started": "2025-07-18T15:40:44.893691Z"
    },
    "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",
    "    transform = transforms.Compose([\n",
    "        transforms.ToTensor(),\n",
    "        transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))\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": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:48.696482Z",
     "iopub.status.busy": "2025-07-18T15:40:48.696256Z",
     "iopub.status.idle": "2025-07-18T15:40:48.706982Z",
     "shell.execute_reply": "2025-07-18T15:40:48.706247Z",
     "shell.execute_reply.started": "2025-07-18T15:40:48.696466Z"
    },
    "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": [
    "### AdaptiveClientHyperparams with Changed Temperature Adjust Factor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:53.205471Z",
     "iopub.status.busy": "2025-07-18T15:40:53.204894Z",
     "iopub.status.idle": "2025-07-18T15:40:53.222272Z",
     "shell.execute_reply": "2025-07-18T15:40:53.221543Z",
     "shell.execute_reply.started": "2025-07-18T15:40:53.205450Z"
    },
    "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):\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",
    "\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(-2 * 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",
    "    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": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:40:59.653820Z",
     "iopub.status.busy": "2025-07-18T15:40:59.653539Z",
     "iopub.status.idle": "2025-07-18T15:40:59.657584Z",
     "shell.execute_reply": "2025-07-18T15:40:59.656838Z",
     "shell.execute_reply.started": "2025-07-18T15:40:59.653799Z"
    },
    "id": "RlQUq8Ht61cg",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 64\n",
    "LEARNING_RATE = 0.01\n",
    "LOCAL_EPOCHS = 5\n",
    "NUM_OF_CLIENTS = 10\n",
    "COMM_ROUND = 30\n",
    "ALPHA = 0.5  \n",
    "FRAC = 0.1   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:41:04.502064Z",
     "iopub.status.busy": "2025-07-18T15:41:04.501392Z",
     "iopub.status.idle": "2025-07-18T15:41:04.510120Z",
     "shell.execute_reply": "2025-07-18T15:41:04.509541Z",
     "shell.execute_reply.started": "2025-07-18T15:41:04.502033Z"
    },
    "id": "aM8zh73nA2hC",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def run_flexchill(temperature=0.05, model_class=MedCNN):\n",
    "    print_flag = False\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_model = model_class().to(device)\n",
    "\n",
    "    round_server_acc_list = []\n",
    "    round_client_acc_list = [[] 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=LEARNING_RATE) for model in client_models]\n",
    "\n",
    "    print(f\"Running Flex&Chill with temperature T={temperature}\")\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",
    "            if comm_round == COMM_ROUND - 1:\n",
    "                print(f\"\\n--- Client {client_idx} Local Training with T={temperature} ---\")\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=temperature,\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",
    "            if comm_round == COMM_ROUND - 1:\n",
    "                print(f\"Client {client_idx} Test Set Validation Accuracy: {client_testset_acc:.2f}%\")\n",
    "\n",
    "            round_client_acc_list[client_idx].append(local_acc)\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",
    "\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": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:41:08.429683Z",
     "iopub.status.busy": "2025-07-18T15:41:08.429415Z",
     "iopub.status.idle": "2025-07-18T15:41:08.440448Z",
     "shell.execute_reply": "2025-07-18T15:41:08.439735Z",
     "shell.execute_reply.started": "2025-07-18T15:41:08.429664Z"
    },
    "id": "ZGkxcCH6A2hC",
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def run_fedchill(model_class=MedCNN):\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() 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, client_temp_history, client_lr_history, global_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:41:16.746161Z",
     "iopub.status.busy": "2025-07-18T15:41:16.745659Z",
     "iopub.status.idle": "2025-07-18T15:41:16.755078Z",
     "shell.execute_reply": "2025-07-18T15:41:16.754010Z",
     "shell.execute_reply.started": "2025-07-18T15:41:16.746141Z"
    },
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def run_component_ablation(alpha_values=[0.5, 5.0], model_classes=[SmallCNN, LargeCNN]):\n",
    "    \n",
    "    results = {}\n",
    "    \n",
    "    for alpha in alpha_values:\n",
    "        results[alpha] = {}\n",
    "        \n",
    "        for model_class in model_classes:\n",
    "            model_name = model_class.__name__\n",
    "            results[alpha][model_name] = {}\n",
    "            \n",
    "            print(f\"\\n\\n{'='*80}\")\n",
    "            print(f\"RUNNING ABLATION WITH α={alpha}, MODEL={model_name}\")\n",
    "            print(f\"{'='*80}\\n\")\n",
    "            \n",
    "            global ALPHA\n",
    "            ALPHA = alpha\n",
    "            \n",
    "            print(f\"\\n--- COMPONENT: FedAvg (T=1.0) ---\")\n",
    "            server_acc, client_acc, _ = run_flexchill(temperature=1.0, model_class=model_class)\n",
    "            results[alpha][model_name][\"fedavg\"] = {\n",
    "                \"server_acc\": server_acc[-1],  # Final accuracy\n",
    "                \"client_acc\": [acc[-1] for acc in client_acc],  # Final client accuracies\n",
    "                \"avg_client_acc\": sum([acc[-1] for acc in client_acc]) / len(client_acc)\n",
    "            }\n",
    "            \n",
    "            print(f\"\\n--- COMPONENT: Fixed Low Temperature (T=0.05) ---\")\n",
    "            server_acc, client_acc, _ = run_flexchill(temperature=0.05, model_class=model_class)\n",
    "            results[alpha][model_name][\"fixed_low_temp\"] = {\n",
    "                \"server_acc\": server_acc[-1],\n",
    "                \"client_acc\": [acc[-1] for acc in client_acc],\n",
    "                \"avg_client_acc\": sum([acc[-1] for acc in client_acc]) / len(client_acc)\n",
    "            }\n",
    "            \n",
    "            print(f\"\\n--- COMPONENT: Heterogeneity-based Temperature (No Decay) ---\")\n",
    "            server_acc, client_acc, temp_history, _, _ = run_fedchill_no_decay(model_class=model_class)\n",
    "            results[alpha][model_name][\"het_based_temp\"] = {\n",
    "                \"server_acc\": server_acc[-1],\n",
    "                \"client_acc\": [acc[-1] for acc in client_acc],\n",
    "                \"avg_client_acc\": sum([acc[-1] for acc in client_acc]) / len(client_acc),\n",
    "                \"final_temps\": [temps[-1] for temps in temp_history]\n",
    "            }\n",
    "            \n",
    "            print(f\"\\n--- COMPONENT: Full FedChill ---\")\n",
    "            server_acc, client_acc, temp_history, _, _ = run_fedchill(model_class=model_class)\n",
    "            results[alpha][model_name][\"full_fedchill\"] = {\n",
    "                \"server_acc\": server_acc[-1],\n",
    "                \"client_acc\": [acc[-1] for acc in client_acc],\n",
    "                \"avg_client_acc\": sum([acc[-1] for acc in client_acc]) / len(client_acc),\n",
    "                \"final_temps\": [temps[-1] for temps in temp_history]\n",
    "            }\n",
    "    \n",
    "    print_component_ablation_table(results)\n",
    "    \n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:41:34.716432Z",
     "iopub.status.busy": "2025-07-18T15:41:34.716175Z",
     "iopub.status.idle": "2025-07-18T15:41:34.726960Z",
     "shell.execute_reply": "2025-07-18T15:41:34.726334Z",
     "shell.execute_reply.started": "2025-07-18T15:41:34.716414Z"
    },
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def run_fedchill_no_decay(model_class=MedCNN):\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 = []\n",
    "    \n",
    "    for _ in range(num_clients):\n",
    "        params = AdaptiveClientHyperparams()\n",
    "        params.patience = 1000  \n",
    "        client_params.append(params)\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}, Fixed 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",
    "            client_params[client_idx].record_performance(local_acc)\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, client_temp_history, client_lr_history, global_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:41:37.552409Z",
     "iopub.status.busy": "2025-07-18T15:41:37.551848Z",
     "iopub.status.idle": "2025-07-18T15:41:37.560919Z",
     "shell.execute_reply": "2025-07-18T15:41:37.559991Z",
     "shell.execute_reply.started": "2025-07-18T15:41:37.552385Z"
    },
    "trusted": true
   },
   "outputs": [],
   "source": [
    "def print_component_ablation_table(results):\n",
    "    print(\"\\n# Ablation Study - Component Contributions in FedChill\\n\")\n",
    "    \n",
    "    print(\"| Heterogeneity (α) | CNN Architecture | Component | Local Acc (%) | Global Acc (%) |\")\n",
    "    print(\"|------------------|-----------------|-----------|---------------|----------------|\")\n",
    "    \n",
    "    component_names = {\n",
    "        \"fedavg\": \"FedAvg (T=1.0)\", \n",
    "        \"fixed_low_temp\": \"Fixed T=0.05\", \n",
    "        \"het_based_temp\": \"Het-based T\", \n",
    "        \"full_fedchill\": \"Full FedChill\"\n",
    "    }\n",
    "    \n",
    "    for alpha in sorted(results.keys()):\n",
    "        first_alpha = True\n",
    "        \n",
    "        for model_name in results[alpha].keys():\n",
    "            first_model = True\n",
    "            model_params = count_parameters(eval(f\"{model_name}()\"))\n",
    "            model_display = f\"{model_name} ({model_params/1000000:.2f}M)\"\n",
    "            \n",
    "            for component in [\"fedavg\", \"fixed_low_temp\", \"het_based_temp\", \"full_fedchill\"]:\n",
    "                comp_data = results[alpha][model_name][component]\n",
    "                \n",
    "                if first_alpha and first_model:\n",
    "                    print(f\"| α = {alpha} | {model_display} | {component_names[component]} | {comp_data['avg_client_acc']:.2f} | {comp_data['server_acc']:.2f} |\")\n",
    "                    first_model = False\n",
    "                    first_alpha = False\n",
    "                elif first_model:\n",
    "                    print(f\"| α = {alpha} | {model_display} | {component_names[component]} | {comp_data['avg_client_acc']:.2f} | {comp_data['server_acc']:.2f} |\")\n",
    "                    first_model = False\n",
    "                else:\n",
    "                    print(f\"|  |  | {component_names[component]} | {comp_data['avg_client_acc']:.2f} | {comp_data['server_acc']:.2f} |\")\n",
    "    \n",
    "    with open('component_ablation_results.md', 'w') as f:\n",
    "        f.write(\"# Ablation Study - Component Contributions in FedChill\\n\\n\")\n",
    "        f.write(\"| Heterogeneity (α) | CNN Architecture | Component | Local Acc (%) | Global Acc (%) |\\n\")\n",
    "        f.write(\"|------------------|-----------------|-----------|---------------|----------------|\\n\")\n",
    "        \n",
    "        for alpha in sorted(results.keys()):\n",
    "            first_alpha = True\n",
    "            \n",
    "            for model_name in results[alpha].keys():\n",
    "                first_model = True\n",
    "                model_params = count_parameters(eval(f\"{model_name}()\"))\n",
    "                model_display = f\"{model_name} ({model_params/1000000:.2f}M)\"\n",
    "                \n",
    "                for component in [\"fedavg\", \"fixed_low_temp\", \"het_based_temp\", \"full_fedchill\"]:\n",
    "                    comp_data = results[alpha][model_name][component]\n",
    "                    \n",
    "                    if first_alpha and first_model:\n",
    "                        f.write(f\"| α = {alpha} | {model_display} | {component_names[component]} | {comp_data['avg_client_acc']:.2f} | {comp_data['server_acc']:.2f} |\\n\")\n",
    "                        first_model = False\n",
    "                        first_alpha = False\n",
    "                    elif first_model:\n",
    "                        f.write(f\"| α = {alpha} | {model_display} | {component_names[component]} | {comp_data['avg_client_acc']:.2f} | {comp_data['server_acc']:.2f} |\\n\")\n",
    "                        first_model = False\n",
    "                    else:\n",
    "                        f.write(f\"|  |  | {component_names[component]} | {comp_data['avg_client_acc']:.2f} | {comp_data['server_acc']:.2f} |\\n\")\n",
    "    \n",
    "    print(\"\\nResults also saved to 'component_ablation_results.md'\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-07-18T15:41:42.305119Z",
     "iopub.status.busy": "2025-07-18T15:41:42.304434Z",
     "iopub.status.idle": "2025-07-18T20:46:35.491768Z",
     "shell.execute_reply": "2025-07-18T20:46:35.490943Z",
     "shell.execute_reply.started": "2025-07-18T15:41:42.305097Z"
    },
    "trusted": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "================================================================================\n",
      "RUNNING ABLATION WITH α=0.5, MODEL=SmallCNN\n",
      "================================================================================\n",
      "\n",
      "\n",
      "--- COMPONENT: FedAvg (T=1.0) ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 170M/170M [00:15<00:00, 11.0MB/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=1.0\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=1.0 ---\n",
      "Epoch [1/5], Loss: 0.4397\n",
      "Epoch [2/5], Loss: 0.1696\n",
      "Epoch [3/5], Loss: 0.1215\n",
      "Epoch [4/5], Loss: 0.0917\n",
      "Epoch [5/5], Loss: 0.0855\n",
      "Client 0 Private Data Validation Accuracy: 56.56%\n",
      "Client 0 Test Set Validation Accuracy: 32.56%\n",
      "\n",
      "--- Client 1 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 1.5139\n",
      "Epoch [2/5], Loss: 0.8569\n",
      "Epoch [3/5], Loss: 0.5796\n",
      "Epoch [4/5], Loss: 0.4786\n",
      "Epoch [5/5], Loss: 0.3501\n",
      "Client 1 Private Data Validation Accuracy: 59.38%\n",
      "Client 1 Test Set Validation Accuracy: 38.56%\n",
      "\n",
      "--- Client 2 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 1.0701\n",
      "Epoch [2/5], Loss: 0.4921\n",
      "Epoch [3/5], Loss: 0.2769\n",
      "Epoch [4/5], Loss: 0.2034\n",
      "Epoch [5/5], Loss: 0.1631\n",
      "Client 2 Private Data Validation Accuracy: 62.50%\n",
      "Client 2 Test Set Validation Accuracy: 30.78%\n",
      "\n",
      "--- Client 3 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.7861\n",
      "Epoch [2/5], Loss: 0.2344\n",
      "Epoch [3/5], Loss: 0.1544\n",
      "Epoch [4/5], Loss: 0.0819\n",
      "Epoch [5/5], Loss: 0.0609\n",
      "Client 3 Private Data Validation Accuracy: 90.62%\n",
      "Client 3 Test Set Validation Accuracy: 26.83%\n",
      "\n",
      "--- Client 4 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.5538\n",
      "Epoch [2/5], Loss: 0.2820\n",
      "Epoch [3/5], Loss: 0.1784\n",
      "Epoch [4/5], Loss: 0.1504\n",
      "Epoch [5/5], Loss: 0.1070\n",
      "Client 4 Private Data Validation Accuracy: 56.77%\n",
      "Client 4 Test Set Validation Accuracy: 39.99%\n",
      "\n",
      "--- Client 5 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.9977\n",
      "Epoch [2/5], Loss: 0.6110\n",
      "Epoch [3/5], Loss: 0.4287\n",
      "Epoch [4/5], Loss: 0.2940\n",
      "Epoch [5/5], Loss: 0.2649\n",
      "Client 5 Private Data Validation Accuracy: 50.78%\n",
      "Client 5 Test Set Validation Accuracy: 42.42%\n",
      "\n",
      "--- Client 6 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 1.9805\n",
      "Epoch [2/5], Loss: 0.9439\n",
      "Epoch [3/5], Loss: 0.6658\n",
      "Epoch [4/5], Loss: 0.4738\n",
      "Epoch [5/5], Loss: 0.3521\n",
      "Client 6 Private Data Validation Accuracy: 64.06%\n",
      "Client 6 Test Set Validation Accuracy: 38.31%\n",
      "\n",
      "--- Client 7 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.5324\n",
      "Epoch [2/5], Loss: 0.2824\n",
      "Epoch [3/5], Loss: 0.2121\n",
      "Epoch [4/5], Loss: 0.1797\n",
      "Epoch [5/5], Loss: 0.1561\n",
      "Client 7 Private Data Validation Accuracy: 62.50%\n",
      "Client 7 Test Set Validation Accuracy: 40.47%\n",
      "\n",
      "--- Client 8 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.6392\n",
      "Epoch [2/5], Loss: 0.2377\n",
      "Epoch [3/5], Loss: 0.1903\n",
      "Epoch [4/5], Loss: 0.1349\n",
      "Epoch [5/5], Loss: 0.1353\n",
      "Client 8 Private Data Validation Accuracy: 77.34%\n",
      "Client 8 Test Set Validation Accuracy: 33.67%\n",
      "\n",
      "--- Client 9 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.8214\n",
      "Epoch [2/5], Loss: 0.3637\n",
      "Epoch [3/5], Loss: 0.2754\n",
      "Epoch [4/5], Loss: 0.1909\n",
      "Epoch [5/5], Loss: 0.1495\n",
      "Client 9 Private Data Validation Accuracy: 64.84%\n",
      "Client 9 Test Set Validation Accuracy: 35.17%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 46.96%\n",
      "\n",
      "--- COMPONENT: Fixed Low Temperature (T=0.05) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=0.05\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.05 ---\n",
      "Epoch [1/5], Loss: 0.2862\n",
      "Epoch [2/5], Loss: 0.2499\n",
      "Epoch [3/5], Loss: 0.2130\n",
      "Epoch [4/5], Loss: 0.1394\n",
      "Epoch [5/5], Loss: 0.2019\n",
      "Client 0 Private Data Validation Accuracy: 55.94%\n",
      "Client 0 Test Set Validation Accuracy: 30.29%\n",
      "\n",
      "--- Client 1 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.6171\n",
      "Epoch [2/5], Loss: 0.6534\n",
      "Epoch [3/5], Loss: 0.5441\n",
      "Epoch [4/5], Loss: 0.3165\n",
      "Epoch [5/5], Loss: 0.2055\n",
      "Client 1 Private Data Validation Accuracy: 62.50%\n",
      "Client 1 Test Set Validation Accuracy: 37.49%\n",
      "\n",
      "--- Client 2 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.0002\n",
      "Epoch [2/5], Loss: 0.3601\n",
      "Epoch [3/5], Loss: 0.1975\n",
      "Epoch [4/5], Loss: 0.2033\n",
      "Epoch [5/5], Loss: 0.2122\n",
      "Client 2 Private Data Validation Accuracy: 65.10%\n",
      "Client 2 Test Set Validation Accuracy: 27.44%\n",
      "\n",
      "--- Client 3 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5016\n",
      "Epoch [2/5], Loss: 0.0625\n",
      "Epoch [3/5], Loss: 0.0328\n",
      "Epoch [4/5], Loss: 0.0317\n",
      "Epoch [5/5], Loss: 0.0268\n",
      "Client 3 Private Data Validation Accuracy: 94.27%\n",
      "Client 3 Test Set Validation Accuracy: 18.76%\n",
      "\n",
      "--- Client 4 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.3783\n",
      "Epoch [2/5], Loss: 0.3259\n",
      "Epoch [3/5], Loss: 0.2154\n",
      "Epoch [4/5], Loss: 0.1371\n",
      "Epoch [5/5], Loss: 0.2081\n",
      "Client 4 Private Data Validation Accuracy: 48.96%\n",
      "Client 4 Test Set Validation Accuracy: 37.06%\n",
      "\n",
      "--- Client 5 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.5847\n",
      "Epoch [2/5], Loss: 0.8416\n",
      "Epoch [3/5], Loss: 0.5097\n",
      "Epoch [4/5], Loss: 0.4008\n",
      "Epoch [5/5], Loss: 0.4111\n",
      "Client 5 Private Data Validation Accuracy: 60.16%\n",
      "Client 5 Test Set Validation Accuracy: 32.45%\n",
      "\n",
      "--- Client 6 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.5975\n",
      "Epoch [2/5], Loss: 0.4542\n",
      "Epoch [3/5], Loss: 0.3501\n",
      "Epoch [4/5], Loss: 0.1928\n",
      "Epoch [5/5], Loss: 0.1856\n",
      "Client 6 Private Data Validation Accuracy: 68.75%\n",
      "Client 6 Test Set Validation Accuracy: 34.08%\n",
      "\n",
      "--- Client 7 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.4500\n",
      "Epoch [2/5], Loss: 0.2280\n",
      "Epoch [3/5], Loss: 0.2375\n",
      "Epoch [4/5], Loss: 0.3066\n",
      "Epoch [5/5], Loss: 0.1703\n",
      "Client 7 Private Data Validation Accuracy: 56.25%\n",
      "Client 7 Test Set Validation Accuracy: 39.45%\n",
      "\n",
      "--- Client 8 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.3529\n",
      "Epoch [2/5], Loss: 0.1613\n",
      "Epoch [3/5], Loss: 0.1895\n",
      "Epoch [4/5], Loss: 0.1336\n",
      "Epoch [5/5], Loss: 0.2148\n",
      "Client 8 Private Data Validation Accuracy: 72.66%\n",
      "Client 8 Test Set Validation Accuracy: 26.28%\n",
      "\n",
      "--- Client 9 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.7762\n",
      "Epoch [2/5], Loss: 0.2804\n",
      "Epoch [3/5], Loss: 0.2208\n",
      "Epoch [4/5], Loss: 0.1399\n",
      "Epoch [5/5], Loss: 0.1448\n",
      "Client 9 Private Data Validation Accuracy: 71.88%\n",
      "Client 9 Test Set Validation Accuracy: 34.37%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 47.26%\n",
      "\n",
      "--- COMPONENT: Heterogeneity-based Temperature (No Decay) ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9007, Fixed temp: 0.1651\n",
      "Client 1 - Het Score: 0.7295, Fixed temp: 0.2325\n",
      "Client 2 - Het Score: 0.8682, Fixed temp: 0.1762\n",
      "Client 3 - Het Score: 0.8552, Fixed temp: 0.1808\n",
      "Client 4 - Het Score: 0.5698, Fixed temp: 0.3199\n",
      "Client 5 - Het Score: 0.5956, Fixed temp: 0.3038\n",
      "Client 6 - Het Score: 0.7451, Fixed temp: 0.2253\n",
      "Client 7 - Het Score: 0.6556, Fixed temp: 0.2695\n",
      "Client 8 - Het Score: 1.0000, Fixed temp: 0.1353\n",
      "Client 9 - Het Score: 1.0000, Fixed temp: 0.1353\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.1651, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1918\n",
      "Epoch [2/5], Loss: 0.0325\n",
      "Epoch [3/5], Loss: 0.0427\n",
      "Epoch [4/5], Loss: 0.0297\n",
      "Epoch [5/5], Loss: 0.0420\n",
      "Client 0 Private Data Validation Accuracy: 59.69%\n",
      "\n",
      "--- Client 1 Local Training with T=0.2325, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2181\n",
      "Epoch [2/5], Loss: 0.2421\n",
      "Epoch [3/5], Loss: 0.1668\n",
      "Epoch [4/5], Loss: 0.1330\n",
      "Epoch [5/5], Loss: 0.0766\n",
      "Client 1 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1762, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4884\n",
      "Epoch [2/5], Loss: 0.1990\n",
      "Epoch [3/5], Loss: 0.1062\n",
      "Epoch [4/5], Loss: 0.1411\n",
      "Epoch [5/5], Loss: 0.0880\n",
      "Client 2 Private Data Validation Accuracy: 65.10%\n",
      "\n",
      "--- Client 3 Local Training with T=0.1808, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3950\n",
      "Epoch [2/5], Loss: 0.0147\n",
      "Epoch [3/5], Loss: 0.0409\n",
      "Epoch [4/5], Loss: 0.0102\n",
      "Epoch [5/5], Loss: 0.0083\n",
      "Client 3 Private Data Validation Accuracy: 90.62%\n",
      "\n",
      "--- Client 4 Local Training with T=0.3199, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3032\n",
      "Epoch [2/5], Loss: 0.1320\n",
      "Epoch [3/5], Loss: 0.0742\n",
      "Epoch [4/5], Loss: 0.0556\n",
      "Epoch [5/5], Loss: 0.0509\n",
      "Client 4 Private Data Validation Accuracy: 57.29%\n",
      "\n",
      "--- Client 5 Local Training with T=0.3038, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5659\n",
      "Epoch [2/5], Loss: 0.2337\n",
      "Epoch [3/5], Loss: 0.1508\n",
      "Epoch [4/5], Loss: 0.0932\n",
      "Epoch [5/5], Loss: 0.0929\n",
      "Client 5 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 6 Local Training with T=0.2253, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.3367\n",
      "Epoch [2/5], Loss: 0.2773\n",
      "Epoch [3/5], Loss: 0.1682\n",
      "Epoch [4/5], Loss: 0.1046\n",
      "Epoch [5/5], Loss: 0.0712\n",
      "Client 6 Private Data Validation Accuracy: 76.56%\n",
      "\n",
      "--- Client 7 Local Training with T=0.2695, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2881\n",
      "Epoch [2/5], Loss: 0.1166\n",
      "Epoch [3/5], Loss: 0.1009\n",
      "Epoch [4/5], Loss: 0.0634\n",
      "Epoch [5/5], Loss: 0.0573\n",
      "Client 7 Private Data Validation Accuracy: 66.15%\n",
      "\n",
      "--- Client 8 Local Training with T=0.1353, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2314\n",
      "Epoch [2/5], Loss: 0.0341\n",
      "Epoch [3/5], Loss: 0.0390\n",
      "Epoch [4/5], Loss: 0.0285\n",
      "Epoch [5/5], Loss: 0.0885\n",
      "Client 8 Private Data Validation Accuracy: 75.39%\n",
      "\n",
      "--- Client 9 Local Training with T=0.1353, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6083\n",
      "Epoch [2/5], Loss: 0.1154\n",
      "Epoch [3/5], Loss: 0.0763\n",
      "Epoch [4/5], Loss: 0.0602\n",
      "Epoch [5/5], Loss: 0.0288\n",
      "Client 9 Private Data Validation Accuracy: 67.97%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 49.33%\n",
      "\n",
      "--- COMPONENT: Full FedChill ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9007, Initial temp: 0.1651\n",
      "Client 1 - Het Score: 0.7295, Initial temp: 0.2325\n",
      "Client 2 - Het Score: 0.8682, Initial temp: 0.1762\n",
      "Client 3 - Het Score: 0.8552, Initial temp: 0.1808\n",
      "Client 4 - Het Score: 0.5698, Initial temp: 0.3199\n",
      "Client 5 - Het Score: 0.5956, Initial temp: 0.3038\n",
      "Client 6 - Het Score: 0.7451, Initial temp: 0.2253\n",
      "Client 7 - Het Score: 0.6556, Initial temp: 0.2695\n",
      "Client 8 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 9 - Het Score: 1.0000, Initial temp: 0.1353\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.1415, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1316\n",
      "Epoch [2/5], Loss: 0.0219\n",
      "Epoch [3/5], Loss: 0.0359\n",
      "Epoch [4/5], Loss: 0.0203\n",
      "Epoch [5/5], Loss: 0.0429\n",
      "Client 0 Private Data Validation Accuracy: 56.88%\n",
      "\n",
      "--- Client 1 Local Training with T=0.1893, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.2807\n",
      "Epoch [2/5], Loss: 0.2678\n",
      "Epoch [3/5], Loss: 0.1700\n",
      "Epoch [4/5], Loss: 0.1201\n",
      "Epoch [5/5], Loss: 0.0885\n",
      "Client 1 Private Data Validation Accuracy: 64.06%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1590, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4865\n",
      "Epoch [2/5], Loss: 0.1303\n",
      "Epoch [3/5], Loss: 0.0858\n",
      "Epoch [4/5], Loss: 0.0986\n",
      "Epoch [5/5], Loss: 0.0578\n",
      "Client 2 Private Data Validation Accuracy: 64.06%\n",
      "\n",
      "--- Client 3 Local Training with T=0.1550, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3880\n",
      "Epoch [2/5], Loss: 0.0197\n",
      "Epoch [3/5], Loss: 0.0255\n",
      "Epoch [4/5], Loss: 0.0067\n",
      "Epoch [5/5], Loss: 0.0062\n",
      "Client 3 Private Data Validation Accuracy: 91.67%\n",
      "Client 3 - decrease-temp to 0.147272\n",
      "\n",
      "--- Client 4 Local Training with T=0.2743, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3289\n",
      "Epoch [2/5], Loss: 0.1169\n",
      "Epoch [3/5], Loss: 0.0703\n",
      "Epoch [4/5], Loss: 0.0475\n",
      "Epoch [5/5], Loss: 0.0435\n",
      "Client 4 Private Data Validation Accuracy: 62.50%\n",
      "\n",
      "--- Client 5 Local Training with T=0.2742, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.5890\n",
      "Epoch [2/5], Loss: 0.2608\n",
      "Epoch [3/5], Loss: 0.1678\n",
      "Epoch [4/5], Loss: 0.1004\n",
      "Epoch [5/5], Loss: 0.1235\n",
      "Client 5 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 6 Local Training with T=0.1835, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.4322\n",
      "Epoch [2/5], Loss: 0.2322\n",
      "Epoch [3/5], Loss: 0.1541\n",
      "Epoch [4/5], Loss: 0.0774\n",
      "Epoch [5/5], Loss: 0.0623\n",
      "Client 6 Private Data Validation Accuracy: 64.06%\n",
      "Client 6 - decrease-temp to 0.174347\n",
      "\n",
      "--- Client 7 Local Training with T=0.2432, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3108\n",
      "Epoch [2/5], Loss: 0.1193\n",
      "Epoch [3/5], Loss: 0.1008\n",
      "Epoch [4/5], Loss: 0.0709\n",
      "Epoch [5/5], Loss: 0.0567\n",
      "Client 7 Private Data Validation Accuracy: 64.06%\n",
      "\n",
      "--- Client 8 Local Training with T=0.1102, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2708\n",
      "Epoch [2/5], Loss: 0.0517\n",
      "Epoch [3/5], Loss: 0.0544\n",
      "Epoch [4/5], Loss: 0.0704\n",
      "Epoch [5/5], Loss: 0.1122\n",
      "Client 8 Private Data Validation Accuracy: 75.39%\n",
      "\n",
      "--- Client 9 Local Training with T=0.0995, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9553\n",
      "Epoch [2/5], Loss: 0.4265\n",
      "Epoch [3/5], Loss: 0.1611\n",
      "Epoch [4/5], Loss: 0.1317\n",
      "Epoch [5/5], Loss: 0.0794\n",
      "Client 9 Private Data Validation Accuracy: 57.81%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 49.49%\n",
      "\n",
      "\n",
      "================================================================================\n",
      "RUNNING ABLATION WITH α=0.5, MODEL=LargeCNN\n",
      "================================================================================\n",
      "\n",
      "\n",
      "--- COMPONENT: FedAvg (T=1.0) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=1.0\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=1.0 ---\n",
      "Epoch [1/5], Loss: 0.1925\n",
      "Epoch [2/5], Loss: 0.0872\n",
      "Epoch [3/5], Loss: 0.0633\n",
      "Epoch [4/5], Loss: 0.0424\n",
      "Epoch [5/5], Loss: 0.0437\n",
      "Client 0 Private Data Validation Accuracy: 58.75%\n",
      "Client 0 Test Set Validation Accuracy: 36.13%\n",
      "\n",
      "--- Client 1 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 1.4351\n",
      "Epoch [2/5], Loss: 0.7486\n",
      "Epoch [3/5], Loss: 0.4259\n",
      "Epoch [4/5], Loss: 0.2844\n",
      "Epoch [5/5], Loss: 0.2103\n",
      "Client 1 Private Data Validation Accuracy: 67.19%\n",
      "Client 1 Test Set Validation Accuracy: 34.06%\n",
      "\n",
      "--- Client 2 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.9791\n",
      "Epoch [2/5], Loss: 0.4150\n",
      "Epoch [3/5], Loss: 0.1984\n",
      "Epoch [4/5], Loss: 0.1504\n",
      "Epoch [5/5], Loss: 0.1057\n",
      "Client 2 Private Data Validation Accuracy: 68.75%\n",
      "Client 2 Test Set Validation Accuracy: 29.33%\n",
      "\n",
      "--- Client 3 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.6705\n",
      "Epoch [2/5], Loss: 0.1542\n",
      "Epoch [3/5], Loss: 0.0820\n",
      "Epoch [4/5], Loss: 0.0435\n",
      "Epoch [5/5], Loss: 0.0299\n",
      "Client 3 Private Data Validation Accuracy: 91.15%\n",
      "Client 3 Test Set Validation Accuracy: 25.88%\n",
      "\n",
      "--- Client 4 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.3337\n",
      "Epoch [2/5], Loss: 0.2127\n",
      "Epoch [3/5], Loss: 0.1174\n",
      "Epoch [4/5], Loss: 0.0816\n",
      "Epoch [5/5], Loss: 0.0628\n",
      "Client 4 Private Data Validation Accuracy: 54.17%\n",
      "Client 4 Test Set Validation Accuracy: 41.19%\n",
      "\n",
      "--- Client 5 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.7145\n",
      "Epoch [2/5], Loss: 0.5189\n",
      "Epoch [3/5], Loss: 0.3069\n",
      "Epoch [4/5], Loss: 0.1857\n",
      "Epoch [5/5], Loss: 0.1392\n",
      "Client 5 Private Data Validation Accuracy: 57.03%\n",
      "Client 5 Test Set Validation Accuracy: 39.21%\n",
      "\n",
      "--- Client 6 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 1.5628\n",
      "Epoch [2/5], Loss: 0.9176\n",
      "Epoch [3/5], Loss: 0.6288\n",
      "Epoch [4/5], Loss: 0.3472\n",
      "Epoch [5/5], Loss: 0.2311\n",
      "Client 6 Private Data Validation Accuracy: 57.81%\n",
      "Client 6 Test Set Validation Accuracy: 35.29%\n",
      "\n",
      "--- Client 7 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.3118\n",
      "Epoch [2/5], Loss: 0.1735\n",
      "Epoch [3/5], Loss: 0.1212\n",
      "Epoch [4/5], Loss: 0.1024\n",
      "Epoch [5/5], Loss: 0.0874\n",
      "Client 7 Private Data Validation Accuracy: 56.77%\n",
      "Client 7 Test Set Validation Accuracy: 40.54%\n",
      "\n",
      "--- Client 8 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.4484\n",
      "Epoch [2/5], Loss: 0.1401\n",
      "Epoch [3/5], Loss: 0.1034\n",
      "Epoch [4/5], Loss: 0.0642\n",
      "Epoch [5/5], Loss: 0.0688\n",
      "Client 8 Private Data Validation Accuracy: 76.17%\n",
      "Client 8 Test Set Validation Accuracy: 32.27%\n",
      "\n",
      "--- Client 9 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.5652\n",
      "Epoch [2/5], Loss: 0.2258\n",
      "Epoch [3/5], Loss: 0.1398\n",
      "Epoch [4/5], Loss: 0.0963\n",
      "Epoch [5/5], Loss: 0.0604\n",
      "Client 9 Private Data Validation Accuracy: 71.88%\n",
      "Client 9 Test Set Validation Accuracy: 33.62%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 45.74%\n",
      "\n",
      "--- COMPONENT: Fixed Low Temperature (T=0.05) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=0.05\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.05 ---\n",
      "Epoch [1/5], Loss: 0.6058\n",
      "Epoch [2/5], Loss: 0.5050\n",
      "Epoch [3/5], Loss: 0.3160\n",
      "Epoch [4/5], Loss: 0.2576\n",
      "Epoch [5/5], Loss: 0.2992\n",
      "Client 0 Private Data Validation Accuracy: 55.31%\n",
      "Client 0 Test Set Validation Accuracy: 23.85%\n",
      "\n",
      "--- Client 1 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.6124\n",
      "Epoch [2/5], Loss: 0.5953\n",
      "Epoch [3/5], Loss: 0.3636\n",
      "Epoch [4/5], Loss: 0.2569\n",
      "Epoch [5/5], Loss: 0.2188\n",
      "Client 1 Private Data Validation Accuracy: 60.94%\n",
      "Client 1 Test Set Validation Accuracy: 30.65%\n",
      "\n",
      "--- Client 2 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.8942\n",
      "Epoch [2/5], Loss: 0.4293\n",
      "Epoch [3/5], Loss: 0.3987\n",
      "Epoch [4/5], Loss: 0.2294\n",
      "Epoch [5/5], Loss: 0.1493\n",
      "Client 2 Private Data Validation Accuracy: 65.62%\n",
      "Client 2 Test Set Validation Accuracy: 24.37%\n",
      "\n",
      "--- Client 3 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.4558\n",
      "Epoch [2/5], Loss: 0.0910\n",
      "Epoch [3/5], Loss: 0.0463\n",
      "Epoch [4/5], Loss: 0.0239\n",
      "Epoch [5/5], Loss: 0.0148\n",
      "Client 3 Private Data Validation Accuracy: 89.06%\n",
      "Client 3 Test Set Validation Accuracy: 17.58%\n",
      "\n",
      "--- Client 4 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5997\n",
      "Epoch [2/5], Loss: 0.4887\n",
      "Epoch [3/5], Loss: 0.3354\n",
      "Epoch [4/5], Loss: 0.2896\n",
      "Epoch [5/5], Loss: 0.2054\n",
      "Client 4 Private Data Validation Accuracy: 50.52%\n",
      "Client 4 Test Set Validation Accuracy: 37.01%\n",
      "\n",
      "--- Client 5 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.0971\n",
      "Epoch [2/5], Loss: 0.9693\n",
      "Epoch [3/5], Loss: 0.6695\n",
      "Epoch [4/5], Loss: 0.4271\n",
      "Epoch [5/5], Loss: 0.3352\n",
      "Client 5 Private Data Validation Accuracy: 45.31%\n",
      "Client 5 Test Set Validation Accuracy: 28.95%\n",
      "\n",
      "--- Client 6 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.5564\n",
      "Epoch [2/5], Loss: 0.5659\n",
      "Epoch [3/5], Loss: 0.3954\n",
      "Epoch [4/5], Loss: 0.2843\n",
      "Epoch [5/5], Loss: 0.3019\n",
      "Client 6 Private Data Validation Accuracy: 56.25%\n",
      "Client 6 Test Set Validation Accuracy: 27.36%\n",
      "\n",
      "--- Client 7 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5958\n",
      "Epoch [2/5], Loss: 0.4390\n",
      "Epoch [3/5], Loss: 0.3518\n",
      "Epoch [4/5], Loss: 0.3271\n",
      "Epoch [5/5], Loss: 0.2022\n",
      "Client 7 Private Data Validation Accuracy: 53.65%\n",
      "Client 7 Test Set Validation Accuracy: 35.92%\n",
      "\n",
      "--- Client 8 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.4332\n",
      "Epoch [2/5], Loss: 0.1947\n",
      "Epoch [3/5], Loss: 0.1579\n",
      "Epoch [4/5], Loss: 0.1054\n",
      "Epoch [5/5], Loss: 0.1185\n",
      "Client 8 Private Data Validation Accuracy: 75.78%\n",
      "Client 8 Test Set Validation Accuracy: 29.44%\n",
      "\n",
      "--- Client 9 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.9385\n",
      "Epoch [2/5], Loss: 0.4228\n",
      "Epoch [3/5], Loss: 0.3627\n",
      "Epoch [4/5], Loss: 0.2999\n",
      "Epoch [5/5], Loss: 0.1831\n",
      "Client 9 Private Data Validation Accuracy: 64.84%\n",
      "Client 9 Test Set Validation Accuracy: 27.10%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 39.22%\n",
      "\n",
      "--- COMPONENT: Heterogeneity-based Temperature (No Decay) ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9007, Fixed temp: 0.1651\n",
      "Client 1 - Het Score: 0.7295, Fixed temp: 0.2325\n",
      "Client 2 - Het Score: 0.8682, Fixed temp: 0.1762\n",
      "Client 3 - Het Score: 0.8552, Fixed temp: 0.1808\n",
      "Client 4 - Het Score: 0.5698, Fixed temp: 0.3199\n",
      "Client 5 - Het Score: 0.5956, Fixed temp: 0.3038\n",
      "Client 6 - Het Score: 0.7451, Fixed temp: 0.2253\n",
      "Client 7 - Het Score: 0.6556, Fixed temp: 0.2695\n",
      "Client 8 - Het Score: 1.0000, Fixed temp: 0.1353\n",
      "Client 9 - Het Score: 1.0000, Fixed temp: 0.1353\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.1651, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1165\n",
      "Epoch [2/5], Loss: 0.0283\n",
      "Epoch [3/5], Loss: 0.0179\n",
      "Epoch [4/5], Loss: 0.0127\n",
      "Epoch [5/5], Loss: 0.0098\n",
      "Client 0 Private Data Validation Accuracy: 59.06%\n",
      "\n",
      "--- Client 1 Local Training with T=0.2325, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.9111\n",
      "Epoch [2/5], Loss: 0.2373\n",
      "Epoch [3/5], Loss: 0.1358\n",
      "Epoch [4/5], Loss: 0.0935\n",
      "Epoch [5/5], Loss: 0.0638\n",
      "Client 1 Private Data Validation Accuracy: 64.06%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1762, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4907\n",
      "Epoch [2/5], Loss: 0.1602\n",
      "Epoch [3/5], Loss: 0.0729\n",
      "Epoch [4/5], Loss: 0.0689\n",
      "Epoch [5/5], Loss: 0.0573\n",
      "Client 2 Private Data Validation Accuracy: 71.35%\n",
      "\n",
      "--- Client 3 Local Training with T=0.1808, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3746\n",
      "Epoch [2/5], Loss: 0.0169\n",
      "Epoch [3/5], Loss: 0.0184\n",
      "Epoch [4/5], Loss: 0.0051\n",
      "Epoch [5/5], Loss: 0.0046\n",
      "Client 3 Private Data Validation Accuracy: 91.15%\n",
      "\n",
      "--- Client 4 Local Training with T=0.3199, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2190\n",
      "Epoch [2/5], Loss: 0.0587\n",
      "Epoch [3/5], Loss: 0.0351\n",
      "Epoch [4/5], Loss: 0.0239\n",
      "Epoch [5/5], Loss: 0.0231\n",
      "Client 4 Private Data Validation Accuracy: 60.42%\n",
      "\n",
      "--- Client 5 Local Training with T=0.3038, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4567\n",
      "Epoch [2/5], Loss: 0.1944\n",
      "Epoch [3/5], Loss: 0.1362\n",
      "Epoch [4/5], Loss: 0.0699\n",
      "Epoch [5/5], Loss: 0.0486\n",
      "Client 5 Private Data Validation Accuracy: 60.94%\n",
      "\n",
      "--- Client 6 Local Training with T=0.2253, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0651\n",
      "Epoch [2/5], Loss: 0.2387\n",
      "Epoch [3/5], Loss: 0.1025\n",
      "Epoch [4/5], Loss: 0.0758\n",
      "Epoch [5/5], Loss: 0.0306\n",
      "Client 6 Private Data Validation Accuracy: 65.62%\n",
      "\n",
      "--- Client 7 Local Training with T=0.2695, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1804\n",
      "Epoch [2/5], Loss: 0.0626\n",
      "Epoch [3/5], Loss: 0.0443\n",
      "Epoch [4/5], Loss: 0.0277\n",
      "Epoch [5/5], Loss: 0.0272\n",
      "Client 7 Private Data Validation Accuracy: 65.62%\n",
      "\n",
      "--- Client 8 Local Training with T=0.1353, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1569\n",
      "Epoch [2/5], Loss: 0.0273\n",
      "Epoch [3/5], Loss: 0.0862\n",
      "Epoch [4/5], Loss: 0.0954\n",
      "Epoch [5/5], Loss: 0.0559\n",
      "Client 8 Private Data Validation Accuracy: 71.48%\n",
      "\n",
      "--- Client 9 Local Training with T=0.1353, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4976\n",
      "Epoch [2/5], Loss: 0.1710\n",
      "Epoch [3/5], Loss: 0.0906\n",
      "Epoch [4/5], Loss: 0.0743\n",
      "Epoch [5/5], Loss: 0.0429\n",
      "Client 9 Private Data Validation Accuracy: 67.19%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 47.55%\n",
      "\n",
      "--- COMPONENT: Full FedChill ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.9007, Initial temp: 0.1651\n",
      "Client 1 - Het Score: 0.7295, Initial temp: 0.2325\n",
      "Client 2 - Het Score: 0.8682, Initial temp: 0.1762\n",
      "Client 3 - Het Score: 0.8552, Initial temp: 0.1808\n",
      "Client 4 - Het Score: 0.5698, Initial temp: 0.3199\n",
      "Client 5 - Het Score: 0.5956, Initial temp: 0.3038\n",
      "Client 6 - Het Score: 0.7451, Initial temp: 0.2253\n",
      "Client 7 - Het Score: 0.6556, Initial temp: 0.2695\n",
      "Client 8 - Het Score: 1.0000, Initial temp: 0.1353\n",
      "Client 9 - Het Score: 1.0000, Initial temp: 0.1353\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.1490, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1189\n",
      "Epoch [2/5], Loss: 0.0343\n",
      "Epoch [3/5], Loss: 0.0380\n",
      "Epoch [4/5], Loss: 0.0239\n",
      "Epoch [5/5], Loss: 0.0356\n",
      "Client 0 Private Data Validation Accuracy: 58.12%\n",
      "\n",
      "--- Client 1 Local Training with T=0.2098, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1879\n",
      "Epoch [2/5], Loss: 0.4187\n",
      "Epoch [3/5], Loss: 0.0874\n",
      "Epoch [4/5], Loss: 0.0629\n",
      "Epoch [5/5], Loss: 0.0586\n",
      "Client 1 Private Data Validation Accuracy: 65.62%\n",
      "\n",
      "--- Client 2 Local Training with T=0.1435, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6056\n",
      "Epoch [2/5], Loss: 0.2840\n",
      "Epoch [3/5], Loss: 0.1513\n",
      "Epoch [4/5], Loss: 0.1054\n",
      "Epoch [5/5], Loss: 0.0982\n",
      "Client 2 Private Data Validation Accuracy: 70.83%\n",
      "\n",
      "--- Client 3 Local Training with T=0.1632, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4020\n",
      "Epoch [2/5], Loss: 0.0346\n",
      "Epoch [3/5], Loss: 0.0083\n",
      "Epoch [4/5], Loss: 0.0142\n",
      "Epoch [5/5], Loss: 0.0053\n",
      "Client 3 Private Data Validation Accuracy: 91.15%\n",
      "\n",
      "--- Client 4 Local Training with T=0.2352, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1479\n",
      "Epoch [2/5], Loss: 0.0472\n",
      "Epoch [3/5], Loss: 0.0287\n",
      "Epoch [4/5], Loss: 0.0252\n",
      "Epoch [5/5], Loss: 0.0196\n",
      "Client 4 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 5 Local Training with T=0.2605, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4273\n",
      "Epoch [2/5], Loss: 0.2003\n",
      "Epoch [3/5], Loss: 0.1200\n",
      "Epoch [4/5], Loss: 0.0521\n",
      "Epoch [5/5], Loss: 0.0424\n",
      "Client 5 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 6 Local Training with T=0.1656, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.1536\n",
      "Epoch [2/5], Loss: 0.2739\n",
      "Epoch [3/5], Loss: 0.1368\n",
      "Epoch [4/5], Loss: 0.0940\n",
      "Epoch [5/5], Loss: 0.0227\n",
      "Client 6 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 7 Local Training with T=0.1981, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1430\n",
      "Epoch [2/5], Loss: 0.0560\n",
      "Epoch [3/5], Loss: 0.0307\n",
      "Epoch [4/5], Loss: 0.0282\n",
      "Epoch [5/5], Loss: 0.0217\n",
      "Client 7 Private Data Validation Accuracy: 65.62%\n",
      "\n",
      "--- Client 8 Local Training with T=0.1221, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1353\n",
      "Epoch [2/5], Loss: 0.0318\n",
      "Epoch [3/5], Loss: 0.0268\n",
      "Epoch [4/5], Loss: 0.0289\n",
      "Epoch [5/5], Loss: 0.1342\n",
      "Client 8 Private Data Validation Accuracy: 54.30%\n",
      "Client 8 - decrease-temp to 0.116033\n",
      "\n",
      "--- Client 9 Local Training with T=0.1221, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3376\n",
      "Epoch [2/5], Loss: 0.0931\n",
      "Epoch [3/5], Loss: 0.0826\n",
      "Epoch [4/5], Loss: 0.0795\n",
      "Epoch [5/5], Loss: 0.0587\n",
      "Client 9 Private Data Validation Accuracy: 61.72%\n",
      "Client 9 - decrease-temp to 0.116033\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 45.39%\n",
      "\n",
      "\n",
      "================================================================================\n",
      "RUNNING ABLATION WITH α=5.0, MODEL=SmallCNN\n",
      "================================================================================\n",
      "\n",
      "\n",
      "--- COMPONENT: FedAvg (T=1.0) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=1.0\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=1.0 ---\n",
      "Epoch [1/5], Loss: 0.7955\n",
      "Epoch [2/5], Loss: 0.5224\n",
      "Epoch [3/5], Loss: 0.3036\n",
      "Epoch [4/5], Loss: 0.2127\n",
      "Epoch [5/5], Loss: 0.1520\n",
      "Client 0 Private Data Validation Accuracy: 48.44%\n",
      "Client 0 Test Set Validation Accuracy: 50.33%\n",
      "\n",
      "--- Client 1 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.6408\n",
      "Epoch [2/5], Loss: 0.4728\n",
      "Epoch [3/5], Loss: 0.3076\n",
      "Epoch [4/5], Loss: 0.1844\n",
      "Epoch [5/5], Loss: 0.1678\n",
      "Client 1 Private Data Validation Accuracy: 55.21%\n",
      "Client 1 Test Set Validation Accuracy: 50.26%\n",
      "\n",
      "--- Client 2 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.3644\n",
      "Epoch [2/5], Loss: 0.2768\n",
      "Epoch [3/5], Loss: 0.1378\n",
      "Epoch [4/5], Loss: 0.1169\n",
      "Epoch [5/5], Loss: 0.0965\n",
      "Client 2 Private Data Validation Accuracy: 48.96%\n",
      "Client 2 Test Set Validation Accuracy: 50.84%\n",
      "\n",
      "--- Client 3 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.5374\n",
      "Epoch [2/5], Loss: 0.3961\n",
      "Epoch [3/5], Loss: 0.2496\n",
      "Epoch [4/5], Loss: 0.2282\n",
      "Epoch [5/5], Loss: 0.1708\n",
      "Client 3 Private Data Validation Accuracy: 57.81%\n",
      "Client 3 Test Set Validation Accuracy: 48.55%\n",
      "\n",
      "--- Client 4 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.4104\n",
      "Epoch [2/5], Loss: 0.2848\n",
      "Epoch [3/5], Loss: 0.1838\n",
      "Epoch [4/5], Loss: 0.1612\n",
      "Epoch [5/5], Loss: 0.1238\n",
      "Client 4 Private Data Validation Accuracy: 49.48%\n",
      "Client 4 Test Set Validation Accuracy: 49.21%\n",
      "\n",
      "--- Client 5 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.6262\n",
      "Epoch [2/5], Loss: 0.3080\n",
      "Epoch [3/5], Loss: 0.2439\n",
      "Epoch [4/5], Loss: 0.1517\n",
      "Epoch [5/5], Loss: 0.1358\n",
      "Client 5 Private Data Validation Accuracy: 50.00%\n",
      "Client 5 Test Set Validation Accuracy: 50.27%\n",
      "\n",
      "--- Client 6 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.5438\n",
      "Epoch [2/5], Loss: 0.3419\n",
      "Epoch [3/5], Loss: 0.2024\n",
      "Epoch [4/5], Loss: 0.1879\n",
      "Epoch [5/5], Loss: 0.1294\n",
      "Client 6 Private Data Validation Accuracy: 57.29%\n",
      "Client 6 Test Set Validation Accuracy: 48.09%\n",
      "\n",
      "--- Client 7 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.4138\n",
      "Epoch [2/5], Loss: 0.3159\n",
      "Epoch [3/5], Loss: 0.2174\n",
      "Epoch [4/5], Loss: 0.1529\n",
      "Epoch [5/5], Loss: 0.1667\n",
      "Client 7 Private Data Validation Accuracy: 46.88%\n",
      "Client 7 Test Set Validation Accuracy: 48.78%\n",
      "\n",
      "--- Client 8 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.6557\n",
      "Epoch [2/5], Loss: 0.3814\n",
      "Epoch [3/5], Loss: 0.2879\n",
      "Epoch [4/5], Loss: 0.1909\n",
      "Epoch [5/5], Loss: 0.1487\n",
      "Client 8 Private Data Validation Accuracy: 54.69%\n",
      "Client 8 Test Set Validation Accuracy: 50.20%\n",
      "\n",
      "--- Client 9 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.4730\n",
      "Epoch [2/5], Loss: 0.3198\n",
      "Epoch [3/5], Loss: 0.2000\n",
      "Epoch [4/5], Loss: 0.1606\n",
      "Epoch [5/5], Loss: 0.1616\n",
      "Client 9 Private Data Validation Accuracy: 52.08%\n",
      "Client 9 Test Set Validation Accuracy: 50.99%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 54.56%\n",
      "\n",
      "--- COMPONENT: Fixed Low Temperature (T=0.05) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=0.05\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.05 ---\n",
      "Epoch [1/5], Loss: 0.8181\n",
      "Epoch [2/5], Loss: 0.4695\n",
      "Epoch [3/5], Loss: 0.2647\n",
      "Epoch [4/5], Loss: 0.2354\n",
      "Epoch [5/5], Loss: 0.1648\n",
      "Client 0 Private Data Validation Accuracy: 50.00%\n",
      "Client 0 Test Set Validation Accuracy: 48.35%\n",
      "\n",
      "--- Client 1 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 1.0300\n",
      "Epoch [2/5], Loss: 0.7658\n",
      "Epoch [3/5], Loss: 0.4914\n",
      "Epoch [4/5], Loss: 0.3159\n",
      "Epoch [5/5], Loss: 0.2997\n",
      "Client 1 Private Data Validation Accuracy: 54.69%\n",
      "Client 1 Test Set Validation Accuracy: 43.57%\n",
      "\n",
      "--- Client 2 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.4613\n",
      "Epoch [2/5], Loss: 0.4202\n",
      "Epoch [3/5], Loss: 0.1864\n",
      "Epoch [4/5], Loss: 0.2185\n",
      "Epoch [5/5], Loss: 0.2037\n",
      "Client 2 Private Data Validation Accuracy: 49.48%\n",
      "Client 2 Test Set Validation Accuracy: 44.64%\n",
      "\n",
      "--- Client 3 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5571\n",
      "Epoch [2/5], Loss: 0.5397\n",
      "Epoch [3/5], Loss: 0.4180\n",
      "Epoch [4/5], Loss: 0.2767\n",
      "Epoch [5/5], Loss: 0.3328\n",
      "Client 3 Private Data Validation Accuracy: 53.91%\n",
      "Client 3 Test Set Validation Accuracy: 47.62%\n",
      "\n",
      "--- Client 4 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5417\n",
      "Epoch [2/5], Loss: 0.3408\n",
      "Epoch [3/5], Loss: 0.2502\n",
      "Epoch [4/5], Loss: 0.2349\n",
      "Epoch [5/5], Loss: 0.1405\n",
      "Client 4 Private Data Validation Accuracy: 50.00%\n",
      "Client 4 Test Set Validation Accuracy: 48.65%\n",
      "\n",
      "--- Client 5 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.9282\n",
      "Epoch [2/5], Loss: 0.4782\n",
      "Epoch [3/5], Loss: 0.4738\n",
      "Epoch [4/5], Loss: 0.2144\n",
      "Epoch [5/5], Loss: 0.2965\n",
      "Client 5 Private Data Validation Accuracy: 41.41%\n",
      "Client 5 Test Set Validation Accuracy: 45.57%\n",
      "\n",
      "--- Client 6 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5349\n",
      "Epoch [2/5], Loss: 0.5927\n",
      "Epoch [3/5], Loss: 0.4021\n",
      "Epoch [4/5], Loss: 0.2827\n",
      "Epoch [5/5], Loss: 0.3511\n",
      "Client 6 Private Data Validation Accuracy: 54.69%\n",
      "Client 6 Test Set Validation Accuracy: 41.42%\n",
      "\n",
      "--- Client 7 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.4340\n",
      "Epoch [2/5], Loss: 0.4220\n",
      "Epoch [3/5], Loss: 0.2570\n",
      "Epoch [4/5], Loss: 0.2352\n",
      "Epoch [5/5], Loss: 0.2324\n",
      "Client 7 Private Data Validation Accuracy: 54.69%\n",
      "Client 7 Test Set Validation Accuracy: 49.71%\n",
      "\n",
      "--- Client 8 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.8855\n",
      "Epoch [2/5], Loss: 0.5197\n",
      "Epoch [3/5], Loss: 0.4570\n",
      "Epoch [4/5], Loss: 0.2952\n",
      "Epoch [5/5], Loss: 0.2275\n",
      "Client 8 Private Data Validation Accuracy: 55.47%\n",
      "Client 8 Test Set Validation Accuracy: 52.65%\n",
      "\n",
      "--- Client 9 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.5371\n",
      "Epoch [2/5], Loss: 0.4136\n",
      "Epoch [3/5], Loss: 0.2200\n",
      "Epoch [4/5], Loss: 0.3597\n",
      "Epoch [5/5], Loss: 0.3309\n",
      "Client 9 Private Data Validation Accuracy: 41.15%\n",
      "Client 9 Test Set Validation Accuracy: 45.94%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 56.10%\n",
      "\n",
      "--- COMPONENT: Heterogeneity-based Temperature (No Decay) ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.5138, Fixed temp: 0.3579\n",
      "Client 1 - Het Score: 0.4359, Fixed temp: 0.4182\n",
      "Client 2 - Het Score: 0.3881, Fixed temp: 0.4602\n",
      "Client 3 - Het Score: 0.3954, Fixed temp: 0.4535\n",
      "Client 4 - Het Score: 0.2446, Fixed temp: 0.6131\n",
      "Client 5 - Het Score: 0.2782, Fixed temp: 0.5733\n",
      "Client 6 - Het Score: 0.4171, Fixed temp: 0.4343\n",
      "Client 7 - Het Score: 0.3625, Fixed temp: 0.4843\n",
      "Client 8 - Het Score: 0.2555, Fixed temp: 0.5999\n",
      "Client 9 - Het Score: 0.3068, Fixed temp: 0.5414\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.3579, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.6551\n",
      "Epoch [2/5], Loss: 0.4385\n",
      "Epoch [3/5], Loss: 0.1962\n",
      "Epoch [4/5], Loss: 0.0844\n",
      "Epoch [5/5], Loss: 0.0717\n",
      "Client 0 Private Data Validation Accuracy: 48.44%\n",
      "\n",
      "--- Client 1 Local Training with T=0.4182, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4094\n",
      "Epoch [2/5], Loss: 0.1817\n",
      "Epoch [3/5], Loss: 0.2194\n",
      "Epoch [4/5], Loss: 0.1290\n",
      "Epoch [5/5], Loss: 0.1106\n",
      "Client 1 Private Data Validation Accuracy: 52.08%\n",
      "\n",
      "--- Client 2 Local Training with T=0.4602, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1943\n",
      "Epoch [2/5], Loss: 0.1652\n",
      "Epoch [3/5], Loss: 0.0738\n",
      "Epoch [4/5], Loss: 0.0575\n",
      "Epoch [5/5], Loss: 0.0386\n",
      "Client 2 Private Data Validation Accuracy: 50.00%\n",
      "\n",
      "--- Client 3 Local Training with T=0.4535, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3123\n",
      "Epoch [2/5], Loss: 0.2753\n",
      "Epoch [3/5], Loss: 0.1509\n",
      "Epoch [4/5], Loss: 0.1387\n",
      "Epoch [5/5], Loss: 0.0780\n",
      "Client 3 Private Data Validation Accuracy: 56.25%\n",
      "\n",
      "--- Client 4 Local Training with T=0.6131, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2763\n",
      "Epoch [2/5], Loss: 0.1639\n",
      "Epoch [3/5], Loss: 0.1046\n",
      "Epoch [4/5], Loss: 0.0868\n",
      "Epoch [5/5], Loss: 0.0645\n",
      "Client 4 Private Data Validation Accuracy: 56.77%\n",
      "\n",
      "--- Client 5 Local Training with T=0.5733, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3793\n",
      "Epoch [2/5], Loss: 0.1975\n",
      "Epoch [3/5], Loss: 0.1162\n",
      "Epoch [4/5], Loss: 0.0878\n",
      "Epoch [5/5], Loss: 0.0781\n",
      "Client 5 Private Data Validation Accuracy: 52.34%\n",
      "\n",
      "--- Client 6 Local Training with T=0.4343, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4264\n",
      "Epoch [2/5], Loss: 0.2231\n",
      "Epoch [3/5], Loss: 0.0953\n",
      "Epoch [4/5], Loss: 0.0909\n",
      "Epoch [5/5], Loss: 0.0581\n",
      "Client 6 Private Data Validation Accuracy: 58.33%\n",
      "\n",
      "--- Client 7 Local Training with T=0.4843, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3057\n",
      "Epoch [2/5], Loss: 0.2103\n",
      "Epoch [3/5], Loss: 0.1208\n",
      "Epoch [4/5], Loss: 0.0759\n",
      "Epoch [5/5], Loss: 0.0905\n",
      "Client 7 Private Data Validation Accuracy: 54.17%\n",
      "\n",
      "--- Client 8 Local Training with T=0.5999, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3971\n",
      "Epoch [2/5], Loss: 0.2103\n",
      "Epoch [3/5], Loss: 0.1631\n",
      "Epoch [4/5], Loss: 0.1279\n",
      "Epoch [5/5], Loss: 0.0916\n",
      "Client 8 Private Data Validation Accuracy: 55.47%\n",
      "\n",
      "--- Client 9 Local Training with T=0.5414, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3327\n",
      "Epoch [2/5], Loss: 0.1702\n",
      "Epoch [3/5], Loss: 0.1155\n",
      "Epoch [4/5], Loss: 0.0838\n",
      "Epoch [5/5], Loss: 0.0865\n",
      "Client 9 Private Data Validation Accuracy: 58.85%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 55.67%\n",
      "\n",
      "--- COMPONENT: Full FedChill ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.5138, Initial temp: 0.3579\n",
      "Client 1 - Het Score: 0.4359, Initial temp: 0.4182\n",
      "Client 2 - Het Score: 0.3881, Initial temp: 0.4602\n",
      "Client 3 - Het Score: 0.3954, Initial temp: 0.4535\n",
      "Client 4 - Het Score: 0.2446, Initial temp: 0.6131\n",
      "Client 5 - Het Score: 0.2782, Initial temp: 0.5733\n",
      "Client 6 - Het Score: 0.4171, Initial temp: 0.4343\n",
      "Client 7 - Het Score: 0.3625, Initial temp: 0.4843\n",
      "Client 8 - Het Score: 0.2555, Initial temp: 0.5999\n",
      "Client 9 - Het Score: 0.3068, Initial temp: 0.5414\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.2769, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 1.0046\n",
      "Epoch [2/5], Loss: 0.4724\n",
      "Epoch [3/5], Loss: 0.3057\n",
      "Epoch [4/5], Loss: 0.1599\n",
      "Epoch [5/5], Loss: 0.1116\n",
      "Client 0 Private Data Validation Accuracy: 44.53%\n",
      "\n",
      "--- Client 1 Local Training with T=0.3585, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4908\n",
      "Epoch [2/5], Loss: 0.2093\n",
      "Epoch [3/5], Loss: 0.1881\n",
      "Epoch [4/5], Loss: 0.0908\n",
      "Epoch [5/5], Loss: 0.0869\n",
      "Client 1 Private Data Validation Accuracy: 51.04%\n",
      "Client 1 - decrease-temp to 0.340621\n",
      "\n",
      "--- Client 2 Local Training with T=0.3945, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1826\n",
      "Epoch [2/5], Loss: 0.1605\n",
      "Epoch [3/5], Loss: 0.0587\n",
      "Epoch [4/5], Loss: 0.0584\n",
      "Epoch [5/5], Loss: 0.0399\n",
      "Client 2 Private Data Validation Accuracy: 50.00%\n",
      "\n",
      "--- Client 3 Local Training with T=0.3693, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3356\n",
      "Epoch [2/5], Loss: 0.2399\n",
      "Epoch [3/5], Loss: 0.2185\n",
      "Epoch [4/5], Loss: 0.1760\n",
      "Epoch [5/5], Loss: 0.0769\n",
      "Client 3 Private Data Validation Accuracy: 58.59%\n",
      "\n",
      "--- Client 4 Local Training with T=0.4744, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2605\n",
      "Epoch [2/5], Loss: 0.1560\n",
      "Epoch [3/5], Loss: 0.0882\n",
      "Epoch [4/5], Loss: 0.0741\n",
      "Epoch [5/5], Loss: 0.0561\n",
      "Client 4 Private Data Validation Accuracy: 57.29%\n",
      "\n",
      "--- Client 5 Local Training with T=0.5446, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3605\n",
      "Epoch [2/5], Loss: 0.2018\n",
      "Epoch [3/5], Loss: 0.1366\n",
      "Epoch [4/5], Loss: 0.0900\n",
      "Epoch [5/5], Loss: 0.0823\n",
      "Client 5 Private Data Validation Accuracy: 47.66%\n",
      "Client 5 - decrease-temp to 0.517412\n",
      "\n",
      "--- Client 6 Local Training with T=0.3537, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4498\n",
      "Epoch [2/5], Loss: 0.2823\n",
      "Epoch [3/5], Loss: 0.1685\n",
      "Epoch [4/5], Loss: 0.1102\n",
      "Epoch [5/5], Loss: 0.0896\n",
      "Client 6 Private Data Validation Accuracy: 60.42%\n",
      "\n",
      "--- Client 7 Local Training with T=0.3747, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3367\n",
      "Epoch [2/5], Loss: 0.2230\n",
      "Epoch [3/5], Loss: 0.1388\n",
      "Epoch [4/5], Loss: 0.0712\n",
      "Epoch [5/5], Loss: 0.0994\n",
      "Client 7 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 8 Local Training with T=0.5143, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.4064\n",
      "Epoch [2/5], Loss: 0.2170\n",
      "Epoch [3/5], Loss: 0.1496\n",
      "Epoch [4/5], Loss: 0.1065\n",
      "Epoch [5/5], Loss: 0.0977\n",
      "Client 8 Private Data Validation Accuracy: 53.91%\n",
      "\n",
      "--- Client 9 Local Training with T=0.4886, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2964\n",
      "Epoch [2/5], Loss: 0.1240\n",
      "Epoch [3/5], Loss: 0.1092\n",
      "Epoch [4/5], Loss: 0.0822\n",
      "Epoch [5/5], Loss: 0.0814\n",
      "Client 9 Private Data Validation Accuracy: 57.29%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 55.81%\n",
      "\n",
      "\n",
      "================================================================================\n",
      "RUNNING ABLATION WITH α=5.0, MODEL=LargeCNN\n",
      "================================================================================\n",
      "\n",
      "\n",
      "--- COMPONENT: FedAvg (T=1.0) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=1.0\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=1.0 ---\n",
      "Epoch [1/5], Loss: 0.6026\n",
      "Epoch [2/5], Loss: 0.5534\n",
      "Epoch [3/5], Loss: 0.3355\n",
      "Epoch [4/5], Loss: 0.1345\n",
      "Epoch [5/5], Loss: 0.0752\n",
      "Client 0 Private Data Validation Accuracy: 45.31%\n",
      "Client 0 Test Set Validation Accuracy: 50.24%\n",
      "\n",
      "--- Client 1 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.3020\n",
      "Epoch [2/5], Loss: 0.3530\n",
      "Epoch [3/5], Loss: 0.1960\n",
      "Epoch [4/5], Loss: 0.1006\n",
      "Epoch [5/5], Loss: 0.0806\n",
      "Client 1 Private Data Validation Accuracy: 47.40%\n",
      "Client 1 Test Set Validation Accuracy: 49.23%\n",
      "\n",
      "--- Client 2 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.1576\n",
      "Epoch [2/5], Loss: 0.1033\n",
      "Epoch [3/5], Loss: 0.0911\n",
      "Epoch [4/5], Loss: 0.0493\n",
      "Epoch [5/5], Loss: 0.0430\n",
      "Client 2 Private Data Validation Accuracy: 51.56%\n",
      "Client 2 Test Set Validation Accuracy: 51.05%\n",
      "\n",
      "--- Client 3 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.2246\n",
      "Epoch [2/5], Loss: 0.1465\n",
      "Epoch [3/5], Loss: 0.0998\n",
      "Epoch [4/5], Loss: 0.0760\n",
      "Epoch [5/5], Loss: 0.0671\n",
      "Client 3 Private Data Validation Accuracy: 55.47%\n",
      "Client 3 Test Set Validation Accuracy: 51.00%\n",
      "\n",
      "--- Client 4 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.2095\n",
      "Epoch [2/5], Loss: 0.1078\n",
      "Epoch [3/5], Loss: 0.0737\n",
      "Epoch [4/5], Loss: 0.0759\n",
      "Epoch [5/5], Loss: 0.0603\n",
      "Client 4 Private Data Validation Accuracy: 51.04%\n",
      "Client 4 Test Set Validation Accuracy: 52.51%\n",
      "\n",
      "--- Client 5 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.2495\n",
      "Epoch [2/5], Loss: 0.1873\n",
      "Epoch [3/5], Loss: 0.1377\n",
      "Epoch [4/5], Loss: 0.0763\n",
      "Epoch [5/5], Loss: 0.0750\n",
      "Client 5 Private Data Validation Accuracy: 45.31%\n",
      "Client 5 Test Set Validation Accuracy: 47.43%\n",
      "\n",
      "--- Client 6 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.2776\n",
      "Epoch [2/5], Loss: 0.1762\n",
      "Epoch [3/5], Loss: 0.1276\n",
      "Epoch [4/5], Loss: 0.1010\n",
      "Epoch [5/5], Loss: 0.0784\n",
      "Client 6 Private Data Validation Accuracy: 58.33%\n",
      "Client 6 Test Set Validation Accuracy: 48.02%\n",
      "\n",
      "--- Client 7 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.1493\n",
      "Epoch [2/5], Loss: 0.1341\n",
      "Epoch [3/5], Loss: 0.0926\n",
      "Epoch [4/5], Loss: 0.0880\n",
      "Epoch [5/5], Loss: 0.0799\n",
      "Client 7 Private Data Validation Accuracy: 50.52%\n",
      "Client 7 Test Set Validation Accuracy: 50.58%\n",
      "\n",
      "--- Client 8 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.2678\n",
      "Epoch [2/5], Loss: 0.2126\n",
      "Epoch [3/5], Loss: 0.2040\n",
      "Epoch [4/5], Loss: 0.0888\n",
      "Epoch [5/5], Loss: 0.0793\n",
      "Client 8 Private Data Validation Accuracy: 54.69%\n",
      "Client 8 Test Set Validation Accuracy: 49.42%\n",
      "\n",
      "--- Client 9 Local Training with T=1.0 ---\n",
      "Epoch [1/5], Loss: 0.1275\n",
      "Epoch [2/5], Loss: 0.0961\n",
      "Epoch [3/5], Loss: 0.0760\n",
      "Epoch [4/5], Loss: 0.0685\n",
      "Epoch [5/5], Loss: 0.0534\n",
      "Client 9 Private Data Validation Accuracy: 47.40%\n",
      "Client 9 Test Set Validation Accuracy: 50.68%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 53.44%\n",
      "\n",
      "--- COMPONENT: Fixed Low Temperature (T=0.05) ---\n",
      "Data partitioning complete.\n",
      "Running Flex&Chill with temperature T=0.05\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.05 ---\n",
      "Epoch [1/5], Loss: 0.6910\n",
      "Epoch [2/5], Loss: 0.4106\n",
      "Epoch [3/5], Loss: 0.3596\n",
      "Epoch [4/5], Loss: 0.2358\n",
      "Epoch [5/5], Loss: 0.2004\n",
      "Client 0 Private Data Validation Accuracy: 46.88%\n",
      "Client 0 Test Set Validation Accuracy: 42.65%\n",
      "\n",
      "--- Client 1 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.4154\n",
      "Epoch [2/5], Loss: 0.4582\n",
      "Epoch [3/5], Loss: 0.4551\n",
      "Epoch [4/5], Loss: 0.2062\n",
      "Epoch [5/5], Loss: 0.1915\n",
      "Client 1 Private Data Validation Accuracy: 44.79%\n",
      "Client 1 Test Set Validation Accuracy: 43.47%\n",
      "\n",
      "--- Client 2 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.2866\n",
      "Epoch [2/5], Loss: 0.2908\n",
      "Epoch [3/5], Loss: 0.4243\n",
      "Epoch [4/5], Loss: 0.3728\n",
      "Epoch [5/5], Loss: 0.1811\n",
      "Client 2 Private Data Validation Accuracy: 43.75%\n",
      "Client 2 Test Set Validation Accuracy: 42.81%\n",
      "\n",
      "--- Client 3 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.2809\n",
      "Epoch [2/5], Loss: 0.5804\n",
      "Epoch [3/5], Loss: 0.2900\n",
      "Epoch [4/5], Loss: 0.2179\n",
      "Epoch [5/5], Loss: 0.2254\n",
      "Client 3 Private Data Validation Accuracy: 42.97%\n",
      "Client 3 Test Set Validation Accuracy: 39.08%\n",
      "\n",
      "--- Client 4 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.2091\n",
      "Epoch [2/5], Loss: 0.2765\n",
      "Epoch [3/5], Loss: 0.2271\n",
      "Epoch [4/5], Loss: 0.3866\n",
      "Epoch [5/5], Loss: 0.1383\n",
      "Client 4 Private Data Validation Accuracy: 50.52%\n",
      "Client 4 Test Set Validation Accuracy: 42.93%\n",
      "\n",
      "--- Client 5 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.3534\n",
      "Epoch [2/5], Loss: 0.3582\n",
      "Epoch [3/5], Loss: 0.5277\n",
      "Epoch [4/5], Loss: 0.2957\n",
      "Epoch [5/5], Loss: 0.1915\n",
      "Client 5 Private Data Validation Accuracy: 44.53%\n",
      "Client 5 Test Set Validation Accuracy: 44.53%\n",
      "\n",
      "--- Client 6 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.2231\n",
      "Epoch [2/5], Loss: 0.2030\n",
      "Epoch [3/5], Loss: 0.3620\n",
      "Epoch [4/5], Loss: 0.3509\n",
      "Epoch [5/5], Loss: 0.3252\n",
      "Client 6 Private Data Validation Accuracy: 57.81%\n",
      "Client 6 Test Set Validation Accuracy: 42.89%\n",
      "\n",
      "--- Client 7 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.2145\n",
      "Epoch [2/5], Loss: 0.1242\n",
      "Epoch [3/5], Loss: 0.1963\n",
      "Epoch [4/5], Loss: 0.2395\n",
      "Epoch [5/5], Loss: 0.2963\n",
      "Client 7 Private Data Validation Accuracy: 48.44%\n",
      "Client 7 Test Set Validation Accuracy: 46.55%\n",
      "\n",
      "--- Client 8 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.3182\n",
      "Epoch [2/5], Loss: 0.4065\n",
      "Epoch [3/5], Loss: 0.5214\n",
      "Epoch [4/5], Loss: 0.3107\n",
      "Epoch [5/5], Loss: 0.2800\n",
      "Client 8 Private Data Validation Accuracy: 48.44%\n",
      "Client 8 Test Set Validation Accuracy: 45.05%\n",
      "\n",
      "--- Client 9 Local Training with T=0.05 ---\n",
      "Epoch [1/5], Loss: 0.1862\n",
      "Epoch [2/5], Loss: 0.2592\n",
      "Epoch [3/5], Loss: 0.2215\n",
      "Epoch [4/5], Loss: 0.1972\n",
      "Epoch [5/5], Loss: 0.2500\n",
      "Client 9 Private Data Validation Accuracy: 44.27%\n",
      "Client 9 Test Set Validation Accuracy: 42.71%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 53.48%\n",
      "\n",
      "--- COMPONENT: Heterogeneity-based Temperature (No Decay) ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.5138, Fixed temp: 0.3579\n",
      "Client 1 - Het Score: 0.4359, Fixed temp: 0.4182\n",
      "Client 2 - Het Score: 0.3881, Fixed temp: 0.4602\n",
      "Client 3 - Het Score: 0.3954, Fixed temp: 0.4535\n",
      "Client 4 - Het Score: 0.2446, Fixed temp: 0.6131\n",
      "Client 5 - Het Score: 0.2782, Fixed temp: 0.5733\n",
      "Client 6 - Het Score: 0.4171, Fixed temp: 0.4343\n",
      "Client 7 - Het Score: 0.3625, Fixed temp: 0.4843\n",
      "Client 8 - Het Score: 0.2555, Fixed temp: 0.5999\n",
      "Client 9 - Het Score: 0.3068, Fixed temp: 0.5414\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.3579, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.3381\n",
      "Epoch [2/5], Loss: 0.6034\n",
      "Epoch [3/5], Loss: 0.3654\n",
      "Epoch [4/5], Loss: 0.1624\n",
      "Epoch [5/5], Loss: 0.0434\n",
      "Client 0 Private Data Validation Accuracy: 46.88%\n",
      "\n",
      "--- Client 1 Local Training with T=0.4182, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.0965\n",
      "Epoch [2/5], Loss: 0.1548\n",
      "Epoch [3/5], Loss: 0.0962\n",
      "Epoch [4/5], Loss: 0.0913\n",
      "Epoch [5/5], Loss: 0.0640\n",
      "Client 1 Private Data Validation Accuracy: 49.48%\n",
      "\n",
      "--- Client 2 Local Training with T=0.4602, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.0601\n",
      "Epoch [2/5], Loss: 0.0348\n",
      "Epoch [3/5], Loss: 0.0284\n",
      "Epoch [4/5], Loss: 0.0203\n",
      "Epoch [5/5], Loss: 0.0227\n",
      "Client 2 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 3 Local Training with T=0.4535, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.0750\n",
      "Epoch [2/5], Loss: 0.1039\n",
      "Epoch [3/5], Loss: 0.0732\n",
      "Epoch [4/5], Loss: 0.0612\n",
      "Epoch [5/5], Loss: 0.0349\n",
      "Client 3 Private Data Validation Accuracy: 57.81%\n",
      "\n",
      "--- Client 4 Local Training with T=0.6131, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1065\n",
      "Epoch [2/5], Loss: 0.0612\n",
      "Epoch [3/5], Loss: 0.0335\n",
      "Epoch [4/5], Loss: 0.0391\n",
      "Epoch [5/5], Loss: 0.0275\n",
      "Client 4 Private Data Validation Accuracy: 55.21%\n",
      "\n",
      "--- Client 5 Local Training with T=0.5733, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1450\n",
      "Epoch [2/5], Loss: 0.1161\n",
      "Epoch [3/5], Loss: 0.0682\n",
      "Epoch [4/5], Loss: 0.0398\n",
      "Epoch [5/5], Loss: 0.0417\n",
      "Client 5 Private Data Validation Accuracy: 51.56%\n",
      "\n",
      "--- Client 6 Local Training with T=0.4343, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1246\n",
      "Epoch [2/5], Loss: 0.1042\n",
      "Epoch [3/5], Loss: 0.1034\n",
      "Epoch [4/5], Loss: 0.1060\n",
      "Epoch [5/5], Loss: 0.0432\n",
      "Client 6 Private Data Validation Accuracy: 59.38%\n",
      "\n",
      "--- Client 7 Local Training with T=0.4843, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1146\n",
      "Epoch [2/5], Loss: 0.1384\n",
      "Epoch [3/5], Loss: 0.0985\n",
      "Epoch [4/5], Loss: 0.0914\n",
      "Epoch [5/5], Loss: 0.0807\n",
      "Client 7 Private Data Validation Accuracy: 54.69%\n",
      "\n",
      "--- Client 8 Local Training with T=0.5999, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1803\n",
      "Epoch [2/5], Loss: 0.1163\n",
      "Epoch [3/5], Loss: 0.0567\n",
      "Epoch [4/5], Loss: 0.0355\n",
      "Epoch [5/5], Loss: 0.0271\n",
      "Client 8 Private Data Validation Accuracy: 56.25%\n",
      "\n",
      "--- Client 9 Local Training with T=0.5414, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.0868\n",
      "Epoch [2/5], Loss: 0.0774\n",
      "Epoch [3/5], Loss: 0.0403\n",
      "Epoch [4/5], Loss: 0.0417\n",
      "Epoch [5/5], Loss: 0.0253\n",
      "Client 9 Private Data Validation Accuracy: 54.17%\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 55.57%\n",
      "\n",
      "--- COMPONENT: Full FedChill ---\n",
      "Data partitioning complete.\n",
      "Client 0 - Het Score: 0.5138, Initial temp: 0.3579\n",
      "Client 1 - Het Score: 0.4359, Initial temp: 0.4182\n",
      "Client 2 - Het Score: 0.3881, Initial temp: 0.4602\n",
      "Client 3 - Het Score: 0.3954, Initial temp: 0.4535\n",
      "Client 4 - Het Score: 0.2446, Initial temp: 0.6131\n",
      "Client 5 - Het Score: 0.2782, Initial temp: 0.5733\n",
      "Client 6 - Het Score: 0.4171, Initial temp: 0.4343\n",
      "Client 7 - Het Score: 0.3625, Initial temp: 0.4843\n",
      "Client 8 - Het Score: 0.2555, Initial temp: 0.5999\n",
      "Client 9 - Het Score: 0.3068, Initial temp: 0.5414\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.3068, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.2590\n",
      "Epoch [2/5], Loss: 0.5451\n",
      "Epoch [3/5], Loss: 0.3608\n",
      "Epoch [4/5], Loss: 0.4839\n",
      "Epoch [5/5], Loss: 0.1139\n",
      "Client 0 Private Data Validation Accuracy: 42.97%\n",
      "\n",
      "--- Client 1 Local Training with T=0.3585, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1423\n",
      "Epoch [2/5], Loss: 0.1746\n",
      "Epoch [3/5], Loss: 0.2294\n",
      "Epoch [4/5], Loss: 0.1284\n",
      "Epoch [5/5], Loss: 0.1264\n",
      "Client 1 Private Data Validation Accuracy: 46.35%\n",
      "Client 1 - decrease-temp to 0.340621\n",
      "\n",
      "--- Client 2 Local Training with T=0.4153, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.0570\n",
      "Epoch [2/5], Loss: 0.0456\n",
      "Epoch [3/5], Loss: 0.0840\n",
      "Epoch [4/5], Loss: 0.0442\n",
      "Epoch [5/5], Loss: 0.0317\n",
      "Client 2 Private Data Validation Accuracy: 46.88%\n",
      "\n",
      "--- Client 3 Local Training with T=0.3693, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1241\n",
      "Epoch [2/5], Loss: 0.2911\n",
      "Epoch [3/5], Loss: 0.2199\n",
      "Epoch [4/5], Loss: 0.1623\n",
      "Epoch [5/5], Loss: 0.1091\n",
      "Client 3 Private Data Validation Accuracy: 50.00%\n",
      "\n",
      "--- Client 4 Local Training with T=0.5824, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1413\n",
      "Epoch [2/5], Loss: 0.0718\n",
      "Epoch [3/5], Loss: 0.0405\n",
      "Epoch [4/5], Loss: 0.0441\n",
      "Epoch [5/5], Loss: 0.0331\n",
      "Client 4 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 5 Local Training with T=0.5446, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1785\n",
      "Epoch [2/5], Loss: 0.0844\n",
      "Epoch [3/5], Loss: 0.0856\n",
      "Epoch [4/5], Loss: 0.0486\n",
      "Epoch [5/5], Loss: 0.0470\n",
      "Client 5 Private Data Validation Accuracy: 48.44%\n",
      "\n",
      "--- Client 6 Local Training with T=0.3919, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1323\n",
      "Epoch [2/5], Loss: 0.0756\n",
      "Epoch [3/5], Loss: 0.0801\n",
      "Epoch [4/5], Loss: 0.0668\n",
      "Epoch [5/5], Loss: 0.0338\n",
      "Client 6 Private Data Validation Accuracy: 60.42%\n",
      "\n",
      "--- Client 7 Local Training with T=0.3944, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.0568\n",
      "Epoch [2/5], Loss: 0.0637\n",
      "Epoch [3/5], Loss: 0.0497\n",
      "Epoch [4/5], Loss: 0.0410\n",
      "Epoch [5/5], Loss: 0.0474\n",
      "Client 7 Private Data Validation Accuracy: 53.12%\n",
      "\n",
      "--- Client 8 Local Training with T=0.5143, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1688\n",
      "Epoch [2/5], Loss: 0.1140\n",
      "Epoch [3/5], Loss: 0.0700\n",
      "Epoch [4/5], Loss: 0.0410\n",
      "Epoch [5/5], Loss: 0.0272\n",
      "Client 8 Private Data Validation Accuracy: 56.25%\n",
      "\n",
      "--- Client 9 Local Training with T=0.4642, LR=0.010000 ---\n",
      "Epoch [1/5], Loss: 0.1007\n",
      "Epoch [2/5], Loss: 0.0642\n",
      "Epoch [3/5], Loss: 0.0504\n",
      "Epoch [4/5], Loss: 0.0356\n",
      "Epoch [5/5], Loss: 0.0242\n",
      "Client 9 Private Data Validation Accuracy: 50.52%\n",
      "Client 9 - decrease-temp to 0.440945\n",
      "\n",
      "--- Server Evaluation ---\n",
      "Server Test Data Validation Accuracy: 56.54%\n",
      "\n",
      "# Ablation Study - Component Contributions in FedChill\n",
      "\n",
      "| Heterogeneity (α) | CNN Architecture | Component | Local Acc (%) | Global Acc (%) |\n",
      "|------------------|-----------------|-----------|---------------|----------------|\n",
      "| α = 0.5 | SmallCNN (0.69M) | FedAvg (T=1.0) | 64.54 | 46.96 |\n",
      "|  |  | Fixed T=0.05 | 65.65 | 47.26 |\n",
      "|  |  | Het-based T | 67.91 | 49.33 |\n",
      "|  |  | Full FedChill | 65.36 | 49.49 |\n",
      "| α = 0.5 | LargeCNN (13.95M) | FedAvg (T=1.0) | 65.97 | 45.74 |\n",
      "|  |  | Fixed T=0.05 | 61.73 | 39.22 |\n",
      "|  |  | Het-based T | 67.69 | 47.55 |\n",
      "|  |  | Full FedChill | 64.55 | 45.39 |\n",
      "| α = 5.0 | SmallCNN (0.69M) | FedAvg (T=1.0) | 52.08 | 54.56 |\n",
      "|  |  | Fixed T=0.05 | 50.55 | 56.10 |\n",
      "|  |  | Het-based T | 54.27 | 55.67 |\n",
      "|  |  | Full FedChill | 53.39 | 55.81 |\n",
      "| α = 5.0 | LargeCNN (13.95M) | FedAvg (T=1.0) | 50.70 | 53.44 |\n",
      "|  |  | Fixed T=0.05 | 47.24 | 53.48 |\n",
      "|  |  | Het-based T | 53.85 | 55.57 |\n",
      "|  |  | Full FedChill | 50.81 | 56.54 |\n",
      "\n",
      "Results also saved to 'component_ablation_results.md'\n"
     ]
    }
   ],
   "source": [
    "ablation_results = run_component_ablation(\n",
    "    alpha_values=[0.5, 5.0],\n",
    "    model_classes=[SmallCNN, LargeCNN]\n",
    ")"
   ]
  },
  {
   "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
}
