{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "560e4fda",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "import numpy as np\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy\n",
    "from torchvision import datasets, transforms\n",
    "import math, copy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "70f14269",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load MNIST dataset for reconstruction\n",
    "transform = transforms.Compose([transforms.ToTensor()])\n",
    "mnist_train = datasets.MNIST(root='./data', train=True, download=True, transform=transform)\n",
    "mnist_test = datasets.MNIST(root='./data', train=False, download=True, transform=transform)\n",
    "batch_size = 1000\n",
    "k = 10  # Number of classes\n",
    "unbalance_factors = [1, 1, 1, 1, 1, 0.2, 0.2, 0.2, 0.2, 0.2]  # Define the proportions for each class\n",
    "\n",
    "# Initialize list to hold data for each class\n",
    "class_data = [[] for _ in range(k)]\n",
    "for data, label in mnist_train:\n",
    "    class_data[label].append(data)\n",
    "\n",
    "# Make the classes unbalanced based on the defined unbalance factors\n",
    "unbalanced_class_data = []\n",
    "for i in range(k):\n",
    "    total_samples = len(class_data[i])\n",
    "    # Calculate the number of samples to keep for the class based on the unbalance factor\n",
    "    samples_to_keep = int(total_samples * unbalance_factors[i])\n",
    "    # Randomly select the subset of data\n",
    "    selected_data = random.sample(class_data[i], samples_to_keep)\n",
    "    unbalanced_class_data.append(torch.stack(selected_data))\n",
    "\n",
    "# Create TensorDatasets for each class\n",
    "tensor_datasets = [TensorDataset(data, torch.full((data.size(0),), label, dtype=torch.long)) for label, data in enumerate(unbalanced_class_data)]\n",
    "mnist_train = torch.utils.data.ConcatDataset(tensor_datasets)\n",
    "\n",
    "# Combine all training data for a single DataLoader\n",
    "train_loader = DataLoader(mnist_train, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "# Create a DataLoader for the test data directly\n",
    "test_loader = DataLoader(mnist_test, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "# Shuffle indices at the start of each epoch\n",
    "def shuffle_class_data(tensor_datasets):\n",
    "    shuffled_indices = []\n",
    "    for dataset in tensor_datasets:\n",
    "        num_samples = dataset.tensors[0].size(0)\n",
    "        # Shuffle indices for the current class\n",
    "        shuffled_indices.append(torch.randperm(num_samples))\n",
    "    return shuffled_indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "74c00925",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the Autoencoder model for image reconstruction\n",
    "class Autoencoder(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Autoencoder, self).__init__()\n",
    "        # Encoder\n",
    "        self.encoder = nn.Sequential(\n",
    "            nn.Flatten(),\n",
    "            nn.Linear(28 * 28, 128),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(128, 32)\n",
    "        )\n",
    "        # Decoder\n",
    "        self.decoder = nn.Sequential(\n",
    "            nn.Linear(32, 128),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(128, 28 * 28),\n",
    "            nn.Sigmoid()  # Sigmoid for output between 0 and 1\n",
    "        )\n",
    "    \n",
    "    def forward(self, x):\n",
    "        encoded = self.encoder(x)\n",
    "        decoded = self.decoder(encoded)\n",
    "        return decoded.view(-1, 1, 28, 28)  # Reshape to image size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "2d5987eb",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iter 0, Epoch 0, Cls Error: 62.023, L2M Error: 62.001, Alpha: [0.16  0.174 0.158 0.161 0.154 0.036 0.04  0.04  0.039 0.039]\n",
      "Iter 0, Epoch 1, Cls Error: 50.711, L2M Error: 50.674, Alpha: [0.156 0.163 0.153 0.155 0.148 0.043 0.047 0.045 0.045 0.044]\n",
      "Iter 0, Epoch 2, Cls Error: 44.508, L2M Error: 44.345, Alpha: [0.152 0.152 0.149 0.15  0.143 0.049 0.053 0.051 0.052 0.048]\n",
      "Iter 0, Epoch 3, Cls Error: 39.839, L2M Error: 39.417, Alpha: [0.147 0.142 0.146 0.145 0.138 0.055 0.061 0.056 0.058 0.053]\n",
      "Iter 0, Epoch 4, Cls Error: 35.592, L2M Error: 34.756, Alpha: [0.143 0.132 0.143 0.14  0.134 0.061 0.067 0.061 0.064 0.056]\n",
      "Iter 0, Epoch 5, Cls Error: 31.998, L2M Error: 31.029, Alpha: [0.138 0.123 0.14  0.136 0.13  0.065 0.071 0.066 0.07  0.059]\n",
      "Iter 0, Epoch 6, Cls Error: 29.317, L2M Error: 28.203, Alpha: [0.134 0.115 0.139 0.133 0.127 0.07  0.075 0.07  0.075 0.062]\n",
      "Iter 0, Epoch 7, Cls Error: 26.835, L2M Error: 25.686, Alpha: [0.13  0.108 0.137 0.13  0.125 0.074 0.078 0.073 0.08  0.065]\n",
      "Iter 0, Epoch 8, Cls Error: 24.366, L2M Error: 23.325, Alpha: [0.127 0.101 0.136 0.127 0.123 0.078 0.081 0.075 0.085 0.068]\n",
      "Iter 0, Epoch 9, Cls Error: 22.227, L2M Error: 21.312, Alpha: [0.123 0.096 0.134 0.125 0.121 0.082 0.084 0.077 0.089 0.069]\n",
      "Iter 0, Epoch 10, Cls Error: 20.536, L2M Error: 19.776, Alpha: [0.12  0.091 0.133 0.123 0.119 0.086 0.085 0.078 0.093 0.071]\n",
      "Iter 0, Epoch 11, Cls Error: 19.329, L2M Error: 18.575, Alpha: [0.118 0.085 0.133 0.121 0.117 0.09  0.087 0.079 0.097 0.073]\n",
      "Iter 0, Epoch 12, Cls Error: 18.364, L2M Error: 17.575, Alpha: [0.115 0.081 0.133 0.12  0.115 0.093 0.089 0.08  0.1   0.074]\n",
      "Iter 0, Epoch 13, Cls Error: 17.568, L2M Error: 16.679, Alpha: [0.113 0.077 0.133 0.118 0.114 0.096 0.09  0.081 0.102 0.075]\n",
      "Iter 0, Epoch 14, Cls Error: 16.912, L2M Error: 15.945, Alpha: [0.111 0.073 0.133 0.118 0.113 0.099 0.091 0.081 0.105 0.077]\n",
      "Iter 0, Epoch 15, Cls Error: 16.248, L2M Error: 15.284, Alpha: [0.109 0.07  0.132 0.116 0.112 0.101 0.094 0.082 0.107 0.078]\n",
      "Iter 0, Epoch 16, Cls Error: 15.710, L2M Error: 14.756, Alpha: [0.107 0.066 0.131 0.115 0.111 0.103 0.096 0.082 0.11  0.079]\n",
      "Iter 0, Epoch 17, Cls Error: 15.251, L2M Error: 14.265, Alpha: [0.105 0.063 0.131 0.115 0.111 0.105 0.097 0.082 0.112 0.08 ]\n",
      "Iter 0, Epoch 18, Cls Error: 14.802, L2M Error: 13.822, Alpha: [0.103 0.061 0.131 0.115 0.111 0.106 0.098 0.082 0.113 0.081]\n",
      "Iter 0, Epoch 19, Cls Error: 14.405, L2M Error: 13.417, Alpha: [0.102 0.059 0.131 0.114 0.11  0.107 0.098 0.083 0.114 0.081]\n",
      "Iter 0, Epoch 20, Cls Error: 14.057, L2M Error: 13.035, Alpha: [0.101 0.057 0.13  0.114 0.11  0.108 0.099 0.083 0.116 0.082]\n",
      "Iter 0, Epoch 21, Cls Error: 13.715, L2M Error: 12.685, Alpha: [0.1   0.055 0.13  0.115 0.109 0.109 0.1   0.083 0.117 0.082]\n",
      "Iter 0, Epoch 22, Cls Error: 13.420, L2M Error: 12.412, Alpha: [0.098 0.055 0.129 0.114 0.109 0.11  0.1   0.084 0.118 0.083]\n",
      "Iter 0, Epoch 23, Cls Error: 13.090, L2M Error: 12.094, Alpha: [0.097 0.053 0.129 0.114 0.108 0.11  0.101 0.084 0.12  0.083]\n",
      "Iter 0, Epoch 24, Cls Error: 12.815, L2M Error: 11.824, Alpha: [0.097 0.052 0.129 0.113 0.108 0.11  0.101 0.084 0.121 0.085]\n",
      "Iter 0, Epoch 25, Cls Error: 12.628, L2M Error: 11.594, Alpha: [0.097 0.051 0.129 0.113 0.108 0.112 0.101 0.084 0.121 0.084]\n",
      "Iter 0, Epoch 26, Cls Error: 12.364, L2M Error: 11.404, Alpha: [0.096 0.049 0.129 0.112 0.109 0.112 0.101 0.084 0.122 0.085]\n",
      "Iter 0, Epoch 27, Cls Error: 12.160, L2M Error: 11.168, Alpha: [0.096 0.048 0.129 0.111 0.108 0.112 0.102 0.085 0.124 0.085]\n",
      "Iter 0, Epoch 28, Cls Error: 11.957, L2M Error: 11.019, Alpha: [0.096 0.047 0.13  0.111 0.109 0.112 0.102 0.085 0.124 0.084]\n",
      "Iter 0, Epoch 29, Cls Error: 11.769, L2M Error: 10.845, Alpha: [0.096 0.047 0.13  0.11  0.109 0.112 0.102 0.084 0.125 0.085]\n",
      "Iter 0, Epoch 30, Cls Error: 11.609, L2M Error: 10.673, Alpha: [0.095 0.046 0.131 0.109 0.108 0.113 0.103 0.085 0.125 0.085]\n",
      "Iter 0, Epoch 31, Cls Error: 11.436, L2M Error: 10.512, Alpha: [0.095 0.045 0.13  0.11  0.108 0.113 0.102 0.085 0.126 0.086]\n",
      "Iter 0, Epoch 32, Cls Error: 11.286, L2M Error: 10.358, Alpha: [0.094 0.044 0.13  0.109 0.108 0.113 0.103 0.085 0.126 0.087]\n",
      "Iter 0, Epoch 33, Cls Error: 11.141, L2M Error: 10.219, Alpha: [0.093 0.044 0.131 0.109 0.108 0.113 0.103 0.086 0.126 0.087]\n",
      "Iter 0, Epoch 34, Cls Error: 10.946, L2M Error: 10.077, Alpha: [0.094 0.043 0.131 0.109 0.109 0.113 0.103 0.085 0.127 0.087]\n",
      "Iter 0, Epoch 35, Cls Error: 10.822, L2M Error: 9.947, Alpha: [0.094 0.043 0.131 0.109 0.108 0.112 0.103 0.086 0.128 0.087]\n",
      "Iter 0, Epoch 36, Cls Error: 10.686, L2M Error: 9.797, Alpha: [0.094 0.043 0.131 0.109 0.107 0.112 0.103 0.086 0.128 0.087]\n",
      "Iter 0, Epoch 37, Cls Error: 10.517, L2M Error: 9.675, Alpha: [0.094 0.043 0.132 0.109 0.107 0.111 0.103 0.086 0.129 0.086]\n",
      "Iter 0, Epoch 38, Cls Error: 10.405, L2M Error: 9.548, Alpha: [0.093 0.043 0.132 0.109 0.108 0.111 0.103 0.086 0.129 0.086]\n",
      "Iter 0, Epoch 39, Cls Error: 10.263, L2M Error: 9.424, Alpha: [0.093 0.042 0.133 0.109 0.107 0.112 0.102 0.086 0.128 0.087]\n",
      "Iter 1, Epoch 0, Cls Error: 62.000, L2M Error: 62.015, Alpha: [0.159 0.174 0.158 0.161 0.154 0.037 0.039 0.041 0.039 0.038]\n",
      "Iter 1, Epoch 1, Cls Error: 50.870, L2M Error: 50.816, Alpha: [0.155 0.164 0.154 0.155 0.148 0.044 0.046 0.047 0.044 0.043]\n",
      "Iter 1, Epoch 2, Cls Error: 44.505, L2M Error: 44.354, Alpha: [0.15  0.154 0.15  0.149 0.143 0.05  0.052 0.052 0.051 0.049]\n",
      "Iter 1, Epoch 3, Cls Error: 39.062, L2M Error: 38.615, Alpha: [0.146 0.143 0.147 0.145 0.138 0.055 0.057 0.058 0.057 0.053]\n",
      "Iter 1, Epoch 4, Cls Error: 34.183, L2M Error: 33.479, Alpha: [0.142 0.134 0.144 0.141 0.134 0.061 0.062 0.062 0.064 0.057]\n",
      "Iter 1, Epoch 5, Cls Error: 30.797, L2M Error: 29.850, Alpha: [0.137 0.125 0.142 0.137 0.129 0.067 0.068 0.065 0.07  0.06 ]\n",
      "Iter 1, Epoch 6, Cls Error: 28.033, L2M Error: 27.008, Alpha: [0.133 0.117 0.14  0.134 0.126 0.072 0.072 0.068 0.075 0.063]\n",
      "Iter 1, Epoch 7, Cls Error: 25.728, L2M Error: 24.582, Alpha: [0.13  0.109 0.139 0.131 0.124 0.077 0.075 0.071 0.08  0.065]\n",
      "Iter 1, Epoch 8, Cls Error: 23.750, L2M Error: 22.609, Alpha: [0.127 0.102 0.137 0.128 0.121 0.081 0.078 0.073 0.084 0.067]\n",
      "Iter 1, Epoch 9, Cls Error: 21.921, L2M Error: 20.830, Alpha: [0.123 0.096 0.136 0.127 0.12  0.085 0.081 0.074 0.089 0.069]\n",
      "Iter 1, Epoch 10, Cls Error: 20.434, L2M Error: 19.342, Alpha: [0.12  0.09  0.135 0.124 0.118 0.088 0.084 0.077 0.092 0.071]\n",
      "Iter 1, Epoch 11, Cls Error: 19.260, L2M Error: 18.167, Alpha: [0.117 0.085 0.134 0.122 0.117 0.092 0.087 0.078 0.096 0.072]\n",
      "Iter 1, Epoch 12, Cls Error: 18.283, L2M Error: 17.229, Alpha: [0.114 0.081 0.134 0.121 0.115 0.094 0.089 0.079 0.099 0.074]\n",
      "Iter 1, Epoch 13, Cls Error: 17.447, L2M Error: 16.424, Alpha: [0.112 0.076 0.134 0.119 0.113 0.097 0.091 0.08  0.102 0.076]\n",
      "Iter 1, Epoch 14, Cls Error: 16.709, L2M Error: 15.724, Alpha: [0.11  0.072 0.133 0.118 0.113 0.099 0.093 0.081 0.105 0.077]\n",
      "Iter 1, Epoch 15, Cls Error: 16.111, L2M Error: 15.103, Alpha: [0.108 0.069 0.132 0.117 0.111 0.101 0.095 0.081 0.108 0.078]\n",
      "Iter 1, Epoch 16, Cls Error: 15.624, L2M Error: 14.546, Alpha: [0.107 0.066 0.132 0.116 0.11  0.103 0.096 0.082 0.11  0.078]\n",
      "Iter 1, Epoch 17, Cls Error: 15.136, L2M Error: 14.073, Alpha: [0.105 0.063 0.132 0.116 0.11  0.104 0.097 0.082 0.111 0.079]\n",
      "Iter 1, Epoch 18, Cls Error: 14.727, L2M Error: 13.626, Alpha: [0.105 0.061 0.131 0.116 0.109 0.106 0.099 0.082 0.113 0.079]\n",
      "Iter 1, Epoch 19, Cls Error: 14.381, L2M Error: 13.261, Alpha: [0.104 0.058 0.13  0.115 0.109 0.108 0.099 0.082 0.115 0.08 ]\n",
      "Iter 1, Epoch 20, Cls Error: 13.964, L2M Error: 12.887, Alpha: [0.102 0.057 0.131 0.114 0.108 0.109 0.1   0.083 0.116 0.081]\n",
      "Iter 1, Epoch 21, Cls Error: 13.612, L2M Error: 12.559, Alpha: [0.102 0.054 0.131 0.113 0.108 0.11  0.101 0.083 0.117 0.081]\n",
      "Iter 1, Epoch 22, Cls Error: 13.298, L2M Error: 12.274, Alpha: [0.101 0.052 0.131 0.113 0.107 0.11  0.101 0.084 0.118 0.082]\n",
      "Iter 1, Epoch 23, Cls Error: 13.000, L2M Error: 12.017, Alpha: [0.099 0.051 0.132 0.113 0.107 0.111 0.102 0.084 0.12  0.082]\n",
      "Iter 1, Epoch 24, Cls Error: 12.725, L2M Error: 11.815, Alpha: [0.098 0.049 0.131 0.112 0.107 0.112 0.102 0.084 0.12  0.083]\n",
      "Iter 1, Epoch 25, Cls Error: 12.509, L2M Error: 11.558, Alpha: [0.097 0.048 0.132 0.112 0.106 0.113 0.103 0.084 0.122 0.082]\n",
      "Iter 1, Epoch 26, Cls Error: 12.285, L2M Error: 11.351, Alpha: [0.097 0.047 0.132 0.111 0.107 0.114 0.104 0.084 0.123 0.083]\n",
      "Iter 1, Epoch 27, Cls Error: 12.085, L2M Error: 11.175, Alpha: [0.096 0.046 0.132 0.111 0.107 0.114 0.104 0.084 0.124 0.083]\n",
      "Iter 1, Epoch 28, Cls Error: 11.899, L2M Error: 10.984, Alpha: [0.096 0.045 0.132 0.111 0.107 0.114 0.103 0.084 0.124 0.083]\n",
      "Iter 1, Epoch 29, Cls Error: 11.724, L2M Error: 10.817, Alpha: [0.095 0.045 0.133 0.111 0.107 0.114 0.103 0.085 0.125 0.083]\n",
      "Iter 1, Epoch 30, Cls Error: 11.569, L2M Error: 10.654, Alpha: [0.096 0.045 0.132 0.111 0.106 0.115 0.103 0.084 0.126 0.083]\n",
      "Iter 1, Epoch 31, Cls Error: 11.399, L2M Error: 10.487, Alpha: [0.095 0.044 0.132 0.111 0.105 0.114 0.104 0.085 0.127 0.083]\n",
      "Iter 1, Epoch 32, Cls Error: 11.253, L2M Error: 10.334, Alpha: [0.095 0.043 0.133 0.11  0.105 0.115 0.104 0.085 0.126 0.083]\n",
      "Iter 1, Epoch 33, Cls Error: 11.220, L2M Error: 10.177, Alpha: [0.095 0.043 0.133 0.11  0.105 0.116 0.104 0.086 0.127 0.083]\n",
      "Iter 1, Epoch 34, Cls Error: 10.988, L2M Error: 10.052, Alpha: [0.094 0.042 0.133 0.11  0.105 0.116 0.103 0.086 0.128 0.083]\n",
      "Iter 1, Epoch 35, Cls Error: 10.866, L2M Error: 9.910, Alpha: [0.094 0.042 0.133 0.109 0.106 0.116 0.104 0.085 0.128 0.083]\n",
      "Iter 1, Epoch 36, Cls Error: 10.730, L2M Error: 9.766, Alpha: [0.094 0.041 0.134 0.109 0.106 0.115 0.104 0.085 0.128 0.083]\n",
      "Iter 1, Epoch 37, Cls Error: 10.655, L2M Error: 9.665, Alpha: [0.094 0.041 0.134 0.109 0.106 0.115 0.105 0.086 0.128 0.084]\n",
      "Iter 1, Epoch 38, Cls Error: 10.518, L2M Error: 9.530, Alpha: [0.094 0.04  0.133 0.109 0.107 0.115 0.105 0.085 0.128 0.084]\n",
      "Iter 1, Epoch 39, Cls Error: 10.444, L2M Error: 9.449, Alpha: [0.094 0.04  0.133 0.109 0.106 0.114 0.105 0.086 0.128 0.084]\n",
      "Iter 2, Epoch 0, Cls Error: 61.900, L2M Error: 61.913, Alpha: [0.159 0.175 0.158 0.161 0.154 0.037 0.039 0.04  0.039 0.038]\n",
      "Iter 2, Epoch 1, Cls Error: 51.131, L2M Error: 51.090, Alpha: [0.154 0.164 0.153 0.155 0.148 0.045 0.046 0.046 0.045 0.043]\n",
      "Iter 2, Epoch 2, Cls Error: 44.325, L2M Error: 44.189, Alpha: [0.15  0.153 0.149 0.15  0.143 0.051 0.053 0.052 0.051 0.048]\n",
      "Iter 2, Epoch 3, Cls Error: 38.627, L2M Error: 38.332, Alpha: [0.145 0.143 0.146 0.145 0.138 0.057 0.059 0.058 0.057 0.051]\n",
      "Iter 2, Epoch 4, Cls Error: 34.191, L2M Error: 33.673, Alpha: [0.141 0.134 0.143 0.14  0.134 0.062 0.065 0.063 0.063 0.055]\n",
      "Iter 2, Epoch 5, Cls Error: 30.978, L2M Error: 30.231, Alpha: [0.136 0.125 0.141 0.137 0.13  0.067 0.069 0.067 0.069 0.059]\n",
      "Iter 2, Epoch 6, Cls Error: 28.322, L2M Error: 27.273, Alpha: [0.132 0.117 0.139 0.133 0.127 0.072 0.073 0.071 0.074 0.062]\n",
      "Iter 2, Epoch 7, Cls Error: 25.942, L2M Error: 24.808, Alpha: [0.128 0.109 0.137 0.13  0.124 0.077 0.077 0.073 0.078 0.065]\n",
      "Iter 2, Epoch 8, Cls Error: 23.753, L2M Error: 22.701, Alpha: [0.125 0.102 0.136 0.128 0.122 0.082 0.081 0.075 0.082 0.068]\n",
      "Iter 2, Epoch 9, Cls Error: 21.988, L2M Error: 20.835, Alpha: [0.122 0.096 0.134 0.126 0.119 0.085 0.084 0.077 0.086 0.071]\n",
      "Iter 2, Epoch 10, Cls Error: 20.449, L2M Error: 19.159, Alpha: [0.119 0.09  0.134 0.124 0.118 0.089 0.086 0.078 0.09  0.073]\n",
      "Iter 2, Epoch 11, Cls Error: 19.160, L2M Error: 17.883, Alpha: [0.117 0.085 0.133 0.123 0.117 0.092 0.088 0.08  0.093 0.074]\n",
      "Iter 2, Epoch 12, Cls Error: 18.123, L2M Error: 16.897, Alpha: [0.114 0.081 0.132 0.121 0.115 0.095 0.089 0.08  0.096 0.076]\n",
      "Iter 2, Epoch 13, Cls Error: 17.215, L2M Error: 16.125, Alpha: [0.112 0.076 0.132 0.119 0.114 0.098 0.092 0.081 0.099 0.077]\n",
      "Iter 2, Epoch 14, Cls Error: 16.528, L2M Error: 15.457, Alpha: [0.11  0.073 0.132 0.118 0.113 0.1   0.094 0.082 0.102 0.078]\n",
      "Iter 2, Epoch 15, Cls Error: 15.882, L2M Error: 14.894, Alpha: [0.108 0.069 0.131 0.117 0.112 0.101 0.095 0.082 0.105 0.08 ]\n",
      "Iter 2, Epoch 16, Cls Error: 15.298, L2M Error: 14.363, Alpha: [0.106 0.066 0.131 0.116 0.111 0.103 0.096 0.082 0.107 0.081]\n",
      "Iter 2, Epoch 17, Cls Error: 14.791, L2M Error: 13.922, Alpha: [0.105 0.063 0.131 0.116 0.11  0.104 0.097 0.083 0.11  0.082]\n",
      "Iter 2, Epoch 18, Cls Error: 14.333, L2M Error: 13.512, Alpha: [0.103 0.061 0.131 0.114 0.11  0.105 0.099 0.083 0.111 0.082]\n",
      "Iter 2, Epoch 19, Cls Error: 13.887, L2M Error: 13.094, Alpha: [0.102 0.058 0.131 0.114 0.109 0.107 0.099 0.083 0.113 0.084]\n",
      "Iter 2, Epoch 20, Cls Error: 13.519, L2M Error: 12.693, Alpha: [0.101 0.056 0.131 0.113 0.109 0.108 0.1   0.084 0.114 0.084]\n",
      "Iter 2, Epoch 21, Cls Error: 13.183, L2M Error: 12.328, Alpha: [0.1   0.054 0.131 0.112 0.108 0.109 0.101 0.084 0.117 0.084]\n",
      "Iter 2, Epoch 22, Cls Error: 12.891, L2M Error: 12.009, Alpha: [0.1   0.053 0.131 0.111 0.108 0.11  0.101 0.084 0.118 0.084]\n",
      "Iter 2, Epoch 23, Cls Error: 12.603, L2M Error: 11.713, Alpha: [0.099 0.051 0.131 0.111 0.108 0.11  0.101 0.085 0.119 0.084]\n",
      "Iter 2, Epoch 24, Cls Error: 12.310, L2M Error: 11.453, Alpha: [0.098 0.05  0.131 0.111 0.108 0.111 0.101 0.085 0.121 0.084]\n",
      "Iter 2, Epoch 25, Cls Error: 12.089, L2M Error: 11.214, Alpha: [0.097 0.05  0.132 0.111 0.108 0.111 0.102 0.085 0.122 0.084]\n",
      "Iter 2, Epoch 26, Cls Error: 11.831, L2M Error: 11.013, Alpha: [0.096 0.049 0.132 0.11  0.107 0.112 0.102 0.086 0.122 0.084]\n",
      "Iter 2, Epoch 27, Cls Error: 11.629, L2M Error: 10.822, Alpha: [0.096 0.048 0.132 0.109 0.107 0.112 0.102 0.087 0.123 0.085]\n",
      "Iter 2, Epoch 28, Cls Error: 11.423, L2M Error: 10.626, Alpha: [0.095 0.047 0.132 0.109 0.106 0.113 0.102 0.087 0.124 0.084]\n",
      "Iter 2, Epoch 29, Cls Error: 11.239, L2M Error: 10.470, Alpha: [0.095 0.047 0.132 0.109 0.106 0.113 0.102 0.087 0.125 0.085]\n",
      "Iter 2, Epoch 30, Cls Error: 11.069, L2M Error: 10.296, Alpha: [0.094 0.046 0.132 0.109 0.106 0.113 0.103 0.087 0.126 0.085]\n",
      "Iter 2, Epoch 31, Cls Error: 10.907, L2M Error: 10.124, Alpha: [0.094 0.044 0.133 0.109 0.106 0.113 0.102 0.087 0.126 0.085]\n",
      "Iter 2, Epoch 32, Cls Error: 10.753, L2M Error: 9.977, Alpha: [0.093 0.044 0.134 0.109 0.106 0.114 0.102 0.087 0.126 0.085]\n",
      "Iter 2, Epoch 33, Cls Error: 10.646, L2M Error: 9.844, Alpha: [0.094 0.043 0.134 0.109 0.106 0.114 0.102 0.087 0.127 0.085]\n",
      "Iter 2, Epoch 34, Cls Error: 10.464, L2M Error: 9.729, Alpha: [0.094 0.043 0.134 0.109 0.106 0.114 0.102 0.087 0.128 0.086]\n",
      "Iter 2, Epoch 35, Cls Error: 10.346, L2M Error: 9.607, Alpha: [0.094 0.042 0.134 0.109 0.105 0.114 0.102 0.087 0.128 0.085]\n",
      "Iter 2, Epoch 36, Cls Error: 10.185, L2M Error: 9.496, Alpha: [0.094 0.041 0.134 0.109 0.105 0.114 0.103 0.086 0.128 0.085]\n",
      "Iter 2, Epoch 37, Cls Error: 10.080, L2M Error: 9.387, Alpha: [0.093 0.041 0.134 0.109 0.105 0.114 0.103 0.087 0.128 0.085]\n",
      "Iter 2, Epoch 38, Cls Error: 9.934, L2M Error: 9.279, Alpha: [0.093 0.04  0.134 0.109 0.106 0.115 0.103 0.088 0.128 0.085]\n",
      "Iter 2, Epoch 39, Cls Error: 9.822, L2M Error: 9.175, Alpha: [0.092 0.041 0.134 0.109 0.106 0.114 0.103 0.088 0.128 0.086]\n",
      "Iter 3, Epoch 0, Cls Error: 63.635, L2M Error: 63.658, Alpha: [0.159 0.174 0.158 0.161 0.154 0.037 0.039 0.04  0.039 0.038]\n",
      "Iter 3, Epoch 1, Cls Error: 52.187, L2M Error: 52.143, Alpha: [0.156 0.164 0.154 0.155 0.148 0.043 0.046 0.046 0.045 0.043]\n",
      "Iter 3, Epoch 2, Cls Error: 45.541, L2M Error: 45.287, Alpha: [0.151 0.153 0.15  0.15  0.143 0.05  0.052 0.052 0.051 0.048]\n",
      "Iter 3, Epoch 3, Cls Error: 40.154, L2M Error: 39.618, Alpha: [0.147 0.143 0.146 0.145 0.138 0.056 0.058 0.058 0.057 0.052]\n",
      "Iter 3, Epoch 4, Cls Error: 35.627, L2M Error: 34.700, Alpha: [0.142 0.134 0.143 0.141 0.133 0.061 0.063 0.063 0.063 0.056]\n",
      "Iter 3, Epoch 5, Cls Error: 31.885, L2M Error: 30.698, Alpha: [0.138 0.124 0.141 0.137 0.129 0.067 0.068 0.068 0.068 0.06 ]\n",
      "Iter 3, Epoch 6, Cls Error: 29.079, L2M Error: 27.786, Alpha: [0.134 0.116 0.139 0.134 0.126 0.072 0.073 0.071 0.074 0.063]\n",
      "Iter 3, Epoch 7, Cls Error: 26.674, L2M Error: 25.302, Alpha: [0.13  0.109 0.138 0.13  0.123 0.077 0.076 0.074 0.078 0.066]\n",
      "Iter 3, Epoch 8, Cls Error: 24.641, L2M Error: 23.329, Alpha: [0.127 0.102 0.136 0.127 0.121 0.081 0.08  0.077 0.082 0.068]\n",
      "Iter 3, Epoch 9, Cls Error: 22.984, L2M Error: 21.666, Alpha: [0.123 0.096 0.135 0.125 0.118 0.085 0.083 0.078 0.086 0.07 ]\n",
      "Iter 3, Epoch 10, Cls Error: 21.457, L2M Error: 20.125, Alpha: [0.121 0.091 0.134 0.123 0.116 0.088 0.086 0.079 0.09  0.072]\n",
      "Iter 3, Epoch 11, Cls Error: 20.224, L2M Error: 18.743, Alpha: [0.118 0.086 0.134 0.121 0.114 0.092 0.089 0.08  0.093 0.073]\n",
      "Iter 3, Epoch 12, Cls Error: 19.014, L2M Error: 17.635, Alpha: [0.116 0.081 0.134 0.119 0.113 0.094 0.092 0.081 0.096 0.075]\n",
      "Iter 3, Epoch 13, Cls Error: 17.993, L2M Error: 16.811, Alpha: [0.114 0.077 0.134 0.118 0.111 0.097 0.094 0.082 0.098 0.076]\n",
      "Iter 3, Epoch 14, Cls Error: 17.184, L2M Error: 16.143, Alpha: [0.111 0.073 0.133 0.118 0.11  0.099 0.095 0.082 0.101 0.076]\n",
      "Iter 3, Epoch 15, Cls Error: 16.456, L2M Error: 15.547, Alpha: [0.11  0.069 0.133 0.117 0.109 0.101 0.096 0.083 0.104 0.077]\n",
      "Iter 3, Epoch 16, Cls Error: 15.891, L2M Error: 14.980, Alpha: [0.108 0.066 0.133 0.117 0.108 0.103 0.097 0.083 0.107 0.078]\n",
      "Iter 3, Epoch 17, Cls Error: 15.345, L2M Error: 14.476, Alpha: [0.106 0.064 0.133 0.115 0.107 0.105 0.098 0.084 0.109 0.079]\n",
      "Iter 3, Epoch 18, Cls Error: 14.882, L2M Error: 14.010, Alpha: [0.105 0.061 0.132 0.115 0.107 0.106 0.099 0.084 0.111 0.08 ]\n",
      "Iter 3, Epoch 19, Cls Error: 14.444, L2M Error: 13.566, Alpha: [0.103 0.059 0.132 0.115 0.107 0.107 0.1   0.085 0.112 0.08 ]\n",
      "Iter 3, Epoch 20, Cls Error: 14.034, L2M Error: 13.141, Alpha: [0.102 0.056 0.132 0.114 0.107 0.108 0.101 0.085 0.114 0.08 ]\n",
      "Iter 3, Epoch 21, Cls Error: 13.647, L2M Error: 12.729, Alpha: [0.101 0.054 0.132 0.114 0.106 0.108 0.102 0.086 0.116 0.081]\n",
      "Iter 3, Epoch 22, Cls Error: 13.306, L2M Error: 12.348, Alpha: [0.1   0.052 0.133 0.113 0.106 0.109 0.102 0.087 0.117 0.081]\n",
      "Iter 3, Epoch 23, Cls Error: 12.932, L2M Error: 12.027, Alpha: [0.099 0.051 0.133 0.113 0.106 0.11  0.103 0.087 0.118 0.081]\n",
      "Iter 3, Epoch 24, Cls Error: 12.564, L2M Error: 11.705, Alpha: [0.098 0.05  0.133 0.112 0.106 0.11  0.103 0.087 0.119 0.081]\n",
      "Iter 3, Epoch 25, Cls Error: 12.230, L2M Error: 11.414, Alpha: [0.098 0.049 0.133 0.112 0.105 0.11  0.104 0.088 0.121 0.082]\n",
      "Iter 3, Epoch 26, Cls Error: 11.946, L2M Error: 11.157, Alpha: [0.097 0.048 0.133 0.112 0.105 0.11  0.104 0.088 0.122 0.081]\n",
      "Iter 3, Epoch 27, Cls Error: 11.714, L2M Error: 10.947, Alpha: [0.096 0.047 0.133 0.112 0.105 0.11  0.105 0.088 0.123 0.082]\n",
      "Iter 3, Epoch 28, Cls Error: 11.471, L2M Error: 10.726, Alpha: [0.096 0.047 0.133 0.112 0.104 0.11  0.105 0.088 0.123 0.081]\n",
      "Iter 3, Epoch 29, Cls Error: 11.268, L2M Error: 10.572, Alpha: [0.096 0.046 0.133 0.112 0.105 0.111 0.105 0.089 0.123 0.081]\n",
      "Iter 3, Epoch 30, Cls Error: 11.073, L2M Error: 10.380, Alpha: [0.094 0.045 0.134 0.112 0.106 0.111 0.106 0.089 0.123 0.081]\n",
      "Iter 3, Epoch 31, Cls Error: 10.933, L2M Error: 10.240, Alpha: [0.094 0.044 0.134 0.112 0.106 0.111 0.106 0.089 0.124 0.081]\n",
      "Iter 3, Epoch 32, Cls Error: 10.729, L2M Error: 10.057, Alpha: [0.094 0.044 0.134 0.111 0.105 0.111 0.106 0.088 0.125 0.081]\n",
      "Iter 3, Epoch 33, Cls Error: 10.605, L2M Error: 9.951, Alpha: [0.094 0.044 0.134 0.111 0.106 0.111 0.105 0.088 0.126 0.082]\n",
      "Iter 3, Epoch 34, Cls Error: 10.445, L2M Error: 9.771, Alpha: [0.093 0.043 0.134 0.111 0.105 0.112 0.105 0.088 0.127 0.082]\n",
      "Iter 3, Epoch 35, Cls Error: 10.234, L2M Error: 9.661, Alpha: [0.092 0.043 0.134 0.111 0.105 0.112 0.105 0.088 0.127 0.082]\n",
      "Iter 3, Epoch 36, Cls Error: 10.096, L2M Error: 9.541, Alpha: [0.091 0.043 0.135 0.111 0.105 0.112 0.105 0.088 0.127 0.082]\n",
      "Iter 3, Epoch 37, Cls Error: 10.027, L2M Error: 9.403, Alpha: [0.091 0.043 0.135 0.111 0.105 0.112 0.105 0.088 0.128 0.082]\n",
      "Iter 3, Epoch 38, Cls Error: 9.889, L2M Error: 9.295, Alpha: [0.091 0.043 0.135 0.111 0.106 0.112 0.105 0.087 0.128 0.082]\n",
      "Iter 3, Epoch 39, Cls Error: 9.781, L2M Error: 9.209, Alpha: [0.092 0.042 0.136 0.11  0.106 0.112 0.105 0.087 0.127 0.082]\n",
      "Iter 4, Epoch 0, Cls Error: 63.068, L2M Error: 63.021, Alpha: [0.16  0.175 0.158 0.161 0.154 0.037 0.039 0.04  0.038 0.038]\n",
      "Iter 4, Epoch 1, Cls Error: 52.593, L2M Error: 52.557, Alpha: [0.157 0.164 0.153 0.155 0.148 0.043 0.046 0.046 0.045 0.043]\n",
      "Iter 4, Epoch 2, Cls Error: 44.812, L2M Error: 44.685, Alpha: [0.152 0.154 0.149 0.15  0.143 0.049 0.053 0.051 0.051 0.048]\n",
      "Iter 4, Epoch 3, Cls Error: 38.772, L2M Error: 38.466, Alpha: [0.148 0.143 0.146 0.145 0.138 0.055 0.059 0.057 0.058 0.051]\n",
      "Iter 4, Epoch 4, Cls Error: 34.868, L2M Error: 34.158, Alpha: [0.143 0.133 0.142 0.141 0.134 0.061 0.066 0.062 0.064 0.055]\n",
      "Iter 4, Epoch 5, Cls Error: 31.837, L2M Error: 30.970, Alpha: [0.138 0.124 0.14  0.136 0.13  0.066 0.071 0.067 0.069 0.058]\n",
      "Iter 4, Epoch 6, Cls Error: 28.846, L2M Error: 27.818, Alpha: [0.134 0.116 0.138 0.133 0.127 0.071 0.075 0.07  0.075 0.061]\n",
      "Iter 4, Epoch 7, Cls Error: 26.177, L2M Error: 24.920, Alpha: [0.13  0.108 0.136 0.129 0.125 0.075 0.079 0.073 0.08  0.064]\n",
      "Iter 4, Epoch 8, Cls Error: 24.135, L2M Error: 22.800, Alpha: [0.126 0.101 0.135 0.127 0.122 0.08  0.082 0.076 0.084 0.068]\n",
      "Iter 4, Epoch 9, Cls Error: 22.530, L2M Error: 21.292, Alpha: [0.122 0.095 0.134 0.125 0.12  0.084 0.085 0.078 0.087 0.07 ]\n",
      "Iter 4, Epoch 10, Cls Error: 21.168, L2M Error: 19.972, Alpha: [0.119 0.09  0.133 0.123 0.119 0.088 0.087 0.079 0.091 0.072]\n",
      "Iter 4, Epoch 11, Cls Error: 19.943, L2M Error: 18.797, Alpha: [0.116 0.085 0.132 0.121 0.117 0.092 0.089 0.082 0.094 0.073]\n",
      "Iter 4, Epoch 12, Cls Error: 18.929, L2M Error: 17.830, Alpha: [0.114 0.08  0.131 0.12  0.116 0.095 0.09  0.082 0.097 0.075]\n",
      "Iter 4, Epoch 13, Cls Error: 18.013, L2M Error: 16.903, Alpha: [0.112 0.076 0.131 0.119 0.114 0.098 0.092 0.083 0.1   0.075]\n",
      "Iter 4, Epoch 14, Cls Error: 17.272, L2M Error: 16.069, Alpha: [0.11  0.073 0.131 0.117 0.113 0.1   0.094 0.084 0.103 0.077]\n",
      "Iter 4, Epoch 15, Cls Error: 16.637, L2M Error: 15.329, Alpha: [0.108 0.069 0.131 0.116 0.112 0.101 0.095 0.084 0.105 0.078]\n",
      "Iter 4, Epoch 16, Cls Error: 16.042, L2M Error: 14.707, Alpha: [0.107 0.066 0.13  0.115 0.111 0.103 0.096 0.085 0.108 0.079]\n",
      "Iter 4, Epoch 17, Cls Error: 15.561, L2M Error: 14.141, Alpha: [0.105 0.062 0.131 0.114 0.111 0.105 0.097 0.085 0.11  0.08 ]\n",
      "Iter 4, Epoch 18, Cls Error: 15.086, L2M Error: 13.661, Alpha: [0.104 0.06  0.131 0.114 0.111 0.106 0.097 0.085 0.112 0.081]\n",
      "Iter 4, Epoch 19, Cls Error: 14.666, L2M Error: 13.275, Alpha: [0.103 0.058 0.131 0.113 0.111 0.106 0.098 0.085 0.113 0.082]\n",
      "Iter 4, Epoch 20, Cls Error: 14.234, L2M Error: 12.875, Alpha: [0.102 0.056 0.131 0.113 0.11  0.107 0.098 0.085 0.115 0.082]\n",
      "Iter 4, Epoch 21, Cls Error: 13.888, L2M Error: 12.581, Alpha: [0.101 0.054 0.132 0.114 0.11  0.107 0.098 0.086 0.116 0.083]\n",
      "Iter 4, Epoch 22, Cls Error: 13.618, L2M Error: 12.283, Alpha: [0.1   0.052 0.132 0.113 0.109 0.108 0.099 0.086 0.117 0.083]\n",
      "Iter 4, Epoch 23, Cls Error: 13.239, L2M Error: 12.008, Alpha: [0.099 0.051 0.132 0.113 0.109 0.108 0.1   0.086 0.118 0.083]\n",
      "Iter 4, Epoch 24, Cls Error: 12.969, L2M Error: 11.750, Alpha: [0.099 0.05  0.132 0.113 0.108 0.109 0.1   0.087 0.119 0.084]\n",
      "Iter 4, Epoch 25, Cls Error: 12.713, L2M Error: 11.533, Alpha: [0.098 0.049 0.131 0.113 0.108 0.11  0.1   0.086 0.12  0.084]\n",
      "Iter 4, Epoch 26, Cls Error: 12.499, L2M Error: 11.358, Alpha: [0.098 0.048 0.131 0.113 0.108 0.11  0.1   0.087 0.121 0.085]\n",
      "Iter 4, Epoch 27, Cls Error: 12.254, L2M Error: 11.112, Alpha: [0.097 0.047 0.13  0.113 0.108 0.111 0.099 0.087 0.123 0.085]\n",
      "Iter 4, Epoch 28, Cls Error: 12.037, L2M Error: 10.876, Alpha: [0.096 0.046 0.13  0.112 0.108 0.111 0.1   0.087 0.124 0.085]\n",
      "Iter 4, Epoch 29, Cls Error: 11.853, L2M Error: 10.691, Alpha: [0.096 0.045 0.13  0.112 0.108 0.112 0.1   0.087 0.124 0.085]\n",
      "Iter 4, Epoch 30, Cls Error: 11.610, L2M Error: 10.514, Alpha: [0.096 0.045 0.131 0.111 0.108 0.112 0.1   0.087 0.125 0.085]\n",
      "Iter 4, Epoch 31, Cls Error: 11.409, L2M Error: 10.337, Alpha: [0.095 0.045 0.131 0.111 0.109 0.113 0.101 0.086 0.125 0.085]\n",
      "Iter 4, Epoch 32, Cls Error: 11.204, L2M Error: 10.179, Alpha: [0.094 0.044 0.131 0.111 0.108 0.113 0.1   0.087 0.126 0.085]\n",
      "Iter 4, Epoch 33, Cls Error: 11.018, L2M Error: 10.060, Alpha: [0.094 0.043 0.131 0.111 0.108 0.113 0.101 0.087 0.126 0.086]\n",
      "Iter 4, Epoch 34, Cls Error: 10.880, L2M Error: 9.897, Alpha: [0.094 0.042 0.131 0.111 0.109 0.113 0.1   0.087 0.127 0.086]\n",
      "Iter 4, Epoch 35, Cls Error: 10.730, L2M Error: 9.779, Alpha: [0.094 0.042 0.131 0.111 0.109 0.113 0.1   0.087 0.127 0.085]\n",
      "Iter 4, Epoch 36, Cls Error: 10.545, L2M Error: 9.632, Alpha: [0.094 0.042 0.131 0.111 0.108 0.113 0.101 0.087 0.128 0.085]\n",
      "Iter 4, Epoch 37, Cls Error: 10.403, L2M Error: 9.523, Alpha: [0.094 0.042 0.131 0.111 0.108 0.113 0.101 0.087 0.129 0.085]\n",
      "Iter 4, Epoch 38, Cls Error: 10.312, L2M Error: 9.435, Alpha: [0.094 0.042 0.131 0.111 0.107 0.113 0.101 0.088 0.129 0.085]\n",
      "Iter 4, Epoch 39, Cls Error: 10.154, L2M Error: 9.314, Alpha: [0.094 0.042 0.131 0.111 0.106 0.113 0.101 0.087 0.129 0.085]\n"
     ]
    }
   ],
   "source": [
    "criterion = nn.MSELoss()  # Use MSELoss for reconstruction error\n",
    "N_total = sum(len(dataset) for dataset in tensor_datasets)\n",
    "\n",
    "# Initialize training and test losses\n",
    "epochs = 40\n",
    "iterations = 5\n",
    "M = int(np.floor(N_total / batch_size))  # Number of training batches\n",
    "train_errors = np.zeros((epochs, iterations))\n",
    "classical_errors = np.zeros((epochs, iterations))\n",
    "test_errors = np.zeros((epochs, iterations))\n",
    "classical_test_errors = np.zeros((epochs, iterations))\n",
    "torch.manual_seed(42); model_base = Autoencoder()\n",
    "\n",
    "for iters in range(iterations):\n",
    "    # Initialize the model, criterion, and optimizer\n",
    "    model = copy.deepcopy(model_base)\n",
    "    for param, param_base in zip(model.parameters(), model_base.parameters()):\n",
    "        param.data = param_base.data + torch.randn_like(param_base) * 5e-2  # Small noise perturbation\n",
    "    model_l2m = copy.deepcopy(model)\n",
    "    optimizer = optim.AdamW(model.parameters(), lr=5e-4)\n",
    "    optimizer_l2m = optim.AdamW(model_l2m.parameters(), lr=5e-4)\n",
    "    alpha = torch.tensor([len(dataset) / N_total for dataset in tensor_datasets], dtype=torch.float32)\n",
    "    classical_alpha = torch.tensor([len(dataset) / N_total for dataset in tensor_datasets], dtype=torch.float32)\n",
    "    alpha_lr = 1e-1\n",
    "\n",
    "    # Training loop\n",
    "    for epoch in range(epochs):\n",
    "        l2m_loss = 0; classical_loss = 0; total = 0; l2m_test_loss = 0; classical_test_loss = 0; total_test = 0;\n",
    "        prev_indices = np.zeros(k, dtype=int)\n",
    "        tracking_error = np.zeros(k, dtype=float)\n",
    "        shuffled_indices = shuffle_class_data(tensor_datasets)\n",
    "\n",
    "        # Learn2Mix Training\n",
    "        model_l2m.train()\n",
    "        for j in range(M):  # For each batch in an epoch\n",
    "            combined_images = []\n",
    "            for i in range(k):  # For each dataset\n",
    "                num_samples = max(int(alpha[i].item() * batch_size), 0)  # Number of samples from dataset 'i'\n",
    "                data_list = []; labels_list = []; remaining = num_samples\n",
    "                while remaining > 0:\n",
    "                    available = len(tensor_datasets[i]) - prev_indices[i]\n",
    "                    take = min(available, remaining)\n",
    "                    indices = shuffled_indices[i][prev_indices[i]:prev_indices[i] + take]\n",
    "                    data_list.append(tensor_datasets[i].tensors[0][indices])\n",
    "                    labels_list.append(tensor_datasets[i].tensors[1][indices])\n",
    "                    \n",
    "                    # Update the remaining samples and the previous index, and wrap around if the end of the dataset is reached\n",
    "                    remaining -= take; prev_indices[i] += take\n",
    "                    if prev_indices[i] >= len(tensor_datasets[i]): prev_indices[i] = 0  # Reset to start\n",
    "\n",
    "                # Concatenate all collected data\n",
    "                combined_images.append(torch.cat(data_list, dim=0))\n",
    "\n",
    "            # Inner optimization step: update model parameters\n",
    "            optimizer_l2m.zero_grad()\n",
    "            x_mixed = torch.cat(combined_images, dim=0)\n",
    "            z_mixed = model_l2m(x_mixed)\n",
    "            loss = criterion(z_mixed, x_mixed)      \n",
    "            loss.backward()\n",
    "            optimizer_l2m.step()\n",
    "\n",
    "            # Compute class-wise losses\n",
    "            start_idx = 0\n",
    "            for i in range(k):\n",
    "                num_samples = max(int(alpha[i].item() * batch_size), 0)  # Number of samples from dataset 'i'\n",
    "                tracking_error[i] = criterion(z_mixed[start_idx:start_idx + num_samples], x_mixed[start_idx:start_idx + num_samples])\n",
    "                start_idx += num_samples\n",
    "\n",
    "        # Outer optimization step: update alpha based on dataset-specific losses\n",
    "        rewards = tracking_error / np.sum(tracking_error)\n",
    "        alpha += alpha_lr * (torch.tensor(rewards) - alpha)\n",
    "\n",
    "        # Fixed weights training\n",
    "        model.train()\n",
    "        for j in range(M):  # For each batch in an epoch\n",
    "            combined_images = []\n",
    "            for i in range(k):  # For each dataset\n",
    "                num_samples = max(int(classical_alpha[i].item() * batch_size), 0)  # Number of samples from dataset 'i'\n",
    "                data_list = []; labels_list = []; remaining = num_samples\n",
    "                while remaining > 0:\n",
    "                    available = len(tensor_datasets[i]) - prev_indices[i]\n",
    "                    take = min(available, remaining)\n",
    "                    indices = shuffled_indices[i][prev_indices[i]:prev_indices[i] + take]\n",
    "                    data_list.append(tensor_datasets[i].tensors[0][indices])\n",
    "                    labels_list.append(tensor_datasets[i].tensors[1][indices])\n",
    "                    \n",
    "                    # Update the remaining samples and the previous index, and wrap around if the end of the dataset is reached\n",
    "                    remaining -= take; prev_indices[i] += take\n",
    "                    if prev_indices[i] >= len(tensor_datasets[i]): prev_indices[i] = 0  # Reset to start\n",
    "\n",
    "                # Concatenate all collected data\n",
    "                combined_images.append(torch.cat(data_list, dim=0))\n",
    "\n",
    "            # Inner optimization step: update model parameters\n",
    "            optimizer.zero_grad()\n",
    "            x_mixed = torch.cat(combined_images, dim=0)\n",
    "            z_mixed = model(x_mixed)\n",
    "            loss = criterion(z_mixed, x_mixed)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "        # # Classical Autoencoder Training\n",
    "        # model.train()\n",
    "        # for X_train, _ in train_loader:\n",
    "        #     optimizer.zero_grad()\n",
    "        #     classical_outputs = model(X_train)\n",
    "        #     loss = criterion(classical_outputs, X_train)\n",
    "        #     loss.backward()\n",
    "        #     optimizer.step()\n",
    "\n",
    "        # Computing Train Error\n",
    "        model.eval(); model_l2m.eval();\n",
    "        with torch.no_grad():\n",
    "            classical_loss = 0; learn2mix_loss = 0\n",
    "            for X_train, _ in train_loader:\n",
    "                train_outputs = model_l2m(X_train)\n",
    "                classical_outputs = model(X_train)\n",
    "\n",
    "                total += X_train.size(0)\n",
    "                l2m_loss += F.mse_loss(train_outputs, X_train, reduction='sum').item()\n",
    "                classical_loss += F.mse_loss(classical_outputs, X_train, reduction='sum').item()\n",
    "\n",
    "        # Computing Test Error\n",
    "        model.eval(); model_l2m.eval();\n",
    "        with torch.no_grad():\n",
    "            for X_test, _ in test_loader:\n",
    "                test_outputs = model_l2m(X_test)\n",
    "                classical_outputs = model(X_test)\n",
    "\n",
    "                total_test += X_test.size(0)\n",
    "                l2m_test_loss += F.mse_loss(test_outputs, X_test, reduction='sum').item()\n",
    "                classical_test_loss += F.mse_loss(classical_outputs, X_test, reduction='sum').item()\n",
    "\n",
    "        train_errors[epoch, iters] = l2m_loss / total       \n",
    "        classical_errors[epoch, iters] = classical_loss / total\n",
    "        test_errors[epoch, iters] = l2m_test_loss / total_test\n",
    "        classical_test_errors[epoch, iters] = classical_test_loss / total_test\n",
    "\n",
    "        if epoch % 1 == 0:\n",
    "            print(f\"Iter {iters}, Epoch {epoch}, Cls Error: {classical_test_errors[epoch, iters]:.3f}, L2M Error: {test_errors[epoch, iters]:.3f}, Alpha: {np.round(alpha.detach().numpy(),3)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "1f710b25",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean DNN:       10.0928, STDEV DNN:      0.2557\n",
      "Mean L2M:       9.3142, STDEV L2M:      0.1104\n"
     ]
    },
    {
     "data": {
      "image/png": "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WlDsCVDsCQA1kPFZvO6OgT2Om73hFFrCGZhgNqmNOeQ252Pn+KlPL+7JEB82JXYiIiIiInJIYpust8cxTjzhizjRpC9iItFFWyIBwk6YFida5hgL8GPZ/n2broMHC3fiIi7O/vl8OBH8wFEZAzgq8+v7kr79PX0tkTDv1W6nqnoDDTUfYxrK8LbsIjuyl4E0MdINmS4odIUpdNWDrx7Sdraq/96gH/jpEY9hd1FiJyIiIiIi3c62bGyXjSdxxZYEiYlfrNcvtohLIBKgxYkQjoQxAHhwufy43TYuoqt2uiyiC7k4kTa9fSkmwpiMAkzGV2H46dG9+eJbNsC/GyvZvfcT6vf+i2D9VtxNO0gP76HAaWC4O0KRG/YYm6E9F67DpsRORERERER6XGeJXyzpS1zIJRAOEAhHe/oCkTBhE44/x+3KwOWycVvRXj4bB+KLubTu7XM7EYb60xkyaBIUnQCW3aq3b2+ggTW71vH5lmom93RQDoMSOxERERER6VPiSZ/LQwoprcpi8/piRzASpCXcEu3t23cuJrrypxeXOxO3Fe3ts4hgGaed3r5o4pdrw/i8YzC7wiQTJXYiIiIiIpI0OprX5xinVcIXcSIEwgFawi1ETITmffP6oou4WNGkz/Lh8qTitlz7kj4Hy0QIWbXA5z3+bodDiV0f8tBDD/HQQw8RiUR6uyoiIiIiIknFtmy8Li9eV9v95xLn8sV7+sLBhKSvpVXSF+lgXmBfpsSuD5kzZw5z5syhrq6OrKys3q6OiIiIiEi/4LJduHB1OelramliW8Im6MlAiZ2IiIiIiPzXai/py3Bn9GKNDo3d2xUQERERERGRw6PETkREREREJMkpsRMREREREUlySuxERERERESSnBI7ERERERGRJKfETkREREREJMkpsRMREREREUlySuxERERERESSnBI7ERERERGRJKfETkREREREJMkpsRMREREREUlySuxERERERESSnBI7ERERERGRJKfETkREREREJMkpsRMREREREUlySuxERERERESSnBI7ERERERGRJKfETkREREREJMm5e7sC0pYxBoC6urpDfkYoFKKpqYm6ujo8Hk93VU0OoDj3HMW6ZyjOPUNx7jmKdc9QnHuG4txz+lKsYzlBLEfoiBK7Pqi+vh6AIUOG9HJNRERERESkL6ivrycrK6vDcsscLPWT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1fk//OEPFBUVccopp/RSzfq/vXv3smzZMiZOnNin/gPvb9xuN+eeey5Lly6lvr4+fv6zzz6jtLSUCy+8sBdr1/+98MILNDU1MWXKlN6uSlK46667WLhwIbfffjsLFixoU6723D0OFueOqD13j9LSUmzbZuTIkWrTR1BinDuiNt11AwcOpLS0tM1x5pln4vf7KS0t5e677066Nm2ZWDeD9AszZsxgzZo1/OxnP2PUqFEsWbKExx57jKeeeopvfOMbvV29fuHyyy9n6NChnHjiieTn57N582YWL17M1q1befXVVzn99NN7u4pJ69VXX6WxsZH6+nq+853vMGvWLP73f/8XiA5FSU1N5eOPP+akk05i8uTJ/L//9//iG4VWV1f3vY1C+6iDxbmyspLLL7+cSy+9lFGjRmFZFitXruRXv/oVRx11FO+//z5paWm9/BZ92+LFi7npppv42te+1m6yEfvFS+358HQlzv/5z3/UnrvB1VdfTWZmJieffDIDBgxgz549PP/88/z5z3/m5ptv5uc//zmgNn24uhJntekj54orruCFF16goaEhfi6p2nRvbaAnR0Z9fb354Q9/aAYOHGi8Xq85/vjjzZIlS3q7Wv3KT3/6UzNx4kSTlZVlXC6XKSgoMDNnzjSrVq3q7aolvWHDhhmg3WPbtm3x69asWWOmT59uUlNTTWZmprngggvMli1beq/iSeZgca6urjYzZ840w4cPNykpKcbr9Zqjjz7a3HLLLaampqa3q58USkpKOozxgf/Xq/Z86LoSZ7Xn7vHEE0+Y0047zeTn5xu3222ys7NNSUmJ+dOf/tTmWrXpQ9eVOKtNHzkdbfyeLG1aPXYiIiIiIiJJTnPsREREREREkpwSOxERERERkSSnxE5ERERERCTJKbETERERERFJckrsREREREREkpwSOxERERERkSSnxE5ERERERCTJKbETEZGkYlkWlmWxcOHC3q5Kn/anP/2Jr3zlK+Tk5GDbNpZlMXHixN6uVtJSuxORvk6JnYhIklixYkX8l0vLsrj00ksPes8VV1wRv17+e9xyyy18+9vf5u9//zs1NTUYY77wM8rKylq1t64cF1xwQfe/jIiIdIkSOxGRJPXcc8+xYcOG3q6G9DHbt2/nF7/4BQBTpkxh2bJlfPjhh2zYsIEXX3yxl2snIiJHiru3KyAiIofGGMOCBQtYunRpb1dF+pDS0lIikQgAjz/+OGPHjj3sZ55//vncfffdB70uMzPzsD9LREQOjRI7EZEklJ+fz549e3jppZdYu3YtkydP7u0qSR+xY8eO+M+jR4/ulmdmZ2czbty4bnmWiIgcGRqKKSKShK6//np8Ph8ACxYs6OXaSF8SCATiP3s8nl6siYiI9CQldiIiSai4uJirr74agGXLlvH+++8f0nOGDx+OZVlcccUVnV4XW4Rl+PDhbcoSF9n4/e9/D8DSpUuZMWMGhYWFpKWlMWHCBB588EFCoVD8PmMMzzzzDFOnTqWwsJDU1FQmT57MI4888oUW+3jrrbc477zzGDRoEH6/n5EjR3Ldddfx+eefd+n+Tz75hB/+8IeMHTuWrKwsUlJSGDlyJFdeeSVr167t8L7ExWxWrFiB4zg88cQTTJs2jQEDBmDb9kHj2pGysjJuuOEGxo4dS0ZGBqmpqRx99NF8//vf73BeZey7vPPOO+PnDlzcpKys7JDqczimTp2KZVlMnToViMb76quvZsSIEfj9fgYNGsSsWbN47733uvS8d955h29961sMHz4cv99PdnY2kyZN4vbbb6eysrJLzygrK2PevHmccMIJ5OXl4ff7GTFiBNOmTWPx4sV89tlnB33G6tWrueyyyyguLsbn8zF48GC+9a1v8dFHH3V6X01NDffccw+nnnoqOTk5eDweCgoKOO6445g5cya/+c1vqKio6NJ7iIi0YkREJCmUlpYawADmySefNDt37jQpKSkGMDNmzGj3ntmzZ8fvac+wYcMMYGbPnt3pZ8eeM2zYsDZl27Zta1Wva665Jv7vA48LL7zQhMNh09LSYi6++OIOr7vqqqs6rEvsmgULFpiFCxd2+IzMzEyzcuXKTt/rJz/5iXG73R0+w7IsM3/+/HbvTfw+Xn31VXP66ae3uf9gcW3PH/7wB+Pz+Tqsk8vlMvfee2+b+2LfZWfHtm3bulyPxO/1UN4jpqSkxACmpKTEvPLKKyYtLa3dutm2bRYvXtzhcyKRiJkzZ06n75eVlWXeeOONTutz//33G4/H0+lzSkpK2tyX2O4efPDBDttNampqh+1u06ZNpqio6KDf04MPPviFYiwiYowxSuxERJLEgYmdMcbceOON8XN///vf29zT04ndKaecYgBz1llnmaVLl5oPPvjA/OUvf4mfB8xjjz1mfvCDHxjAXH755WbZsmXmgw8+MM8++6wZM2ZMq2SpPbHyE0880QDmmGOOMb/73e/M6tWrzVtvvWW+//3vG9u2DWAyMjJMWVlZu8+544474s/6n//5H/P444+b9957z6xZs8Y8/fTT5tRTT42XP/DAA23uT/w+jj/+eAOY8847L/7er7zyinn22Wc7jeuBli1bZizLMoBJT083CxYsMH//+9/Ne++9ZxYvXmzy8/Pjn/nwww+3uveTTz4xGzZsaJVYb9iwodURDAa7XJfuTuyOPvpok52dbbKyssy9995r3n33XfPuu++ae+65x2RmZsY/68UXX2z3OTfffHP8mhEjRphHHnnErFq1ypSWlpobbrghnqx5vV6zfv36dp/xk5/8JP6M7Oxsc9ttt5k333zTrF271ixfvtwsWrTIfOlLXzJTp05tc2/svilTphjLssyECRPME088YVavXm3efvttc8MNN8Tb3dChQ00gEGjzjBNOOMEAxuPxmGuvvda8/PLLZvXq1eb99983L730krn11lvN6NGjldiJyCFRYicikiTaS+wqKiriPSDTpk1rc09PJ3aAmTt3bptrGhsbzfDhww1g8vPzjWVZ5le/+lWb63bt2mUyMjLiSVJ7Ej9r8uTJpr6+vs01f/zjH+PXXHzxxW3KV61aFf8l/Pbbb2/3cyKRiPnmN78ZTxD37t3bqjzx+wDMHXfc0e5zuioYDJrBgwfHk7p169a1uaasrMwMGjQo3jNUWVnZ5poFCxZ0+p13VeL3ev7557dJEts7Ghoa2jwnltjFetQ2bdrU5pqNGzfGk7uioqI2SdH//d//xb+vcePGtfkujDHm1VdfjV9z8skntyn/4IMP4uWjR48227dv7/Dd2ytL/K7POuusdhO3u+++O37N0qVLW5Vt3bq1Sz1yjuOY6urqDstFRDqixE5EJEm0l9gZY8y8efPi55cvX97qnp5O7IYMGdJhr1BiwjFlypQOP+vb3/62AUxOTk675Ym/YK9Zs6bD53z96183gHG73Wbnzp2tyi666CIDmBNOOME4jtPhM/bu3RsfFvnYY4+1Kkv8PkaPHm3C4XCHz+mKP//5z/Hn/fSnP+3wuqeeeip+3c9//vM25UcisevqUVpa2uY5iYndokWLOvy8n/3sZ/HrnnvuuVZlib2Q7733XofP+N73vhe/btWqVa3KLr30UgPR4bVr1679YsEw+9ud3+835eXl7V5TV1dnvF6vAcwNN9zQquwf//hH/BkffvjhF/58EZGD0eIpIiJJ7uabbyYjIwOAO+64o1frcuGFF3a4EuPxxx8f//mSSy7p8BkTJkwAYO/evdTU1HR43fjx4znhhBM6LP/Od74DQDgcZsWKFfHzoVCIV199FYCLL74Yy7I6fEZ2djbjx48H6HRxj0suuQSXy9VheVe89dZbQHTBk1jd2zNr1iyysrJa3ZMMLMti9uzZHZZfeeWV8e/iwPeK/fu4445jypQpHT7jqquuanMPgOM4vPbaawCUlJQwadKkL/4C+5xxxhkUFha2W5aRkcHRRx8NwKefftqqbNCgQfGfY4sMiYh0JyV2IiJJLi8vj7lz5wLwj3/8g9dff73X6tLZvmnZ2dlf+Lr6+voOrzvppJM6rcvJJ58c/3njxo3xnzdt2kRTUxMAt956a5uVIw881qxZA8Du3bs7/KzEpPVQxeo4fPjwDhMHAK/XG09MEt/rSJo9ezYmOsqn0yO28mV7RowYQX5+foflBQUF8VVXE98rEAiwefNmAE455ZRO6zlp0qT4HxYSn7Ft27b4Hwm+8pWvdPqMgxkzZkyn5bm5uUDbtjtixAhOO+00AH75y18yduxY5s+fz/Lly+PtUUTkcCixExHpB2688cZ4QjR//vxeq0dqamqHZbZtf+HrIpFIh9d1lvwADBgwIP5zdXV1/OdDXUq+s1++c3JyDumZiWJ1TKx3RwYOHNjqnmRwsO8L9r974nvt3bu3TXlHPB4PeXl5bZ6xZ8+e+M+JPWeHorO2C/vbb3ttd8mSJZx66qlA9A8Md911F9OnTyc7O5uSkhIeeeQRWlpaDqt+IvLfy93bFRARkcOXnZ3NjTfeyPz581m1ahXLli3jnHPO6e1qHVGdDaHsTOIv3Pfffz9f+9rXunRfWlpah2WHOwwzUVfey3yBff76iu54r556xpEyePBg3n33Xf72t7+xdOlSVq5cyaZNmwiFQrz99tu8/fbbLFq0iFdeeaXTXm0RkfYosRMR6Sfmzp3Lr3/9a6qqqpg/fz5nn332Qe+J9S44jtPpdY2Njd1Sx+5UXl7e5fLY8Dgg3qMD0fl248aN6/7KHYJYHTsb8hkTe7fE9+rrDvZ9wf7e1MT3SuwNPVhswuFwvKcu8RmJQ0B37tzZtQofQdOnT2f69OkAVFVV8dZbb/Hoo4+yfPlytm7dyiWXXMK6det6uZYikmw0FFNEpJ/IyMjg5ptvBmDdunX85S9/6dI90Hq4W3s++eSTw65fd1u9enWXyxOTt7Fjx+L1egF44403jkzlDkGsjmVlZZ0OFw2FQvFf+vtKUtoV27Zto6qqqsPyyspKysrKgNbv5fP54guSvP/++51+xrp16wiFQm2eMWLEiHiC+Pbbbx9S/Y+UvLw8LrnkEv72t79x3nnnAbB+/fr4vEIRka5SYici0o9cd9118blMCxYsOOiwtBEjRgCwdu3aDq/duHEjGzZs6N6KdoMNGzZ02qvxxBNPANFhkomLeqSmpsZ7S1asWMGqVauOaD276vTTTweiQwljdW/PCy+8QG1tbat7koExhj/+8Y8dlv/+97+Pt8ED3yv2702bNvHPf/6zw2c8/vjjbe6BaM/0WWedBcDKlSv7bG9YrF1C63mBIiJdocRORKQfSUtLY968eUA08XnllVc6vb6kpASIDk9bsmRJm/L6+vpOl97vbVdffXW7w0SfeeaZ+LtfcMEFbRbM+PGPfxyfa3XppZeydevWDj8jEonwzDPP8Pnnn3djzduaOXMmRUVFANx77718+OGHba7Zvn07N910ExBNUK+88sojWqfudtddd7Xb+/vRRx9xzz33ANHFTc4///xW5ddcc0182PDVV18dT2wTvfHGG/zud78DoiuiHrhq6k033YRt2xhjuPTSSzv9Po/Ed71+/XrWr1/fYbkxptWWF7EVQkVEukpz7ERE+plrrrmGRYsWsWvXroP+1f+b3/wmCxcupK6uju9+97ts2bKFM888M77M/y9+8Qt27NjBpEmT+lwvx4knnsiaNWs48cQTmTdvHuPHj6e2tpYXXniB3/72t0B0qOmiRYva3PulL32J+fPnc+edd7Jt2zYmTpzId7/7XWbMmMGgQYMIBAKUlZXx3nvv8cILL7Bz5042bNhAcXHxEXsfj8fDo48+yrnnnkt9fT1f/vKXufnmm5k+fTput5t3332X++67Lz5Mc9GiRZ1uH9CdampqurS1gsvl4thjj2237Oijj6aiooIpU6Ywb968eC/qihUruO++++LJ2oMPPhgfKhszfvx4fvSjH3H//fezYcMGJk+ezLx585g0aRJNTU28/PLLPPDAA0QiEbxeb/z7TzRx4kTuvPNO7rjjDv79738zfvx45syZw7Rp08jLy6Ompob169ezdOlSXC4XpaWlXzBKnVu/fj1XXnklJ510Eueeey6TJ09m4MCBhEIhtm3bxpNPPsmbb74JwPnnn3/Yq3eKyH+hHt4QXUREDlFpaakBDGCefPLJTq998MEH49fGjo4899xzxuVytbkeMH6/3zz33HNm9uzZBjDDhg1rc/+2bdu6VK/E+peWlnZ43ZNPPhm/btu2bW3KY2ULFiwwCxYsaLfegMnMzDQrVqzoJErG/PKXvzQ+n6/DZ8QOr9drNm/efEjv80X9/ve/77ROLpfL3HvvvR3enxiTw5H4vXb1yMrKavOckpISA5iSkhKzbNkyk5qa2u69tm2bRYsWdVifSCRirr322oN+/uuvv97pe917773G7XZ3+pySkpI29yW2u84kvm+ixHbd2fHlL3/ZVFVVdfoZIiLt0VBMEZF+6KqrrmLIkCFdunbWrFm8++67zJw5k4KCArxeL0OGDGH27NmsWbOGWbNmHeHaHrqFCxfy2muvcfbZZzNgwAC8Xi/Dhw/n2muv5V//+ld8qGlH5s6dy9atW7njjjuYMmUK+fn5uN1u0tLSGD16NBdddBGPPPIIO3bsYNSoUT3yTrNnz+bjjz/m+uuv59hjjyUtLY2UlBSOOuoorrrqKtatW8ett97aI3XpbmeffTZr1qzhyiuvZNiwYXi9XgoLC7nooot45513+NGPftThvbZt89BDD/H222/zjW98g6FDh+Lz+cjMzGTixIncdtttbN68mRkzZnRah1tvvZVNmzYxd+5cxo0bR2ZmJn6/n5EjRzJ9+nR+9atf8eyzz3b3q3P55ZdTWlrKbbfdxmmnncaIESNITU3F6/VSXFzMeeedxzPPPMPKlSuTarVTEek7LGOScDMcERERSQpTp05l5cqVlJSUsGLFit6ujohIv6UeOxERERERkSSnxE5ERERERCTJKbETERERERFJckrsREREREREkpwSOxERERERkSSnVTFFRERERESSnHrsREREREREkpwSOxERERERkSSnxE5ERERERCTJKbETERERERFJckrsREREREREkpwSOxERERERkSSnxE5ERERERCTJKbETERERERFJckrsREREREREktz/B/JLxa4eUhG+AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Step 2: Compute means and 95% confidence intervals\n",
    "def compute_mean_and_CI(data):\n",
    "    mean = np.mean(data, axis=0)\n",
    "    std_error = np.std(data, axis=0) / np.sqrt(data.shape[0])  # Standard error of the mean\n",
    "    stdev = np.std(data, axis=0)\n",
    "    ci = 1.96 * std_error  # 95% CI for a normal distribution\n",
    "    return mean, ci, stdev\n",
    "\n",
    "A = classical_errors.T[:,:]; B = train_errors.T[:,:]\n",
    "mean_A, ci_A, stdev_A = compute_mean_and_CI(A)\n",
    "mean_B, ci_B, stdev_B = compute_mean_and_CI(B)\n",
    "\n",
    "X = classical_test_errors.T[:,:]; Z = test_errors.T[:,:]\n",
    "mean_X, ci_X, stdev_X = compute_mean_and_CI(X)\n",
    "mean_Z, ci_Z, stdev_Z = compute_mean_and_CI(Z)\n",
    "\n",
    "print(f'Mean DNN:       {mean_X[len(mean_X)-1].round(4)}, STDEV DNN:      {stdev_X[len(stdev_X)-1].round(4)}')\n",
    "print(f'Mean L2M:       {mean_Z[len(mean_Z)-1].round(4)}, STDEV L2M:      {stdev_Z[len(stdev_Z)-1].round(4)}')\n",
    "\n",
    "# Step 3: Plot the results\n",
    "epochs_all = list(range(1, X.shape[1] + 1))\n",
    "plt.figure(figsize=(10, 6))\n",
    "\n",
    "# Plotting for A\n",
    "plt.fill_between(epochs_all, mean_A - ci_A, mean_A + ci_A, color='green', alpha=0.1, zorder=0)\n",
    "plt.plot(epochs_all, mean_A, 'g-', label=\"Classical Train Error\", zorder=20)\n",
    "\n",
    "# Plotting for X\n",
    "plt.fill_between(epochs_all, mean_X - ci_X, mean_X + ci_X, color='blue', alpha=0.1, zorder=0)\n",
    "plt.plot(epochs_all, mean_X, 'b-', label=\"Classical Test Error\", zorder=20)\n",
    "\n",
    "# Plotting for B\n",
    "plt.fill_between(epochs_all, mean_B - ci_B, mean_B + ci_B, color='orange', alpha=0.1, zorder=0)\n",
    "plt.plot(epochs_all, mean_B, '-', color='orange', label=\"Learn2Mix Train Error\", zorder=20)\n",
    "\n",
    "# Plotting for Z\n",
    "plt.fill_between(epochs_all, mean_Z - ci_Z, mean_Z + ci_Z, color='red', alpha=0.3, zorder=10)\n",
    "plt.plot(epochs_all, mean_Z, 'r-', label=\"Learn2Mix Test Error\", zorder=30)\n",
    "\n",
    "# Additional plot settings\n",
    "plt.xlabel(\"Number of Epochs\", fontsize=20)\n",
    "plt.ylabel(\"Error\", fontsize=20)\n",
    "plt.yscale('log')\n",
    "plt.xticks(fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "plt.legend(prop={'size': 18},loc='upper right')\n",
    "plt.grid(True)\n",
    "plt.savefig('test.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bb5af041",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
