{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "import os, copy, pickle, datetime, random\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from collections import defaultdict\n",
    "from tqdm import tqdm\n",
    "from copy import deepcopy\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torchvision\n",
    "from torch.utils.data import DataLoader, Subset, TensorDataset\n",
    "\n",
    "from utils import set_seed\n",
    "from get_data_ours import get_loader\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Current cuda device  0\n"
     ]
    }
   ],
   "source": [
    "# Assign GPU number\n",
    "GPU_NUM = 0  # Desired GPU index\n",
    "device = torch.device(f'cuda:{GPU_NUM}' if torch.cuda.is_available() else 'cpu')\n",
    "torch.cuda.set_device(device)  # Change allocation to the selected GPU\n",
    "print('Current cuda device ', torch.cuda.current_device())  # Check current GPU index\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def get_erm_model(device, n_class=10, lr=0.0005, weight_decay=0, n_channel=3):\n",
    "    print(\"Using a CNN model with Batch Normalization as feature extractor\")\n",
    "\n",
    "    # Feature Extractor 정의\n",
    "    feature_extractor = nn.Sequential(\n",
    "        nn.Conv2d(n_channel, 32, kernel_size=5, padding=2),  \n",
    "        nn.BatchNorm2d(32),\n",
    "        nn.ReLU(),\n",
    "        nn.MaxPool2d(kernel_size=2, stride=2),  \n",
    "        nn.Conv2d(32, 48, kernel_size=5, padding=2),  \n",
    "        nn.BatchNorm2d(48),\n",
    "        nn.ReLU(),\n",
    "        nn.MaxPool2d(kernel_size=2, stride=2),  \n",
    "\n",
    "        nn.Conv2d(48, 64, kernel_size=5, padding=2), \n",
    "        nn.BatchNorm2d(64),\n",
    "        nn.ReLU(),\n",
    "        nn.MaxPool2d(kernel_size=2, stride=2),  \n",
    "\n",
    "        nn.Flatten(), \n",
    "    )\n",
    "\n",
    "    dummy_input = torch.randn(1, n_channel, 32, 32)  \n",
    "    with torch.no_grad():\n",
    "        output_features = feature_extractor(dummy_input).view(-1).size(0)\n",
    "\n",
    "    print(f\"Feature Extractor Output Feature Size: {output_features}\")\n",
    "\n",
    "    label_predictor = nn.Sequential(\n",
    "        nn.Linear(output_features, 128),  \n",
    "        nn.BatchNorm1d(128),\n",
    "        nn.ReLU(),\n",
    "        nn.Linear(128, 64),\n",
    "        nn.BatchNorm1d(64),\n",
    "        nn.ReLU(),\n",
    "        nn.Linear(64, n_class)\n",
    "    )\n",
    "\n",
    "    feature_extractor = feature_extractor.to(device)\n",
    "    label_predictor = label_predictor.to(device)\n",
    "    models = {\n",
    "        \"G\": feature_extractor,\n",
    "        \"C\": label_predictor\n",
    "    }\n",
    "\n",
    "    optimizer_G = torch.optim.Adam(\n",
    "        feature_extractor.parameters(), lr=lr, weight_decay=weight_decay,  betas=[0.5, 0.999]\n",
    "    )\n",
    "    optimizer_C = torch.optim.Adam(\n",
    "        label_predictor.parameters(), lr=lr, weight_decay=weight_decay,  betas=[0.5, 0.999]\n",
    "    )\n",
    "    \n",
    "    optimizers = [optimizer_G, optimizer_C]\n",
    "\n",
    "    return models, optimizers\n",
    "\n",
    "\n",
    "\n",
    "def prediction_batch(model_path, target_data_loader, device, models, latent=False):\n",
    "    \"\"\"\n",
    "    Generate predictions in batches and return them.\n",
    "\n",
    "    Args:\n",
    "        model_path (str): Path to the model checkpoint.\n",
    "        target_data_loader (DataLoader): DataLoader for target data.\n",
    "        device (torch.device): Device to run on.\n",
    "        models (dict): Dictionary of models to load (G: Feature Extractor, C: Classifier).\n",
    "        latent (bool): If True, use inputs directly without the Feature Extractor.\n",
    "\n",
    "    Returns:\n",
    "        list: List of predictions for each batch, shape (batch_size, n_class).\n",
    "    \"\"\"\n",
    "    # Load model checkpoint\n",
    "    checkpoint = torch.load(model_path, map_location=device)\n",
    "    models[\"G\"].load_state_dict(checkpoint[\"G\"])\n",
    "    models[\"C\"].load_state_dict(checkpoint[\"C\"])\n",
    "\n",
    "    # Set models to evaluation mode\n",
    "    models[\"G\"].eval()\n",
    "    models[\"C\"].eval()\n",
    "\n",
    "    # Store predictions for each batch\n",
    "    batch_predictions = []\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for inputs, _ in target_data_loader:\n",
    "            inputs = inputs.to(device)\n",
    "\n",
    "            if not latent:\n",
    "                features = models[\"G\"](inputs)  # Extract features using the Feature Extractor\n",
    "            else:\n",
    "                features = inputs  # Use pre-extracted features directly\n",
    "\n",
    "            predictions = models[\"C\"](features)  # Generate predictions with the Classifier\n",
    "\n",
    "            # Move predictions to CPU and store\n",
    "            batch_predictions.append(predictions.cpu())\n",
    "\n",
    "            # Free GPU memory\n",
    "            del inputs, features, predictions\n",
    "            torch.cuda.empty_cache()\n",
    "\n",
    "    return batch_predictions\n",
    "\n",
    "\n",
    "\n",
    "def get_classifier_predictions(classifiers, feature_extractor, unlabeled_loader, device):\n",
    "    \"\"\"\n",
    "    Compute prediction probabilities on unlabeled data using multiple classifiers \n",
    "    and a feature extractor.\n",
    "\n",
    "    Args:\n",
    "        classifiers: List of trained classifiers (nn.Module)\n",
    "        feature_extractor: Backbone model (ERM feature extractor)\n",
    "        unlabeled_loader: DataLoader containing unlabeled images\n",
    "        device: Computation device (cuda or cpu)\n",
    "\n",
    "    Returns:\n",
    "        stacked_probs: Tensor of shape (n_classifiers, N_unlabeled, num_classes)\n",
    "    \"\"\"\n",
    "    print(\"Function called: get_classifier_predictions\")\n",
    "\n",
    "    feature_extractor.eval()\n",
    "    for clf in classifiers:\n",
    "        clf.eval()\n",
    "\n",
    "    all_logits = []\n",
    "\n",
    "    with torch.no_grad():\n",
    "        # Extract features for the entire dataset\n",
    "        all_features = []\n",
    "        for x, _ in unlabeled_loader:\n",
    "            x = x.to(device)\n",
    "            feats = feature_extractor(x)  # (B, feature_dim)\n",
    "            all_features.append(feats.cpu())\n",
    "\n",
    "        features_all = torch.cat(all_features, dim=0).to(device)  # (N, D)\n",
    "\n",
    "        # Run prediction with each classifier\n",
    "        for clf in classifiers:\n",
    "            logits = clf(features_all)  # (N, num_classes)\n",
    "            all_logits.append(logits.cpu())\n",
    "\n",
    "    # Stack predictions → (n_classifiers, N, num_classes)\n",
    "    stacked_probs = torch.stack(all_logits)\n",
    "\n",
    "    return stacked_probs\n",
    "\n",
    "\n",
    "def mirror_descent_with_kl_ball(base_predictions, y_hat, nominal_weights, previous_weight,\n",
    "                                num_base_model=5, lr=0.01, rho=1, threshold=1e-4,\n",
    "                                max_iterations=20, rho_list=None):\n",
    "    \"\"\"\n",
    "    Mirror Descent with KL-divergence and L2 ball projection to find optimal weights.\n",
    "    \"\"\"\n",
    "\n",
    "    base_predictions = base_predictions.cpu()\n",
    "    y_hat = y_hat.cpu()\n",
    "    nominal_weights = nominal_weights.cpu()\n",
    "\n",
    "    def run_mirror_descent(rho_value):\n",
    "        weights = previous_weight.clone().detach().cpu()\n",
    "        weights.requires_grad = True\n",
    "        prev_weights = weights.clone().detach()\n",
    "        criterion = torch.nn.CrossEntropyLoss()\n",
    "\n",
    "        for i in range(max_iterations):\n",
    "            y_tilda = torch.einsum('i,ijk->jk', weights, base_predictions)\n",
    "            loss = criterion(y_tilda, y_hat)\n",
    "            loss.backward()\n",
    "\n",
    "            if weights.grad is None:\n",
    "                raise RuntimeError(\"weights.grad is None. Autograd graph may have been broken.\")\n",
    "\n",
    "            with torch.no_grad():\n",
    "                grad = weights.grad.clone()\n",
    "\n",
    "                # Mirror descent update\n",
    "                weights = weights * torch.exp(lr * grad)\n",
    "                weights = weights / weights.sum()\n",
    "\n",
    "                # L2 ball projection\n",
    "                diff_from_nominal = torch.norm(weights - nominal_weights, p=2)\n",
    "                if diff_from_nominal > rho_value:\n",
    "                    weights = weights - nominal_weights\n",
    "                    weights = weights * (rho_value / diff_from_nominal)\n",
    "                    weights = weights + nominal_weights\n",
    "\n",
    "                weights = weights.detach().requires_grad_()\n",
    "\n",
    "            weights.grad = None\n",
    "            weight_diff = torch.norm(weights - prev_weights, p=2).item()\n",
    "            prev_weights.copy_(weights)\n",
    "\n",
    "            if weight_diff < threshold:\n",
    "                break\n",
    "\n",
    "        return weights\n",
    "\n",
    "    if rho_list is None:\n",
    "        return run_mirror_descent(rho)\n",
    "    return [run_mirror_descent(rho_val) for rho_val in rho_list]\n",
    "\n",
    "\n",
    "def update_adv_weight(base_predictions, y_hat, nominal_weights, previous_weight, num_base_model, rho, lr_weight):\n",
    "    \"\"\"\n",
    "    Mirror descent based weight update function on CPU.\n",
    "    \"\"\"\n",
    "    adv_weight = mirror_descent_with_kl_ball(\n",
    "        base_predictions, y_hat, nominal_weights, previous_weight,\n",
    "        num_base_model=num_base_model, rho=rho, rho_list=None,\n",
    "        lr=lr_weight\n",
    "    )\n",
    "    return adv_weight\n",
    "\n",
    "\n",
    "def test_model(data_loader, models, device):\n",
    "    \"\"\"\n",
    "    Evaluate model performance on a given dataset.\n",
    "    \n",
    "    Args:\n",
    "        data_loader: DataLoader with test data\n",
    "        models: dict containing feature extractor (G) and classifier (C)\n",
    "        device: cuda or cpu\n",
    "    \n",
    "    Returns:\n",
    "        avg_loss: average loss\n",
    "        avg_accuracy: average accuracy\n",
    "    \"\"\"\n",
    "    models[\"G\"].eval()\n",
    "    models[\"C\"].eval()\n",
    "\n",
    "    feature_extractor = models[\"G\"]\n",
    "    label_predictor = models[\"C\"]\n",
    "    loss_fn = torch.nn.CrossEntropyLoss()\n",
    "\n",
    "    total_loss = 0.0\n",
    "    correct_preds = 0\n",
    "    total_samples = 0\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for inputs, labels in data_loader:\n",
    "            inputs, labels = inputs.to(device), labels.to(device)\n",
    "            features = feature_extractor(inputs)\n",
    "            logits = label_predictor(features)\n",
    "\n",
    "            loss = loss_fn(logits, labels)\n",
    "            total_loss += loss.item() * inputs.size(0)\n",
    "\n",
    "            preds = torch.argmax(logits, dim=1)\n",
    "            correct_preds += (preds == labels).sum().item()\n",
    "            total_samples += labels.size(0)\n",
    "\n",
    "    avg_loss = total_loss / total_samples\n",
    "    avg_accuracy = correct_preds / total_samples\n",
    "\n",
    "    return avg_loss, avg_accuracy\n",
    "\n",
    "def train_model_batch(\n",
    "    models, optimizers, loss_fn, dataloaders, base_predictions, nominal_weights, device,\n",
    "    num_epochs=5, model_batch_size=128, max_outer_iteration=10, max_adv_iteration=1, threshold=1e-20,\n",
    "    rho=0.1, lr_weight=0.01, scheduler=None, epsilon=0.1, patience=20, latent = True\n",
    "):\n",
    "    \"\"\"\n",
    "    Train model with adversarial weight updates and early stopping.\n",
    "    \"\"\"\n",
    "    val_loader = dataloaders[\"valid\"]\n",
    "    target_loader = deepcopy(dataloaders[\"target_train\"])\n",
    "    test_data_loader = deepcopy(dataloaders[\"target_test\"])\n",
    "\n",
    "    best_val_accuracy = 0.0\n",
    "    best_val_loss = float(\"inf\")\n",
    "    val_best_test_acc = 0.0\n",
    "    best_test_loss = float(\"inf\")\n",
    "    adv_weight = nominal_weights.clone().cpu()\n",
    "    no_improvement_count = 0\n",
    "\n",
    "    val_loss, val_accuracy = test_model(val_loader, models, device)\n",
    "    test_loss, test_accuracy = test_model(test_data_loader, models, device)\n",
    "    print(f\"Initial - Test Loss: {test_loss:.4f}, Test Acc: {test_accuracy:.4f}\")\n",
    "    print(f\"Initial - Val Loss: {val_loss:.4f}, Val Acc: {val_accuracy:.4f}\")\n",
    "\n",
    "    for outer_iter in range(max_outer_iteration):\n",
    "        print(f\"\\n--- Outer Iteration {outer_iter + 1}/{max_outer_iteration} ---\")\n",
    "\n",
    "        # Adversarial update\n",
    "        _, adv_inputs = update_adv_loader(target_loader, models, device, epsilon, latent=latent)\n",
    "        y_tilda = torch.einsum(\"i,ijk->jk\", adv_weight, base_predictions)\n",
    "        y_tilda_labels = torch.argmax(y_tilda, dim=1).long()\n",
    "\n",
    "        adv_dataset = TensorDataset(adv_inputs, y_tilda_labels)\n",
    "        adv_loader = DataLoader(adv_dataset, batch_size=target_loader.batch_size, shuffle=False)\n",
    "\n",
    "        # Compute y_hat\n",
    "        y_hat_list = []\n",
    "        with torch.no_grad():\n",
    "            for inputs, _ in adv_loader:\n",
    "                if latent:\n",
    "                    features = inputs.to(device)\n",
    "                else:\n",
    "                    inputs = inputs.to(device)\n",
    "                    features = models[\"G\"](inputs)\n",
    "                y_hat_list.append(models[\"C\"](features).cpu())\n",
    "        y_hat_tensor = torch.cat(y_hat_list, dim=0)\n",
    "        y_hat_labels = torch.argmax(y_hat_tensor, dim=1).long()\n",
    "\n",
    "        # Weight update\n",
    "        adv_weight = update_adv_weight(\n",
    "            base_predictions,\n",
    "            y_hat_labels,\n",
    "            nominal_weights,\n",
    "            previous_weight=adv_weight,\n",
    "            num_base_model=num_base_model,\n",
    "            rho=rho,\n",
    "            lr_weight=lr_weight,\n",
    "        )\n",
    "\n",
    "        # Updated pseudo-labels\n",
    "        y_tilda = torch.einsum(\"i,ijk->jk\", adv_weight, base_predictions)\n",
    "        y_tilda_labels = torch.argmax(y_tilda, dim=1).long()\n",
    "\n",
    "        adv_dataset = TensorDataset(adv_inputs, y_tilda_labels)\n",
    "        adv_loader = DataLoader(adv_dataset, batch_size=target_loader.batch_size, shuffle=True)\n",
    "\n",
    "        # Training loop\n",
    "        for epoch in range(num_epochs):\n",
    "            models[\"G\"].train()\n",
    "            models[\"C\"].train()\n",
    "            total_loss, total_correct, total_samples = 0.0, 0, 0\n",
    "\n",
    "            for inputs, labels in tqdm(adv_loader):\n",
    "                inputs, labels = inputs.to(device), labels.to(device)\n",
    "\n",
    "                if not latent:\n",
    "                    optimizers[0].zero_grad()\n",
    "                optimizers[1].zero_grad()\n",
    "\n",
    "                features = inputs if latent else models[\"G\"](inputs)\n",
    "                logits = models[\"C\"](features)\n",
    "                loss = loss_fn(logits, labels)\n",
    "                loss.backward()\n",
    "\n",
    "                if not latent:\n",
    "                    optimizers[0].step()\n",
    "                optimizers[1].step()\n",
    "\n",
    "                total_loss += loss.item() * inputs.size(0)\n",
    "                total_correct += (torch.argmax(logits, dim=1) == labels).sum().item()\n",
    "                total_samples += inputs.size(0)\n",
    "\n",
    "            train_loss = total_loss / total_samples\n",
    "            train_accuracy = total_correct / total_samples\n",
    "            val_loss, val_accuracy = test_model(val_loader, models, device)\n",
    "            test_loss, test_accuracy = test_model(test_data_loader, models, device)\n",
    "\n",
    "            print(f\"Epoch {epoch+1}/{num_epochs} - \"\n",
    "                  f\"Train Loss: {train_loss:.4f}, Train Acc: {train_accuracy:.4f} | \"\n",
    "                  f\"Val Loss: {val_loss:.4f}, Val Acc: {val_accuracy:.4f} | \"\n",
    "                  f\"Test Loss: {test_loss:.4f}, Test Acc: {test_accuracy:.4f}\")\n",
    "\n",
    "            if val_accuracy > best_val_accuracy:\n",
    "                best_val_accuracy = val_accuracy\n",
    "                val_best_test_acc = test_accuracy\n",
    "                best_val_loss = val_loss\n",
    "                best_test_loss = test_loss\n",
    "                no_improvement_count = 0\n",
    "            else:\n",
    "                no_improvement_count += 1\n",
    "                if no_improvement_count >= patience:\n",
    "                    print(f\"Early stopping at Epoch {epoch+1}\")\n",
    "                    return models, val_best_test_acc, best_val_loss, best_test_loss, adv_loader\n",
    "\n",
    "            if scheduler is not None:\n",
    "                scheduler.step(train_loss)\n",
    "\n",
    "    print(\"Training completed.\")\n",
    "    return models, val_best_test_acc, best_val_loss, best_test_loss, adv_loader\n",
    "\n",
    "\n",
    "def update_adv_loader(target_loader, models, device, epsilon, latent=False):\n",
    "    \"\"\"\n",
    "    Generate adversarial inputs (x_adv or z_adv) and return a new DataLoader.\n",
    "    \"\"\"\n",
    "    adv_inputs = []\n",
    "    adv_labels = []\n",
    "\n",
    "    for inputs, labels in target_loader:\n",
    "        inputs, labels = inputs.to(device), labels.to(device)\n",
    "\n",
    "        if not latent:\n",
    "            inputs.requires_grad = True\n",
    "            features = models[\"G\"](inputs)\n",
    "            logits = models[\"C\"](features)\n",
    "            loss = torch.nn.CrossEntropyLoss()(logits, labels)\n",
    "            loss.backward()\n",
    "            adv_input = inputs + epsilon * inputs.grad.sign()\n",
    "        else:\n",
    "            with torch.no_grad():\n",
    "                z = models[\"G\"](inputs)\n",
    "            z.requires_grad = True\n",
    "            logits = models[\"C\"](z)\n",
    "            loss = torch.nn.CrossEntropyLoss()(logits, labels)\n",
    "            loss.backward()\n",
    "            adv_input = z + epsilon * z.grad.sign()\n",
    "\n",
    "        adv_inputs.append(adv_input.detach().cpu())\n",
    "        adv_labels.append(labels.detach().cpu())\n",
    "\n",
    "    adv_inputs = torch.cat(adv_inputs, dim=0)\n",
    "    adv_labels = torch.cat(adv_labels, dim=0)\n",
    "    adv_dataset = TensorDataset(adv_inputs, adv_labels)\n",
    "    adv_loader = DataLoader(adv_dataset, batch_size=target_loader.batch_size, shuffle=False)\n",
    "\n",
    "    return adv_loader, adv_inputs\n",
    "\n",
    "def save_and_print_results(base_model_results, timestamp, dataset, type_base_model, max_outer_iteration, latent, seed, max_adv_iteration=1, u=0):\n",
    "    \"\"\"\n",
    "    Print and save final results as a CSV file.\n",
    "    \"\"\"\n",
    "    print(\"---- Final Results ----\")\n",
    "    for result in base_model_results:\n",
    "        print(f\"num_base_model={result[0]}, rho={result[1]}, epsilon={result[2]} | \"\n",
    "              f\"Val-Best Test Loss={result[3]:.4f}, Val-Best Test Acc={result[4]:.4f} | \"\n",
    "              f\"Last Test Loss={result[5]:.4f}, Last Test Acc={result[6]:.4f}\")\n",
    "\n",
    "    results_df = pd.DataFrame(base_model_results, columns=[\n",
    "        \"num_base_model\", \"e2\", \"e1\", \"val_best_test_loss\", \"val_best_test_acc\", \"last_test_loss\", \"last_test_accuracy\"\n",
    "    ])\n",
    "\n",
    "    csv_save_path = os.path.join(\n",
    "        \"./Ours_results\", f\"{dataset}\",\n",
    "        f\"{timestamp}_{dataset}_{type_base_model}_max_iter_{max_outer_iteration}_latent_{latent}_u{u}.csv\"\n",
    "    )\n",
    "\n",
    "    os.makedirs(os.path.dirname(csv_save_path), exist_ok=True)\n",
    "    results_df.to_csv(csv_save_path, index=False)\n",
    "\n",
    "    print(f\"Results saved to {csv_save_path}\")\n",
    "\n",
    "\n",
    "\n",
    "def split_source_loader(s_train_loader, K=100, num_splits=10, batch_size=128, replacement=True, seed=11):\n",
    "    dataset = s_train_loader.dataset\n",
    "    targets = dataset.targets if hasattr(dataset, \"targets\") else [y for _, y in dataset]\n",
    "    label_to_indices = defaultdict(list)\n",
    "    for idx, label in enumerate(targets):\n",
    "        label = int(label)\n",
    "        label_to_indices[label].append(idx)\n",
    "\n",
    "    random.seed(seed)\n",
    "    split_loaders = []\n",
    "    for split_idx in range(num_splits):\n",
    "        selected_indices = []\n",
    "        for label, indices in label_to_indices.items():\n",
    "            chosen = random.choices(indices, k=K) if replacement else random.sample(indices, k=K)\n",
    "            selected_indices.extend(chosen)\n",
    "\n",
    "        subset = Subset(dataset, selected_indices)\n",
    "        loader = DataLoader(subset, batch_size=batch_size, shuffle=True, drop_last=True)\n",
    "        split_loaders.append(loader)\n",
    "\n",
    "    return split_loaders\n",
    "\n",
    "\n",
    "def train_classifiers(split_loaders, ERM_feature_map, valid_loader, n_class, device, \n",
    "                      n_epochs=20, lr=1e-3, weight_decay=0, patience=10):\n",
    "    \"\"\"\n",
    "    Train linear classifiers on split feature sets with early stopping.\n",
    "    \"\"\"\n",
    "    classifiers = []\n",
    "    ERM_feature_map.eval()  # keep feature extractor fixed\n",
    "\n",
    "    for split_idx, loader in enumerate(split_loaders):\n",
    "        print(f\"\\n--- Split {split_idx+1}/{len(split_loaders)} ---\")\n",
    "\n",
    "        # Get feature dimension\n",
    "        with torch.no_grad():\n",
    "            dummy_input, _ = next(iter(loader))\n",
    "            dummy_input = dummy_input.to(device)\n",
    "            feature_dim = ERM_feature_map(dummy_input).view(dummy_input.size(0), -1).size(1)\n",
    "\n",
    "        classifier = nn.Linear(feature_dim, n_class).to(device)\n",
    "        optimizer = optim.Adam(classifier.parameters(), lr=lr, weight_decay=weight_decay)\n",
    "        criterion = nn.CrossEntropyLoss()\n",
    "\n",
    "        best_val_acc, no_improve = 0.0, 0\n",
    "\n",
    "        for epoch in range(n_epochs):\n",
    "            classifier.train()\n",
    "            total_loss, correct, total = 0.0, 0, 0\n",
    "\n",
    "            for inputs, labels in loader:\n",
    "                inputs, labels = inputs.to(device), labels.to(device)\n",
    "                with torch.no_grad():\n",
    "                    features = ERM_feature_map(inputs).view(inputs.size(0), -1)\n",
    "\n",
    "                outputs = classifier(features)\n",
    "                loss = criterion(outputs, labels)\n",
    "\n",
    "                optimizer.zero_grad()\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "\n",
    "                total_loss += loss.item() * inputs.size(0)\n",
    "                preds = torch.argmax(outputs, dim=1)\n",
    "                correct += (preds == labels).sum().item()\n",
    "                total += labels.size(0)\n",
    "\n",
    "            train_loss = total_loss / total\n",
    "            train_acc = correct / total\n",
    "\n",
    "            # Validation\n",
    "            classifier.eval()\n",
    "            val_correct, val_total = 0, 0\n",
    "            with torch.no_grad():\n",
    "                for inputs, labels in valid_loader:\n",
    "                    inputs, labels = inputs.to(device), labels.to(device)\n",
    "                    features = ERM_feature_map(inputs).view(inputs.size(0), -1)\n",
    "                    outputs = classifier(features)\n",
    "                    preds = torch.argmax(outputs, dim=1)\n",
    "                    val_correct += (preds == labels).sum().item()\n",
    "                    val_total += labels.size(0)\n",
    "            val_acc = val_correct / val_total\n",
    "\n",
    "            print(f\"Split {split_idx+1}, Epoch {epoch+1}/{n_epochs} | \"\n",
    "                  f\"Train Loss: {train_loss:.4f}, Train Acc: {train_acc:.4f} | \"\n",
    "                  f\"Val Acc: {val_acc:.4f}\")\n",
    "\n",
    "            if val_acc > best_val_acc:\n",
    "                best_val_acc, no_improve = val_acc, 0\n",
    "            else:\n",
    "                no_improve += 1\n",
    "\n",
    "            if no_improve >= patience:\n",
    "                \n",
    "                break\n",
    "\n",
    "        classifiers.append(classifier)\n",
    "\n",
    "    return classifiers\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Parameter setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = 0\n",
    "set_seed(seed)\n",
    "\n",
    "data_path = \"./data\"\n",
    "dataset = \"s2m\"\n",
    "partition = 2000\n",
    "num_val = 100\n",
    "target_sparse = True\n",
    "batch_size = 100\n",
    "ERM_path = \"./Digit_ERM\"  # path for ERM feature map\n",
    "\n",
    "# Common training parameters\n",
    "loss_fn = torch.nn.CrossEntropyLoss()\n",
    "init_erm = True\n",
    "n_class = 10  # number of classes (e.g., MNIST/USPS = 10)\n",
    "\n",
    "# ERM feature extractor parameters\n",
    "erm_model_lr = 1e-3\n",
    "erm_weight_decay = 1e-6\n",
    "\n",
    "# Classifier parameters\n",
    "clf_lr = 1e-2\n",
    "clf_weight_decay = 0\n",
    "clf_epochs = 20\n",
    "clf_patience = 5\n",
    "\n",
    "# Target data setting\n",
    "u = 100  # number of unlabeled target samples\n",
    "\n",
    "# Base model parameters\n",
    "num_base_model = 10\n",
    "base_model_lr = 1e-3\n",
    "base_model_weight_decay = 0\n",
    "base_model_epochs = 2\n",
    "early_stop_threshold = 1e-20\n",
    "max_outer_iteration = 150\n",
    "\n",
    "# DRO parameters\n",
    "rho_values = [0, 0.2, 0.4, 0.6, 0.9] \n",
    "epsilon_values = [0, 0.2, 0.4, 0.6, 0.8, 1]\n",
    "\n",
    "# General settings\n",
    "latent = True\n",
    "type_base_model = \"ERM\"\n",
    "\n",
    "# Path to save/load model\n",
    "default_path = f\"{ERM_path}/{dataset}_u{u}_ERM_model.pth\"\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## SHVN -> MNIST"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### DATA Loading"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No noise perturbed\n",
      "Source DataLoader:\n",
      "Source Batch 0 | Inputs: torch.Size([100, 3, 32, 32]) | Targets: torch.Size([100])\n",
      "\n",
      "Target DataLoader:\n",
      "Target Batch 0 | Inputs: torch.Size([100, 3, 32, 32]) | Targets: torch.Size([100])\n",
      "Num Channels: 3\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "\n",
      "--- Split 1/10 ---\n",
      "Split 1, Epoch 1/20 | Train Loss: 0.6012, Train Acc: 0.8313 | Val Acc: 0.6300\n",
      "Split 1, Epoch 2/20 | Train Loss: 0.2503, Train Acc: 0.9292 | Val Acc: 0.5700\n",
      "Split 1, Epoch 3/20 | Train Loss: 0.2027, Train Acc: 0.9425 | Val Acc: 0.6100\n",
      "Split 1, Epoch 4/20 | Train Loss: 0.1774, Train Acc: 0.9473 | Val Acc: 0.6500\n",
      "Split 1, Epoch 5/20 | Train Loss: 0.1485, Train Acc: 0.9577 | Val Acc: 0.5600\n",
      "Split 1, Epoch 6/20 | Train Loss: 0.1287, Train Acc: 0.9647 | Val Acc: 0.5900\n",
      "Split 1, Epoch 7/20 | Train Loss: 0.1282, Train Acc: 0.9632 | Val Acc: 0.5800\n",
      "Split 1, Epoch 8/20 | Train Loss: 0.1140, Train Acc: 0.9673 | Val Acc: 0.5800\n",
      "Split 1, Epoch 9/20 | Train Loss: 0.1034, Train Acc: 0.9697 | Val Acc: 0.5800\n",
      "\n",
      "--- Split 2/10 ---\n",
      "Split 2, Epoch 1/20 | Train Loss: 0.5847, Train Acc: 0.8307 | Val Acc: 0.6100\n",
      "Split 2, Epoch 2/20 | Train Loss: 0.2549, Train Acc: 0.9280 | Val Acc: 0.5700\n",
      "Split 2, Epoch 3/20 | Train Loss: 0.2073, Train Acc: 0.9404 | Val Acc: 0.6100\n",
      "Split 2, Epoch 4/20 | Train Loss: 0.1751, Train Acc: 0.9503 | Val Acc: 0.6300\n",
      "Split 2, Epoch 5/20 | Train Loss: 0.1441, Train Acc: 0.9595 | Val Acc: 0.6300\n",
      "Split 2, Epoch 6/20 | Train Loss: 0.1388, Train Acc: 0.9590 | Val Acc: 0.6100\n",
      "Split 2, Epoch 7/20 | Train Loss: 0.1268, Train Acc: 0.9621 | Val Acc: 0.6200\n",
      "Split 2, Epoch 8/20 | Train Loss: 0.1114, Train Acc: 0.9672 | Val Acc: 0.5800\n",
      "Split 2, Epoch 9/20 | Train Loss: 0.0945, Train Acc: 0.9723 | Val Acc: 0.5900\n",
      "\n",
      "--- Split 3/10 ---\n",
      "Split 3, Epoch 1/20 | Train Loss: 0.5841, Train Acc: 0.8314 | Val Acc: 0.5800\n",
      "Split 3, Epoch 2/20 | Train Loss: 0.2597, Train Acc: 0.9223 | Val Acc: 0.5600\n",
      "Split 3, Epoch 3/20 | Train Loss: 0.2009, Train Acc: 0.9437 | Val Acc: 0.5500\n",
      "Split 3, Epoch 4/20 | Train Loss: 0.1690, Train Acc: 0.9513 | Val Acc: 0.5500\n",
      "Split 3, Epoch 5/20 | Train Loss: 0.1599, Train Acc: 0.9528 | Val Acc: 0.5600\n",
      "Split 3, Epoch 6/20 | Train Loss: 0.1437, Train Acc: 0.9546 | Val Acc: 0.5600\n",
      "\n",
      "--- Split 4/10 ---\n",
      "Split 4, Epoch 1/20 | Train Loss: 0.5724, Train Acc: 0.8396 | Val Acc: 0.5900\n",
      "Split 4, Epoch 2/20 | Train Loss: 0.2561, Train Acc: 0.9261 | Val Acc: 0.6400\n",
      "Split 4, Epoch 3/20 | Train Loss: 0.2051, Train Acc: 0.9405 | Val Acc: 0.6000\n",
      "Split 4, Epoch 4/20 | Train Loss: 0.1703, Train Acc: 0.9518 | Val Acc: 0.5500\n",
      "Split 4, Epoch 5/20 | Train Loss: 0.1441, Train Acc: 0.9588 | Val Acc: 0.5500\n",
      "Split 4, Epoch 6/20 | Train Loss: 0.1277, Train Acc: 0.9627 | Val Acc: 0.5500\n",
      "Split 4, Epoch 7/20 | Train Loss: 0.1169, Train Acc: 0.9659 | Val Acc: 0.5300\n",
      "\n",
      "--- Split 5/10 ---\n",
      "Split 5, Epoch 1/20 | Train Loss: 0.6074, Train Acc: 0.8273 | Val Acc: 0.5700\n",
      "Split 5, Epoch 2/20 | Train Loss: 0.2697, Train Acc: 0.9216 | Val Acc: 0.5700\n",
      "Split 5, Epoch 3/20 | Train Loss: 0.2069, Train Acc: 0.9418 | Val Acc: 0.5800\n",
      "Split 5, Epoch 4/20 | Train Loss: 0.1769, Train Acc: 0.9486 | Val Acc: 0.5500\n",
      "Split 5, Epoch 5/20 | Train Loss: 0.1572, Train Acc: 0.9536 | Val Acc: 0.5500\n",
      "Split 5, Epoch 6/20 | Train Loss: 0.1306, Train Acc: 0.9637 | Val Acc: 0.5800\n",
      "Split 5, Epoch 7/20 | Train Loss: 0.1228, Train Acc: 0.9644 | Val Acc: 0.6100\n",
      "Split 5, Epoch 8/20 | Train Loss: 0.1085, Train Acc: 0.9686 | Val Acc: 0.5800\n",
      "Split 5, Epoch 9/20 | Train Loss: 0.0907, Train Acc: 0.9761 | Val Acc: 0.5400\n",
      "Split 5, Epoch 10/20 | Train Loss: 0.0844, Train Acc: 0.9772 | Val Acc: 0.5600\n",
      "Split 5, Epoch 11/20 | Train Loss: 0.0872, Train Acc: 0.9742 | Val Acc: 0.5600\n",
      "Split 5, Epoch 12/20 | Train Loss: 0.0772, Train Acc: 0.9778 | Val Acc: 0.5800\n",
      "\n",
      "--- Split 6/10 ---\n",
      "Split 6, Epoch 1/20 | Train Loss: 0.5999, Train Acc: 0.8325 | Val Acc: 0.6200\n",
      "Split 6, Epoch 2/20 | Train Loss: 0.2531, Train Acc: 0.9284 | Val Acc: 0.6300\n",
      "Split 6, Epoch 3/20 | Train Loss: 0.2054, Train Acc: 0.9381 | Val Acc: 0.5600\n",
      "Split 6, Epoch 4/20 | Train Loss: 0.1616, Train Acc: 0.9531 | Val Acc: 0.5700\n",
      "Split 6, Epoch 5/20 | Train Loss: 0.1435, Train Acc: 0.9590 | Val Acc: 0.5500\n",
      "Split 6, Epoch 6/20 | Train Loss: 0.1329, Train Acc: 0.9590 | Val Acc: 0.5900\n",
      "Split 6, Epoch 7/20 | Train Loss: 0.1085, Train Acc: 0.9701 | Val Acc: 0.5600\n",
      "\n",
      "--- Split 7/10 ---\n",
      "Split 7, Epoch 1/20 | Train Loss: 0.5890, Train Acc: 0.8354 | Val Acc: 0.6200\n",
      "Split 7, Epoch 2/20 | Train Loss: 0.2451, Train Acc: 0.9304 | Val Acc: 0.6100\n",
      "Split 7, Epoch 3/20 | Train Loss: 0.2019, Train Acc: 0.9411 | Val Acc: 0.6400\n",
      "Split 7, Epoch 4/20 | Train Loss: 0.1603, Train Acc: 0.9571 | Val Acc: 0.6400\n",
      "Split 7, Epoch 5/20 | Train Loss: 0.1398, Train Acc: 0.9609 | Val Acc: 0.5200\n",
      "Split 7, Epoch 6/20 | Train Loss: 0.1351, Train Acc: 0.9599 | Val Acc: 0.5200\n",
      "Split 7, Epoch 7/20 | Train Loss: 0.1122, Train Acc: 0.9685 | Val Acc: 0.5700\n",
      "Split 7, Epoch 8/20 | Train Loss: 0.0951, Train Acc: 0.9738 | Val Acc: 0.5600\n",
      "\n",
      "--- Split 8/10 ---\n",
      "Split 8, Epoch 1/20 | Train Loss: 0.5530, Train Acc: 0.8414 | Val Acc: 0.6300\n",
      "Split 8, Epoch 2/20 | Train Loss: 0.2553, Train Acc: 0.9254 | Val Acc: 0.6100\n",
      "Split 8, Epoch 3/20 | Train Loss: 0.1903, Train Acc: 0.9436 | Val Acc: 0.5800\n",
      "Split 8, Epoch 4/20 | Train Loss: 0.1616, Train Acc: 0.9538 | Val Acc: 0.6100\n",
      "Split 8, Epoch 5/20 | Train Loss: 0.1442, Train Acc: 0.9594 | Val Acc: 0.5900\n",
      "Split 8, Epoch 6/20 | Train Loss: 0.1254, Train Acc: 0.9646 | Val Acc: 0.6300\n",
      "\n",
      "--- Split 9/10 ---\n",
      "Split 9, Epoch 1/20 | Train Loss: 0.6193, Train Acc: 0.8352 | Val Acc: 0.6300\n",
      "Split 9, Epoch 2/20 | Train Loss: 0.2478, Train Acc: 0.9287 | Val Acc: 0.6200\n",
      "Split 9, Epoch 3/20 | Train Loss: 0.1969, Train Acc: 0.9428 | Val Acc: 0.5800\n",
      "Split 9, Epoch 4/20 | Train Loss: 0.1835, Train Acc: 0.9445 | Val Acc: 0.6200\n",
      "Split 9, Epoch 5/20 | Train Loss: 0.1461, Train Acc: 0.9567 | Val Acc: 0.5800\n",
      "Split 9, Epoch 6/20 | Train Loss: 0.1283, Train Acc: 0.9625 | Val Acc: 0.5900\n",
      "\n",
      "--- Split 10/10 ---\n",
      "Split 10, Epoch 1/20 | Train Loss: 0.5939, Train Acc: 0.8339 | Val Acc: 0.5800\n",
      "Split 10, Epoch 2/20 | Train Loss: 0.2688, Train Acc: 0.9227 | Val Acc: 0.6300\n",
      "Split 10, Epoch 3/20 | Train Loss: 0.1981, Train Acc: 0.9447 | Val Acc: 0.5900\n",
      "Split 10, Epoch 4/20 | Train Loss: 0.1674, Train Acc: 0.9543 | Val Acc: 0.6000\n",
      "Split 10, Epoch 5/20 | Train Loss: 0.1447, Train Acc: 0.9596 | Val Acc: 0.5900\n",
      "Split 10, Epoch 6/20 | Train Loss: 0.1246, Train Acc: 0.9650 | Val Acc: 0.6000\n",
      "Split 10, Epoch 7/20 | Train Loss: 0.1152, Train Acc: 0.9680 | Val Acc: 0.6000\n"
     ]
    }
   ],
   "source": [
    "s_train_loader, s_test_loader, t_train_loader, t_val_loader, t_test_loader, target_loader = get_loader(\n",
    "    dset=dataset,\n",
    "    data_path=data_path,\n",
    "    batch_size=batch_size,\n",
    "    num_workers=4,\n",
    "    num_val=num_val,\n",
    "    target_sparse=target_sparse,\n",
    "    u=u\n",
    ")\n",
    "\n",
    "# Example: split source loader\n",
    "split_loaders = split_source_loader(\n",
    "    s_train_loader, K=partition, num_splits=num_base_model, batch_size=128, replacement=True, seed=seed\n",
    ")\n",
    "\n",
    "\n",
    "dataloaders = {\n",
    "    \"source\": s_train_loader,\n",
    "    \"target_train\": t_train_loader,\n",
    "    \"target_test\": t_test_loader,\n",
    "    \"valid\": t_val_loader\n",
    "}\n",
    "\n",
    "# Check input/output shapes\n",
    "n_channel = None\n",
    "print(\"Source DataLoader:\")\n",
    "for batch_idx, (inputs, targets) in enumerate(dataloaders[\"source\"]):\n",
    "    print(f\"Source Batch {batch_idx} | Inputs: {inputs.shape} | Targets: {targets.shape}\")\n",
    "    break  \n",
    "\n",
    "print(\"\\nTarget DataLoader:\")\n",
    "for batch_idx, (inputs, targets) in enumerate(dataloaders[\"target_train\"]):\n",
    "    n_channel = inputs.shape[1]\n",
    "    print(f\"Target Batch {batch_idx} | Inputs: {inputs.shape} | Targets: {targets.shape}\")\n",
    "    break \n",
    "\n",
    "print(f\"Num Channels: {n_channel}\")\n",
    "\n",
    "\n",
    "\n",
    "# ================== ERM model ==================\n",
    "# NOTE: Requires a pre-trained ERM model saved at `default_path`.\n",
    "checkpoint = torch.load(default_path, map_location=device)\n",
    "models, optimizers = get_erm_model(\n",
    "    device, n_class=n_class, \n",
    "    lr=erm_model_lr, \n",
    "    weight_decay=erm_weight_decay, \n",
    "    n_channel=n_channel\n",
    ")\n",
    "models[\"G\"].load_state_dict(checkpoint[\"G\"])\n",
    "ERM_feature_map = copy.deepcopy(models[\"G\"])\n",
    "\n",
    "\n",
    "# ================== Base Classifier Training ==================\n",
    "classifiers = train_classifiers(\n",
    "    split_loaders=split_loaders,\n",
    "    ERM_feature_map=ERM_feature_map,\n",
    "    valid_loader=t_val_loader,\n",
    "    n_class=n_class,\n",
    "    device=device,\n",
    "    n_epochs=clf_epochs,\n",
    "    lr=clf_lr,\n",
    "    weight_decay=clf_weight_decay,\n",
    "    patience=clf_patience\n",
    ")\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------------------------------ Starting Main Code ------------------------------------\n",
      "\n",
      "Function called: get_classifier_predictions\n",
      "------------------------ Starting model training with num_base_model=10, rho=0, epsilon=0 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 260.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7033, Train Acc: 0.7910 | Val Loss: 1.8410, Val Acc: 0.6400 | Test Loss: 1.7819, Test Acc: 0.6608\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2533, Train Acc: 0.9060 | Val Loss: 2.0695, Val Acc: 0.6300 | Test Loss: 1.9086, Test Acc: 0.6471\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 299.31it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1337, Train Acc: 0.9590 | Val Loss: 2.0672, Val Acc: 0.6400 | Test Loss: 1.9079, Test Acc: 0.6429\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0858, Train Acc: 0.9810 | Val Loss: 2.0886, Val Acc: 0.6200 | Test Loss: 1.9137, Test Acc: 0.6411\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 268.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0550, Train Acc: 0.9950 | Val Loss: 2.1094, Val Acc: 0.6400 | Test Loss: 1.9168, Test Acc: 0.6485\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0535, Train Acc: 0.9890 | Val Loss: 2.1465, Val Acc: 0.6400 | Test Loss: 1.9455, Test Acc: 0.6464\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 218.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 275.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0334, Train Acc: 0.9960 | Val Loss: 2.2094, Val Acc: 0.6400 | Test Loss: 1.9976, Test Acc: 0.6423\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0299, Train Acc: 0.9970 | Val Loss: 2.2483, Val Acc: 0.6400 | Test Loss: 2.0322, Test Acc: 0.6411\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 145.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0195, Train Acc: 0.9990 | Val Loss: 2.2484, Val Acc: 0.6400 | Test Loss: 2.0514, Test Acc: 0.6400\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0269, Train Acc: 0.9970 | Val Loss: 2.2748, Val Acc: 0.6400 | Test Loss: 2.0851, Test Acc: 0.6406\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 334.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0187, Train Acc: 0.9980 | Val Loss: 2.2906, Val Acc: 0.6300 | Test Loss: 2.1113, Test Acc: 0.6384\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0179, Train Acc: 0.9980 | Val Loss: 2.2937, Val Acc: 0.6500 | Test Loss: 2.1299, Test Acc: 0.6373\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 169.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 262.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0131, Train Acc: 1.0000 | Val Loss: 2.2562, Val Acc: 0.6500 | Test Loss: 2.0911, Test Acc: 0.6427\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0134, Train Acc: 0.9990 | Val Loss: 2.2791, Val Acc: 0.6500 | Test Loss: 2.1211, Test Acc: 0.6409\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 334.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0107, Train Acc: 0.9990 | Val Loss: 2.2777, Val Acc: 0.6500 | Test Loss: 2.1133, Test Acc: 0.6434\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0155, Train Acc: 0.9990 | Val Loss: 2.3088, Val Acc: 0.6500 | Test Loss: 2.1300, Test Acc: 0.6450\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.63it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 230.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0079, Train Acc: 1.0000 | Val Loss: 2.3201, Val Acc: 0.6500 | Test Loss: 2.1311, Test Acc: 0.6463\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0075, Train Acc: 1.0000 | Val Loss: 2.3319, Val Acc: 0.6500 | Test Loss: 2.1405, Test Acc: 0.6464\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 254.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 188.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0072, Train Acc: 1.0000 | Val Loss: 2.3483, Val Acc: 0.6500 | Test Loss: 2.1660, Test Acc: 0.6443\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0081, Train Acc: 1.0000 | Val Loss: 2.3513, Val Acc: 0.6500 | Test Loss: 2.1815, Test Acc: 0.6450\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 212.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0049, Train Acc: 1.0000 | Val Loss: 2.3755, Val Acc: 0.6500 | Test Loss: 2.2078, Test Acc: 0.6456\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0078, Train Acc: 0.9990 | Val Loss: 2.4071, Val Acc: 0.6400 | Test Loss: 2.2411, Test Acc: 0.6440\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 254.42it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 224.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0043, Train Acc: 1.0000 | Val Loss: 2.4283, Val Acc: 0.6400 | Test Loss: 2.2575, Test Acc: 0.6435\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0037, Train Acc: 1.0000 | Val Loss: 2.4057, Val Acc: 0.6400 | Test Loss: 2.2311, Test Acc: 0.6451\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 174.44it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 222.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0040, Train Acc: 1.0000 | Val Loss: 2.4183, Val Acc: 0.6400 | Test Loss: 2.2450, Test Acc: 0.6469\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0042, Train Acc: 1.0000 | Val Loss: 2.4257, Val Acc: 0.6400 | Test Loss: 2.2548, Test Acc: 0.6443\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 373.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 342.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0048, Train Acc: 1.0000 | Val Loss: 2.4456, Val Acc: 0.6500 | Test Loss: 2.2743, Test Acc: 0.6435\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0049, Train Acc: 1.0000 | Val Loss: 2.4254, Val Acc: 0.6500 | Test Loss: 2.2713, Test Acc: 0.6439\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 248.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0054, Train Acc: 0.9990 | Val Loss: 2.4259, Val Acc: 0.6500 | Test Loss: 2.2793, Test Acc: 0.6459\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0053, Train Acc: 0.9990 | Val Loss: 2.4280, Val Acc: 0.6500 | Test Loss: 2.2895, Test Acc: 0.6473\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 267.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0056, Train Acc: 0.9990 | Val Loss: 2.4730, Val Acc: 0.6500 | Test Loss: 2.3345, Test Acc: 0.6464\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0041, Train Acc: 1.0000 | Val Loss: 2.4694, Val Acc: 0.6500 | Test Loss: 2.3344, Test Acc: 0.6466\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0, epsilon=0: Test Loss: 2.1299, Test Accuracy: 0.6373\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0, epsilon=0: Test Loss: 2.3344, Test Accuracy: 0.6466\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0, epsilon=0.2 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 293.18it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.1430, Train Acc: 0.3830 | Val Loss: 0.9841, Val Acc: 0.7900 | Test Loss: 0.9143, Test Acc: 0.7724\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9079, Train Acc: 0.5860 | Val Loss: 0.9281, Val Acc: 0.8400 | Test Loss: 0.7940, Test Acc: 0.8059\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 236.80it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 231.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4701, Train Acc: 0.5320 | Val Loss: 0.9239, Val Acc: 0.8000 | Test Loss: 0.6558, Test Acc: 0.8401\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5120, Train Acc: 0.6530 | Val Loss: 1.0259, Val Acc: 0.7800 | Test Loss: 0.7426, Test Acc: 0.8415\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 339.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 240.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2515, Train Acc: 0.6960 | Val Loss: 0.8964, Val Acc: 0.8100 | Test Loss: 0.5878, Test Acc: 0.8573\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9741, Train Acc: 0.7280 | Val Loss: 0.7942, Val Acc: 0.8300 | Test Loss: 0.5086, Test Acc: 0.8622\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 167.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7216, Train Acc: 0.7840 | Val Loss: 0.7594, Val Acc: 0.8400 | Test Loss: 0.4610, Test Acc: 0.8731\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5760, Train Acc: 0.8220 | Val Loss: 0.7143, Val Acc: 0.8400 | Test Loss: 0.4491, Test Acc: 0.8780\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 187.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 165.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4675, Train Acc: 0.8520 | Val Loss: 0.6706, Val Acc: 0.8400 | Test Loss: 0.4303, Test Acc: 0.8815\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3843, Train Acc: 0.8770 | Val Loss: 0.6450, Val Acc: 0.8400 | Test Loss: 0.4121, Test Acc: 0.8821\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 249.71it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3105, Train Acc: 0.9030 | Val Loss: 0.6432, Val Acc: 0.8500 | Test Loss: 0.4044, Test Acc: 0.8861\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2774, Train Acc: 0.9130 | Val Loss: 0.6376, Val Acc: 0.8500 | Test Loss: 0.3988, Test Acc: 0.8876\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 267.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 278.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2368, Train Acc: 0.9230 | Val Loss: 0.6211, Val Acc: 0.8500 | Test Loss: 0.3848, Test Acc: 0.8908\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2029, Train Acc: 0.9360 | Val Loss: 0.6157, Val Acc: 0.8500 | Test Loss: 0.3851, Test Acc: 0.8900\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1784, Train Acc: 0.9590 | Val Loss: 0.6242, Val Acc: 0.8400 | Test Loss: 0.3850, Test Acc: 0.8932\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1716, Train Acc: 0.9560 | Val Loss: 0.6182, Val Acc: 0.8500 | Test Loss: 0.3912, Test Acc: 0.8935\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 297.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1579, Train Acc: 0.9530 | Val Loss: 0.6000, Val Acc: 0.8500 | Test Loss: 0.3923, Test Acc: 0.8938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1358, Train Acc: 0.9640 | Val Loss: 0.5922, Val Acc: 0.8500 | Test Loss: 0.3873, Test Acc: 0.8936\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 161.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 308.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1116, Train Acc: 0.9780 | Val Loss: 0.6023, Val Acc: 0.8600 | Test Loss: 0.3902, Test Acc: 0.8946\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0979, Train Acc: 0.9820 | Val Loss: 0.6105, Val Acc: 0.8600 | Test Loss: 0.3969, Test Acc: 0.8947\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 244.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1076, Train Acc: 0.9750 | Val Loss: 0.6306, Val Acc: 0.8500 | Test Loss: 0.4053, Test Acc: 0.8936\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0857, Train Acc: 0.9890 | Val Loss: 0.6116, Val Acc: 0.8600 | Test Loss: 0.3967, Test Acc: 0.8937\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 218.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0853, Train Acc: 0.9830 | Val Loss: 0.6181, Val Acc: 0.8500 | Test Loss: 0.3973, Test Acc: 0.8949\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0681, Train Acc: 0.9900 | Val Loss: 0.6350, Val Acc: 0.8500 | Test Loss: 0.4103, Test Acc: 0.8944\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 201.18it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 172.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0758, Train Acc: 0.9900 | Val Loss: 0.6103, Val Acc: 0.8600 | Test Loss: 0.3909, Test Acc: 0.8971\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0631, Train Acc: 0.9930 | Val Loss: 0.6023, Val Acc: 0.8500 | Test Loss: 0.3925, Test Acc: 0.8949\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.24it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0799, Train Acc: 0.9830 | Val Loss: 0.6301, Val Acc: 0.8600 | Test Loss: 0.4005, Test Acc: 0.8954\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0486, Train Acc: 0.9960 | Val Loss: 0.6363, Val Acc: 0.8500 | Test Loss: 0.4273, Test Acc: 0.8936\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 250.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0761, Train Acc: 0.9830 | Val Loss: 0.6313, Val Acc: 0.8500 | Test Loss: 0.4096, Test Acc: 0.8938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0493, Train Acc: 0.9950 | Val Loss: 0.6230, Val Acc: 0.8600 | Test Loss: 0.4131, Test Acc: 0.8929\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 170.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 257.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0813, Train Acc: 0.9820 | Val Loss: 0.6468, Val Acc: 0.8600 | Test Loss: 0.4094, Test Acc: 0.8961\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0392, Train Acc: 0.9970 | Val Loss: 0.6696, Val Acc: 0.8500 | Test Loss: 0.4494, Test Acc: 0.8925\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 261.96it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 337.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0876, Train Acc: 0.9820 | Val Loss: 0.6376, Val Acc: 0.8600 | Test Loss: 0.4080, Test Acc: 0.8963\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0402, Train Acc: 0.9930 | Val Loss: 0.6158, Val Acc: 0.8600 | Test Loss: 0.4159, Test Acc: 0.8921\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 231.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 250.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0710, Train Acc: 0.9840 | Val Loss: 0.6294, Val Acc: 0.8600 | Test Loss: 0.4109, Test Acc: 0.8956\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0377, Train Acc: 0.9970 | Val Loss: 0.6446, Val Acc: 0.8500 | Test Loss: 0.4386, Test Acc: 0.8950\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 215.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0589, Train Acc: 0.9890 | Val Loss: 0.6446, Val Acc: 0.8400 | Test Loss: 0.4255, Test Acc: 0.8952\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0333, Train Acc: 0.9960 | Val Loss: 0.6391, Val Acc: 0.8500 | Test Loss: 0.4207, Test Acc: 0.8944\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 231.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0425, Train Acc: 0.9920 | Val Loss: 0.6291, Val Acc: 0.8600 | Test Loss: 0.4152, Test Acc: 0.8959\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0, epsilon=0.2: Test Loss: 0.3902, Test Accuracy: 0.8946\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0, epsilon=0.2: Test Loss: 0.4152, Test Accuracy: 0.8959\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0, epsilon=0.4 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 6.7307, Train Acc: 0.2620 | Val Loss: 1.1290, Val Acc: 0.7300 | Test Loss: 1.0340, Test Acc: 0.7099\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2763, Train Acc: 0.3490 | Val Loss: 1.0653, Val Acc: 0.7300 | Test Loss: 1.0171, Test Acc: 0.7217\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 222.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 221.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.4884, Train Acc: 0.3160 | Val Loss: 1.0476, Val Acc: 0.7400 | Test Loss: 0.9029, Test Acc: 0.7586\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.1227, Train Acc: 0.3940 | Val Loss: 1.3040, Val Acc: 0.6800 | Test Loss: 1.1163, Test Acc: 0.7528\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 333.28it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 241.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4799, Train Acc: 0.4940 | Val Loss: 1.0096, Val Acc: 0.7300 | Test Loss: 0.8452, Test Acc: 0.7877\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9172, Train Acc: 0.5400 | Val Loss: 0.8574, Val Acc: 0.7800 | Test Loss: 0.7025, Test Acc: 0.8144\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 256.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5284, Train Acc: 0.5640 | Val Loss: 0.8362, Val Acc: 0.7900 | Test Loss: 0.6650, Test Acc: 0.8270\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2765, Train Acc: 0.6090 | Val Loss: 0.8236, Val Acc: 0.7800 | Test Loss: 0.6427, Test Acc: 0.8367\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 335.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1236, Train Acc: 0.6570 | Val Loss: 0.7257, Val Acc: 0.8100 | Test Loss: 0.5537, Test Acc: 0.8511\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9926, Train Acc: 0.6870 | Val Loss: 0.6450, Val Acc: 0.8300 | Test Loss: 0.4901, Test Acc: 0.8623\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 252.88it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8914, Train Acc: 0.7060 | Val Loss: 0.6324, Val Acc: 0.8600 | Test Loss: 0.4819, Test Acc: 0.8662\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7950, Train Acc: 0.7450 | Val Loss: 0.6126, Val Acc: 0.8500 | Test Loss: 0.4580, Test Acc: 0.8727\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 229.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7179, Train Acc: 0.7630 | Val Loss: 0.5974, Val Acc: 0.8500 | Test Loss: 0.4266, Test Acc: 0.8797\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6629, Train Acc: 0.7780 | Val Loss: 0.5779, Val Acc: 0.8500 | Test Loss: 0.3988, Test Acc: 0.8848\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 289.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 214.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6148, Train Acc: 0.7900 | Val Loss: 0.5594, Val Acc: 0.8500 | Test Loss: 0.3861, Test Acc: 0.8872\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5617, Train Acc: 0.8040 | Val Loss: 0.5589, Val Acc: 0.8500 | Test Loss: 0.3883, Test Acc: 0.8876\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 289.44it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5094, Train Acc: 0.8260 | Val Loss: 0.5461, Val Acc: 0.8500 | Test Loss: 0.3697, Test Acc: 0.8921\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4877, Train Acc: 0.8410 | Val Loss: 0.5460, Val Acc: 0.8500 | Test Loss: 0.3582, Test Acc: 0.8948\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4513, Train Acc: 0.8480 | Val Loss: 0.5478, Val Acc: 0.8500 | Test Loss: 0.3569, Test Acc: 0.8951\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4215, Train Acc: 0.8630 | Val Loss: 0.5241, Val Acc: 0.8500 | Test Loss: 0.3490, Test Acc: 0.8963\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 360.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.65it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4042, Train Acc: 0.8520 | Val Loss: 0.5270, Val Acc: 0.8600 | Test Loss: 0.3389, Test Acc: 0.8994\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3646, Train Acc: 0.8690 | Val Loss: 0.5269, Val Acc: 0.8600 | Test Loss: 0.3315, Test Acc: 0.9020\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 242.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 273.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3538, Train Acc: 0.8920 | Val Loss: 0.5236, Val Acc: 0.8600 | Test Loss: 0.3285, Test Acc: 0.9022\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3222, Train Acc: 0.9040 | Val Loss: 0.5081, Val Acc: 0.8600 | Test Loss: 0.3178, Test Acc: 0.9031\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.17it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 245.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3241, Train Acc: 0.8980 | Val Loss: 0.5215, Val Acc: 0.8600 | Test Loss: 0.3189, Test Acc: 0.9044\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2975, Train Acc: 0.9030 | Val Loss: 0.5342, Val Acc: 0.8600 | Test Loss: 0.3393, Test Acc: 0.9026\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 309.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3075, Train Acc: 0.9070 | Val Loss: 0.4984, Val Acc: 0.8600 | Test Loss: 0.3083, Test Acc: 0.9067\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2558, Train Acc: 0.9240 | Val Loss: 0.5003, Val Acc: 0.8600 | Test Loss: 0.3233, Test Acc: 0.9026\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2943, Train Acc: 0.9070 | Val Loss: 0.5057, Val Acc: 0.8700 | Test Loss: 0.3082, Test Acc: 0.9082\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2422, Train Acc: 0.9320 | Val Loss: 0.5231, Val Acc: 0.8700 | Test Loss: 0.3453, Test Acc: 0.9047\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 214.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2917, Train Acc: 0.9110 | Val Loss: 0.4892, Val Acc: 0.8700 | Test Loss: 0.3007, Test Acc: 0.9110\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2182, Train Acc: 0.9450 | Val Loss: 0.4908, Val Acc: 0.8600 | Test Loss: 0.3156, Test Acc: 0.9042\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 228.44it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2766, Train Acc: 0.9180 | Val Loss: 0.4977, Val Acc: 0.8700 | Test Loss: 0.2974, Test Acc: 0.9124\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2188, Train Acc: 0.9360 | Val Loss: 0.5103, Val Acc: 0.8700 | Test Loss: 0.3311, Test Acc: 0.9090\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.61it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2563, Train Acc: 0.9170 | Val Loss: 0.4849, Val Acc: 0.8700 | Test Loss: 0.2970, Test Acc: 0.9121\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1902, Train Acc: 0.9470 | Val Loss: 0.5026, Val Acc: 0.8600 | Test Loss: 0.3300, Test Acc: 0.9017\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2354, Train Acc: 0.9270 | Val Loss: 0.4818, Val Acc: 0.8700 | Test Loss: 0.2935, Test Acc: 0.9130\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1644, Train Acc: 0.9610 | Val Loss: 0.4962, Val Acc: 0.8700 | Test Loss: 0.3195, Test Acc: 0.9136\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 231.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2266, Train Acc: 0.9280 | Val Loss: 0.5068, Val Acc: 0.8700 | Test Loss: 0.3093, Test Acc: 0.9094\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1633, Train Acc: 0.9560 | Val Loss: 0.5406, Val Acc: 0.8700 | Test Loss: 0.3364, Test Acc: 0.8989\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 246.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2118, Train Acc: 0.9350 | Val Loss: 0.4802, Val Acc: 0.8800 | Test Loss: 0.2916, Test Acc: 0.9130\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1536, Train Acc: 0.9660 | Val Loss: 0.4610, Val Acc: 0.8700 | Test Loss: 0.2918, Test Acc: 0.9172\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 164.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 331.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1709, Train Acc: 0.9540 | Val Loss: 0.4770, Val Acc: 0.8800 | Test Loss: 0.2979, Test Acc: 0.9135\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1360, Train Acc: 0.9700 | Val Loss: 0.5118, Val Acc: 0.8800 | Test Loss: 0.3075, Test Acc: 0.9079\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 266.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 242.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1392, Train Acc: 0.9630 | Val Loss: 0.4865, Val Acc: 0.8800 | Test Loss: 0.2860, Test Acc: 0.9149\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1162, Train Acc: 0.9760 | Val Loss: 0.4698, Val Acc: 0.8800 | Test Loss: 0.2792, Test Acc: 0.9182\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 355.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1220, Train Acc: 0.9730 | Val Loss: 0.4762, Val Acc: 0.8800 | Test Loss: 0.2838, Test Acc: 0.9178\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1106, Train Acc: 0.9790 | Val Loss: 0.4808, Val Acc: 0.8700 | Test Loss: 0.2828, Test Acc: 0.9169\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 260.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1099, Train Acc: 0.9730 | Val Loss: 0.4796, Val Acc: 0.8700 | Test Loss: 0.2787, Test Acc: 0.9181\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0935, Train Acc: 0.9850 | Val Loss: 0.4828, Val Acc: 0.8800 | Test Loss: 0.2815, Test Acc: 0.9177\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 219.23it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0988, Train Acc: 0.9810 | Val Loss: 0.4962, Val Acc: 0.8800 | Test Loss: 0.2928, Test Acc: 0.9164\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0798, Train Acc: 0.9850 | Val Loss: 0.4798, Val Acc: 0.8800 | Test Loss: 0.2859, Test Acc: 0.9181\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 245.80it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 251.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0850, Train Acc: 0.9850 | Val Loss: 0.4828, Val Acc: 0.8800 | Test Loss: 0.2804, Test Acc: 0.9190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0808, Train Acc: 0.9840 | Val Loss: 0.4914, Val Acc: 0.8800 | Test Loss: 0.2822, Test Acc: 0.9177\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 146.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 268.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0670, Train Acc: 0.9900 | Val Loss: 0.4872, Val Acc: 0.8800 | Test Loss: 0.2810, Test Acc: 0.9182\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0641, Train Acc: 0.9900 | Val Loss: 0.4902, Val Acc: 0.8800 | Test Loss: 0.2797, Test Acc: 0.9203\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 154.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0701, Train Acc: 0.9880 | Val Loss: 0.4858, Val Acc: 0.8800 | Test Loss: 0.2792, Test Acc: 0.9204\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0611, Train Acc: 0.9900 | Val Loss: 0.4835, Val Acc: 0.8800 | Test Loss: 0.2729, Test Acc: 0.9209\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 356.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0708, Train Acc: 0.9890 | Val Loss: 0.4967, Val Acc: 0.8800 | Test Loss: 0.2728, Test Acc: 0.9222\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0607, Train Acc: 0.9920 | Val Loss: 0.4960, Val Acc: 0.8800 | Test Loss: 0.2747, Test Acc: 0.9212\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 336.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0701, Train Acc: 0.9870 | Val Loss: 0.4910, Val Acc: 0.8800 | Test Loss: 0.2716, Test Acc: 0.9239\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0, epsilon=0.4: Test Loss: 0.2916, Test Accuracy: 0.9130\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0, epsilon=0.4: Test Loss: 0.2716, Test Accuracy: 0.9239\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0, epsilon=0.6 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 214.42it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 399.59it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.5607, Train Acc: 0.2430 | Val Loss: 1.2455, Val Acc: 0.6600 | Test Loss: 1.1443, Test Acc: 0.6517\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.3883, Train Acc: 0.2790 | Val Loss: 1.2838, Val Acc: 0.6000 | Test Loss: 1.1770, Test Acc: 0.6365\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 374.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 184.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.1110, Train Acc: 0.2340 | Val Loss: 1.1691, Val Acc: 0.6900 | Test Loss: 1.0394, Test Acc: 0.7106\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.6585, Train Acc: 0.3170 | Val Loss: 1.3459, Val Acc: 0.6700 | Test Loss: 1.2438, Test Acc: 0.7038\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 314.74it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.1018, Train Acc: 0.3870 | Val Loss: 1.0602, Val Acc: 0.7000 | Test Loss: 0.9855, Test Acc: 0.7302\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.4393, Train Acc: 0.4450 | Val Loss: 0.9428, Val Acc: 0.7300 | Test Loss: 0.8900, Test Acc: 0.7511\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 240.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 309.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.9728, Train Acc: 0.4560 | Val Loss: 0.9686, Val Acc: 0.7200 | Test Loss: 0.8762, Test Acc: 0.7749\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6926, Train Acc: 0.5190 | Val Loss: 0.9942, Val Acc: 0.7300 | Test Loss: 0.8802, Test Acc: 0.7833\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 337.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6660, Train Acc: 0.5460 | Val Loss: 0.7884, Val Acc: 0.7700 | Test Loss: 0.6852, Test Acc: 0.8122\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4128, Train Acc: 0.6020 | Val Loss: 0.7275, Val Acc: 0.7900 | Test Loss: 0.6121, Test Acc: 0.8234\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 296.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3376, Train Acc: 0.5760 | Val Loss: 0.7364, Val Acc: 0.7800 | Test Loss: 0.6064, Test Acc: 0.8321\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1772, Train Acc: 0.6020 | Val Loss: 0.7815, Val Acc: 0.7800 | Test Loss: 0.6347, Test Acc: 0.8300\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 287.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 154.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1083, Train Acc: 0.6390 | Val Loss: 0.6510, Val Acc: 0.8300 | Test Loss: 0.5202, Test Acc: 0.8560\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0074, Train Acc: 0.6820 | Val Loss: 0.6057, Val Acc: 0.8400 | Test Loss: 0.4744, Test Acc: 0.8667\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0128, Train Acc: 0.6280 | Val Loss: 0.6026, Val Acc: 0.8400 | Test Loss: 0.4733, Test Acc: 0.8671\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9291, Train Acc: 0.6610 | Val Loss: 0.6185, Val Acc: 0.8300 | Test Loss: 0.4886, Test Acc: 0.8655\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 328.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8407, Train Acc: 0.7140 | Val Loss: 0.5733, Val Acc: 0.8600 | Test Loss: 0.4389, Test Acc: 0.8785\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7864, Train Acc: 0.7320 | Val Loss: 0.5328, Val Acc: 0.8400 | Test Loss: 0.4035, Test Acc: 0.8866\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 282.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 237.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8160, Train Acc: 0.7150 | Val Loss: 0.5387, Val Acc: 0.8500 | Test Loss: 0.4029, Test Acc: 0.8871\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7515, Train Acc: 0.7240 | Val Loss: 0.5633, Val Acc: 0.8500 | Test Loss: 0.4173, Test Acc: 0.8812\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 294.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 323.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6785, Train Acc: 0.7620 | Val Loss: 0.5288, Val Acc: 0.8400 | Test Loss: 0.3829, Test Acc: 0.8900\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6266, Train Acc: 0.7830 | Val Loss: 0.4963, Val Acc: 0.8400 | Test Loss: 0.3578, Test Acc: 0.8951\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 219.86it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 254.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6754, Train Acc: 0.7700 | Val Loss: 0.5120, Val Acc: 0.8500 | Test Loss: 0.3657, Test Acc: 0.8945\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6227, Train Acc: 0.7760 | Val Loss: 0.5381, Val Acc: 0.8500 | Test Loss: 0.3839, Test Acc: 0.8896\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 213.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5760, Train Acc: 0.7980 | Val Loss: 0.4979, Val Acc: 0.8400 | Test Loss: 0.3475, Test Acc: 0.8980\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5189, Train Acc: 0.8300 | Val Loss: 0.4864, Val Acc: 0.8300 | Test Loss: 0.3397, Test Acc: 0.8973\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 165.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5787, Train Acc: 0.7890 | Val Loss: 0.4980, Val Acc: 0.8500 | Test Loss: 0.3401, Test Acc: 0.8997\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5395, Train Acc: 0.8190 | Val Loss: 0.5113, Val Acc: 0.8600 | Test Loss: 0.3560, Test Acc: 0.8981\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5700, Train Acc: 0.7940 | Val Loss: 0.4673, Val Acc: 0.8600 | Test Loss: 0.3118, Test Acc: 0.9054\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4591, Train Acc: 0.8430 | Val Loss: 0.4707, Val Acc: 0.8300 | Test Loss: 0.3429, Test Acc: 0.8945\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 375.61it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 228.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5608, Train Acc: 0.8090 | Val Loss: 0.4849, Val Acc: 0.8500 | Test Loss: 0.3283, Test Acc: 0.9022\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4468, Train Acc: 0.8500 | Val Loss: 0.5133, Val Acc: 0.8600 | Test Loss: 0.3534, Test Acc: 0.8997\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 319.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5294, Train Acc: 0.8100 | Val Loss: 0.4606, Val Acc: 0.8600 | Test Loss: 0.2896, Test Acc: 0.9122\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4377, Train Acc: 0.8490 | Val Loss: 0.4488, Val Acc: 0.8500 | Test Loss: 0.3116, Test Acc: 0.9006\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 287.43it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 292.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5106, Train Acc: 0.8150 | Val Loss: 0.4763, Val Acc: 0.8600 | Test Loss: 0.3051, Test Acc: 0.9077\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4012, Train Acc: 0.8590 | Val Loss: 0.5004, Val Acc: 0.8600 | Test Loss: 0.3356, Test Acc: 0.9010\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 396.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4298, Train Acc: 0.8590 | Val Loss: 0.4594, Val Acc: 0.8500 | Test Loss: 0.2853, Test Acc: 0.9122\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0, epsilon=0.6: Test Loss: 0.4389, Test Accuracy: 0.8785\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0, epsilon=0.6: Test Loss: 0.2853, Test Accuracy: 0.9122\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0, epsilon=0.8 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 270.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.0346, Train Acc: 0.2360 | Val Loss: 1.2570, Val Acc: 0.6100 | Test Loss: 1.1914, Test Acc: 0.6272\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.8899, Train Acc: 0.2590 | Val Loss: 1.3958, Val Acc: 0.5300 | Test Loss: 1.2863, Test Acc: 0.5823\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.5188, Train Acc: 0.1970 | Val Loss: 1.1680, Val Acc: 0.6400 | Test Loss: 1.0768, Test Acc: 0.6799\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.0434, Train Acc: 0.2660 | Val Loss: 1.3003, Val Acc: 0.6600 | Test Loss: 1.2406, Test Acc: 0.6785\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 292.14it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 311.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.3984, Train Acc: 0.3410 | Val Loss: 1.1058, Val Acc: 0.6300 | Test Loss: 1.0783, Test Acc: 0.6725\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.7139, Train Acc: 0.3880 | Val Loss: 1.0929, Val Acc: 0.6700 | Test Loss: 1.0818, Test Acc: 0.6680\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 196.73it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 238.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.3398, Train Acc: 0.3740 | Val Loss: 1.0678, Val Acc: 0.7100 | Test Loss: 0.9940, Test Acc: 0.7289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9886, Train Acc: 0.4450 | Val Loss: 1.0671, Val Acc: 0.7200 | Test Loss: 0.9769, Test Acc: 0.7377\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 178.61it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.0584, Train Acc: 0.4820 | Val Loss: 0.8978, Val Acc: 0.7200 | Test Loss: 0.8295, Test Acc: 0.7511\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.7457, Train Acc: 0.5370 | Val Loss: 0.8748, Val Acc: 0.6900 | Test Loss: 0.8060, Test Acc: 0.7526\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 381.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6788, Train Acc: 0.4820 | Val Loss: 0.7995, Val Acc: 0.7600 | Test Loss: 0.7029, Test Acc: 0.8021\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4745, Train Acc: 0.5300 | Val Loss: 0.8133, Val Acc: 0.7400 | Test Loss: 0.7000, Test Acc: 0.8115\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 376.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3995, Train Acc: 0.5900 | Val Loss: 0.6998, Val Acc: 0.8100 | Test Loss: 0.6027, Test Acc: 0.8331\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2322, Train Acc: 0.6460 | Val Loss: 0.6826, Val Acc: 0.7900 | Test Loss: 0.5755, Test Acc: 0.8343\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 156.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 255.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3578, Train Acc: 0.5270 | Val Loss: 0.6548, Val Acc: 0.7900 | Test Loss: 0.5333, Test Acc: 0.8511\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1949, Train Acc: 0.5790 | Val Loss: 0.6953, Val Acc: 0.8000 | Test Loss: 0.5638, Test Acc: 0.8431\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0852, Train Acc: 0.6540 | Val Loss: 0.6201, Val Acc: 0.8300 | Test Loss: 0.5050, Test Acc: 0.8615\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9802, Train Acc: 0.6980 | Val Loss: 0.6043, Val Acc: 0.8200 | Test Loss: 0.4931, Test Acc: 0.8613\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1163, Train Acc: 0.6040 | Val Loss: 0.5757, Val Acc: 0.8300 | Test Loss: 0.4597, Test Acc: 0.8750\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0202, Train Acc: 0.6330 | Val Loss: 0.6141, Val Acc: 0.8200 | Test Loss: 0.4951, Test Acc: 0.8617\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 184.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 150.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9316, Train Acc: 0.6840 | Val Loss: 0.5549, Val Acc: 0.8400 | Test Loss: 0.4446, Test Acc: 0.8862\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8162, Train Acc: 0.7280 | Val Loss: 0.5531, Val Acc: 0.8400 | Test Loss: 0.4445, Test Acc: 0.8773\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 271.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0677, Train Acc: 0.6150 | Val Loss: 0.5137, Val Acc: 0.8400 | Test Loss: 0.4060, Test Acc: 0.8911\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9696, Train Acc: 0.6610 | Val Loss: 0.5531, Val Acc: 0.8200 | Test Loss: 0.4429, Test Acc: 0.8737\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 321.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 209.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8444, Train Acc: 0.7100 | Val Loss: 0.5244, Val Acc: 0.8500 | Test Loss: 0.4095, Test Acc: 0.8907\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7442, Train Acc: 0.7570 | Val Loss: 0.5363, Val Acc: 0.8300 | Test Loss: 0.4262, Test Acc: 0.8809\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8807, Train Acc: 0.6840 | Val Loss: 0.5055, Val Acc: 0.8300 | Test Loss: 0.3887, Test Acc: 0.8967\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7763, Train Acc: 0.7360 | Val Loss: 0.5217, Val Acc: 0.8300 | Test Loss: 0.4080, Test Acc: 0.8864\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 266.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7806, Train Acc: 0.7270 | Val Loss: 0.4847, Val Acc: 0.8500 | Test Loss: 0.3664, Test Acc: 0.9000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6886, Train Acc: 0.7650 | Val Loss: 0.4948, Val Acc: 0.8400 | Test Loss: 0.3860, Test Acc: 0.8899\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7524, Train Acc: 0.7360 | Val Loss: 0.4808, Val Acc: 0.8500 | Test Loss: 0.3609, Test Acc: 0.9020\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6601, Train Acc: 0.7720 | Val Loss: 0.5122, Val Acc: 0.8300 | Test Loss: 0.3865, Test Acc: 0.8910\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 186.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6787, Train Acc: 0.7630 | Val Loss: 0.4747, Val Acc: 0.8600 | Test Loss: 0.3384, Test Acc: 0.9048\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5835, Train Acc: 0.8020 | Val Loss: 0.4668, Val Acc: 0.8600 | Test Loss: 0.3522, Test Acc: 0.8973\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 230.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6994, Train Acc: 0.7430 | Val Loss: 0.4619, Val Acc: 0.8500 | Test Loss: 0.3351, Test Acc: 0.9050\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6029, Train Acc: 0.7950 | Val Loss: 0.4952, Val Acc: 0.8400 | Test Loss: 0.3817, Test Acc: 0.8893\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 151.01it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 210.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6253, Train Acc: 0.7830 | Val Loss: 0.4486, Val Acc: 0.8600 | Test Loss: 0.3198, Test Acc: 0.9070\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5218, Train Acc: 0.8250 | Val Loss: 0.4640, Val Acc: 0.8700 | Test Loss: 0.3375, Test Acc: 0.8989\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 319.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6669, Train Acc: 0.7520 | Val Loss: 0.4380, Val Acc: 0.8600 | Test Loss: 0.3083, Test Acc: 0.9122\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5360, Train Acc: 0.8100 | Val Loss: 0.4694, Val Acc: 0.8500 | Test Loss: 0.3598, Test Acc: 0.8965\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 192.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 278.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6464, Train Acc: 0.7750 | Val Loss: 0.4391, Val Acc: 0.8500 | Test Loss: 0.3107, Test Acc: 0.9079\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5242, Train Acc: 0.8330 | Val Loss: 0.4750, Val Acc: 0.8500 | Test Loss: 0.3547, Test Acc: 0.8908\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 208.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6416, Train Acc: 0.7610 | Val Loss: 0.4248, Val Acc: 0.8600 | Test Loss: 0.3011, Test Acc: 0.9124\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4747, Train Acc: 0.8550 | Val Loss: 0.4572, Val Acc: 0.8500 | Test Loss: 0.3579, Test Acc: 0.8958\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 279.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6293, Train Acc: 0.7680 | Val Loss: 0.4261, Val Acc: 0.8500 | Test Loss: 0.3029, Test Acc: 0.9111\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4726, Train Acc: 0.8290 | Val Loss: 0.4719, Val Acc: 0.8400 | Test Loss: 0.3554, Test Acc: 0.8899\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5480, Train Acc: 0.7920 | Val Loss: 0.4170, Val Acc: 0.8600 | Test Loss: 0.2916, Test Acc: 0.9153\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3986, Train Acc: 0.8620 | Val Loss: 0.4344, Val Acc: 0.8600 | Test Loss: 0.3211, Test Acc: 0.9045\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 295.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6241, Train Acc: 0.7730 | Val Loss: 0.4293, Val Acc: 0.8500 | Test Loss: 0.2947, Test Acc: 0.9103\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4569, Train Acc: 0.8460 | Val Loss: 0.4758, Val Acc: 0.8300 | Test Loss: 0.3462, Test Acc: 0.8882\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 332.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 209.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5307, Train Acc: 0.8110 | Val Loss: 0.4119, Val Acc: 0.8700 | Test Loss: 0.2871, Test Acc: 0.9120\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3680, Train Acc: 0.8740 | Val Loss: 0.4098, Val Acc: 0.8800 | Test Loss: 0.3124, Test Acc: 0.9074\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 371.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5522, Train Acc: 0.8080 | Val Loss: 0.4044, Val Acc: 0.8700 | Test Loss: 0.2813, Test Acc: 0.9161\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4061, Train Acc: 0.8590 | Val Loss: 0.4451, Val Acc: 0.8600 | Test Loss: 0.3230, Test Acc: 0.8990\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 186.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4851, Train Acc: 0.8310 | Val Loss: 0.4006, Val Acc: 0.8700 | Test Loss: 0.2808, Test Acc: 0.9155\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3660, Train Acc: 0.8690 | Val Loss: 0.4081, Val Acc: 0.8700 | Test Loss: 0.2947, Test Acc: 0.9091\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.07it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 187.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4773, Train Acc: 0.8120 | Val Loss: 0.4182, Val Acc: 0.8600 | Test Loss: 0.2746, Test Acc: 0.9164\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3591, Train Acc: 0.8700 | Val Loss: 0.4454, Val Acc: 0.8500 | Test Loss: 0.2999, Test Acc: 0.9049\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 273.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 188.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3793, Train Acc: 0.8650 | Val Loss: 0.4007, Val Acc: 0.8600 | Test Loss: 0.2666, Test Acc: 0.9160\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3035, Train Acc: 0.8940 | Val Loss: 0.4051, Val Acc: 0.8500 | Test Loss: 0.2823, Test Acc: 0.9105\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 196.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3801, Train Acc: 0.8540 | Val Loss: 0.3910, Val Acc: 0.8700 | Test Loss: 0.2585, Test Acc: 0.9200\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3010, Train Acc: 0.8950 | Val Loss: 0.3998, Val Acc: 0.8600 | Test Loss: 0.2683, Test Acc: 0.9146\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 236.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3894, Train Acc: 0.8530 | Val Loss: 0.3738, Val Acc: 0.8700 | Test Loss: 0.2564, Test Acc: 0.9164\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3083, Train Acc: 0.8990 | Val Loss: 0.3893, Val Acc: 0.8600 | Test Loss: 0.2741, Test Acc: 0.9094\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 161.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4359, Train Acc: 0.8500 | Val Loss: 0.3803, Val Acc: 0.8700 | Test Loss: 0.2565, Test Acc: 0.9196\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3251, Train Acc: 0.8920 | Val Loss: 0.4052, Val Acc: 0.8600 | Test Loss: 0.2716, Test Acc: 0.9146\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 257.73it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 264.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3864, Train Acc: 0.8560 | Val Loss: 0.3689, Val Acc: 0.8800 | Test Loss: 0.2549, Test Acc: 0.9174\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2822, Train Acc: 0.9060 | Val Loss: 0.3763, Val Acc: 0.8500 | Test Loss: 0.2630, Test Acc: 0.9134\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 347.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 187.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4214, Train Acc: 0.8380 | Val Loss: 0.3655, Val Acc: 0.8800 | Test Loss: 0.2408, Test Acc: 0.9228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2981, Train Acc: 0.8950 | Val Loss: 0.3814, Val Acc: 0.8700 | Test Loss: 0.2469, Test Acc: 0.9202\n",
      "\n",
      "--- Outer Iteration 36/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 251.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4637, Train Acc: 0.8220 | Val Loss: 0.3699, Val Acc: 0.8700 | Test Loss: 0.2596, Test Acc: 0.9137\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3025, Train Acc: 0.8980 | Val Loss: 0.4138, Val Acc: 0.8700 | Test Loss: 0.3172, Test Acc: 0.8967\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0, epsilon=0.8: Test Loss: 0.3124, Test Accuracy: 0.9074\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0, epsilon=0.8: Test Loss: 0.3172, Test Accuracy: 0.8967\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0, epsilon=1 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 164.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.2865, Train Acc: 0.2370 | Val Loss: 1.3972, Val Acc: 0.5900 | Test Loss: 1.3285, Test Acc: 0.5707\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 6.1823, Train Acc: 0.2560 | Val Loss: 1.5648, Val Acc: 0.4500 | Test Loss: 1.4275, Test Acc: 0.5248\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 226.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.7627, Train Acc: 0.1820 | Val Loss: 1.2104, Val Acc: 0.6300 | Test Loss: 1.1237, Test Acc: 0.6565\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2869, Train Acc: 0.2390 | Val Loss: 1.4064, Val Acc: 0.6300 | Test Loss: 1.3478, Test Acc: 0.6525\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 281.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.6926, Train Acc: 0.3230 | Val Loss: 1.2685, Val Acc: 0.5600 | Test Loss: 1.2548, Test Acc: 0.5889\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.9448, Train Acc: 0.3710 | Val Loss: 1.3521, Val Acc: 0.5000 | Test Loss: 1.3324, Test Acc: 0.5642\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.07it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 207.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5688, Train Acc: 0.3030 | Val Loss: 1.1051, Val Acc: 0.6700 | Test Loss: 1.0419, Test Acc: 0.7068\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.1708, Train Acc: 0.3760 | Val Loss: 1.2049, Val Acc: 0.7100 | Test Loss: 1.1210, Test Acc: 0.7054\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 201.80it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 151.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5615, Train Acc: 0.4060 | Val Loss: 1.0624, Val Acc: 0.6800 | Test Loss: 1.0116, Test Acc: 0.6715\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.0966, Train Acc: 0.4710 | Val Loss: 1.1774, Val Acc: 0.5700 | Test Loss: 1.1064, Test Acc: 0.6262\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 322.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.0723, Train Acc: 0.3570 | Val Loss: 0.8764, Val Acc: 0.7400 | Test Loss: 0.8158, Test Acc: 0.7716\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.7672, Train Acc: 0.4290 | Val Loss: 0.9457, Val Acc: 0.7400 | Test Loss: 0.8609, Test Acc: 0.7733\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.00it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6173, Train Acc: 0.5300 | Val Loss: 0.8228, Val Acc: 0.7200 | Test Loss: 0.7462, Test Acc: 0.7811\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4065, Train Acc: 0.5960 | Val Loss: 0.8746, Val Acc: 0.7100 | Test Loss: 0.7753, Test Acc: 0.7458\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7138, Train Acc: 0.4460 | Val Loss: 0.7134, Val Acc: 0.7900 | Test Loss: 0.6088, Test Acc: 0.8384\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4675, Train Acc: 0.5120 | Val Loss: 0.7539, Val Acc: 0.7700 | Test Loss: 0.6433, Test Acc: 0.8223\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 225.32it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3488, Train Acc: 0.5660 | Val Loss: 0.6953, Val Acc: 0.8100 | Test Loss: 0.6099, Test Acc: 0.8425\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1868, Train Acc: 0.6320 | Val Loss: 0.7125, Val Acc: 0.8000 | Test Loss: 0.6314, Test Acc: 0.8266\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 330.00it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4169, Train Acc: 0.4930 | Val Loss: 0.6187, Val Acc: 0.8200 | Test Loss: 0.5241, Test Acc: 0.8648\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2590, Train Acc: 0.5620 | Val Loss: 0.6842, Val Acc: 0.7800 | Test Loss: 0.5871, Test Acc: 0.8385\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1363, Train Acc: 0.6250 | Val Loss: 0.6413, Val Acc: 0.8000 | Test Loss: 0.5568, Test Acc: 0.8595\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9843, Train Acc: 0.6930 | Val Loss: 0.6593, Val Acc: 0.8000 | Test Loss: 0.5762, Test Acc: 0.8521\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 234.43it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3283, Train Acc: 0.5350 | Val Loss: 0.5911, Val Acc: 0.8200 | Test Loss: 0.4994, Test Acc: 0.8761\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1802, Train Acc: 0.5900 | Val Loss: 0.6366, Val Acc: 0.7800 | Test Loss: 0.5502, Test Acc: 0.8533\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 251.64it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 214.65it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9670, Train Acc: 0.6770 | Val Loss: 0.6203, Val Acc: 0.7900 | Test Loss: 0.5311, Test Acc: 0.8607\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8385, Train Acc: 0.7240 | Val Loss: 0.6422, Val Acc: 0.8000 | Test Loss: 0.5491, Test Acc: 0.8562\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 279.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 360.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1196, Train Acc: 0.6120 | Val Loss: 0.5740, Val Acc: 0.8300 | Test Loss: 0.4774, Test Acc: 0.8725\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9935, Train Acc: 0.6760 | Val Loss: 0.6084, Val Acc: 0.7900 | Test Loss: 0.5208, Test Acc: 0.8554\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 237.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 209.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8764, Train Acc: 0.6960 | Val Loss: 0.5805, Val Acc: 0.7700 | Test Loss: 0.4897, Test Acc: 0.8677\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7420, Train Acc: 0.7590 | Val Loss: 0.5943, Val Acc: 0.8000 | Test Loss: 0.5118, Test Acc: 0.8616\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 238.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0276, Train Acc: 0.6280 | Val Loss: 0.5588, Val Acc: 0.8300 | Test Loss: 0.4632, Test Acc: 0.8792\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9119, Train Acc: 0.6890 | Val Loss: 0.6026, Val Acc: 0.8100 | Test Loss: 0.5059, Test Acc: 0.8621\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 286.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8199, Train Acc: 0.7160 | Val Loss: 0.5495, Val Acc: 0.8100 | Test Loss: 0.4535, Test Acc: 0.8762\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6757, Train Acc: 0.7700 | Val Loss: 0.5660, Val Acc: 0.8100 | Test Loss: 0.4813, Test Acc: 0.8641\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 277.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8785, Train Acc: 0.6840 | Val Loss: 0.5312, Val Acc: 0.8300 | Test Loss: 0.4350, Test Acc: 0.8849\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7478, Train Acc: 0.7390 | Val Loss: 0.5887, Val Acc: 0.8200 | Test Loss: 0.4986, Test Acc: 0.8670\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 245.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7526, Train Acc: 0.7510 | Val Loss: 0.5208, Val Acc: 0.8200 | Test Loss: 0.4215, Test Acc: 0.8881\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6401, Train Acc: 0.7900 | Val Loss: 0.5531, Val Acc: 0.7900 | Test Loss: 0.4691, Test Acc: 0.8691\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 281.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8514, Train Acc: 0.7130 | Val Loss: 0.5343, Val Acc: 0.8300 | Test Loss: 0.4319, Test Acc: 0.8834\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6926, Train Acc: 0.7630 | Val Loss: 0.5831, Val Acc: 0.8200 | Test Loss: 0.5001, Test Acc: 0.8681\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 276.65it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 150.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6368, Train Acc: 0.8020 | Val Loss: 0.5190, Val Acc: 0.8000 | Test Loss: 0.4156, Test Acc: 0.8866\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4957, Train Acc: 0.8420 | Val Loss: 0.5375, Val Acc: 0.8100 | Test Loss: 0.4483, Test Acc: 0.8687\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 203.71it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 222.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7424, Train Acc: 0.7530 | Val Loss: 0.4990, Val Acc: 0.8400 | Test Loss: 0.3947, Test Acc: 0.8925\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5877, Train Acc: 0.8120 | Val Loss: 0.5418, Val Acc: 0.8100 | Test Loss: 0.4576, Test Acc: 0.8731\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 168.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6112, Train Acc: 0.7850 | Val Loss: 0.5026, Val Acc: 0.8200 | Test Loss: 0.3887, Test Acc: 0.8911\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4732, Train Acc: 0.8440 | Val Loss: 0.5287, Val Acc: 0.8000 | Test Loss: 0.4269, Test Acc: 0.8753\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6858, Train Acc: 0.7680 | Val Loss: 0.4910, Val Acc: 0.8300 | Test Loss: 0.3780, Test Acc: 0.8974\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5380, Train Acc: 0.8210 | Val Loss: 0.5267, Val Acc: 0.8300 | Test Loss: 0.4337, Test Acc: 0.8765\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 315.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5880, Train Acc: 0.7760 | Val Loss: 0.4900, Val Acc: 0.8200 | Test Loss: 0.3773, Test Acc: 0.8944\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4435, Train Acc: 0.8600 | Val Loss: 0.5169, Val Acc: 0.8200 | Test Loss: 0.4191, Test Acc: 0.8698\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 204.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7030, Train Acc: 0.7560 | Val Loss: 0.4664, Val Acc: 0.8400 | Test Loss: 0.3687, Test Acc: 0.8976\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5306, Train Acc: 0.8250 | Val Loss: 0.5295, Val Acc: 0.8400 | Test Loss: 0.4278, Test Acc: 0.8750\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 230.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6015, Train Acc: 0.8090 | Val Loss: 0.5035, Val Acc: 0.8200 | Test Loss: 0.3766, Test Acc: 0.8920\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4119, Train Acc: 0.8700 | Val Loss: 0.5377, Val Acc: 0.8000 | Test Loss: 0.4201, Test Acc: 0.8692\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 338.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 270.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7264, Train Acc: 0.7340 | Val Loss: 0.4572, Val Acc: 0.8300 | Test Loss: 0.3505, Test Acc: 0.9024\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4568, Train Acc: 0.8360 | Val Loss: 0.4945, Val Acc: 0.8400 | Test Loss: 0.4063, Test Acc: 0.8839\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 367.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7030, Train Acc: 0.7440 | Val Loss: 0.4679, Val Acc: 0.8300 | Test Loss: 0.3499, Test Acc: 0.8999\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4363, Train Acc: 0.8450 | Val Loss: 0.5132, Val Acc: 0.8100 | Test Loss: 0.4099, Test Acc: 0.8726\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 281.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 239.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7310, Train Acc: 0.7450 | Val Loss: 0.4394, Val Acc: 0.8400 | Test Loss: 0.3347, Test Acc: 0.9044\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4593, Train Acc: 0.8470 | Val Loss: 0.4797, Val Acc: 0.8600 | Test Loss: 0.4103, Test Acc: 0.8782\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 217.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5822, Train Acc: 0.7660 | Val Loss: 0.4476, Val Acc: 0.8300 | Test Loss: 0.3359, Test Acc: 0.9023\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3492, Train Acc: 0.8790 | Val Loss: 0.5055, Val Acc: 0.8100 | Test Loss: 0.3989, Test Acc: 0.8748\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 252.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6752, Train Acc: 0.7380 | Val Loss: 0.4222, Val Acc: 0.8400 | Test Loss: 0.3170, Test Acc: 0.9101\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4294, Train Acc: 0.8530 | Val Loss: 0.4651, Val Acc: 0.8700 | Test Loss: 0.3643, Test Acc: 0.8937\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 252.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6145, Train Acc: 0.7810 | Val Loss: 0.4368, Val Acc: 0.8300 | Test Loss: 0.3154, Test Acc: 0.9091\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4209, Train Acc: 0.8490 | Val Loss: 0.4607, Val Acc: 0.8300 | Test Loss: 0.3452, Test Acc: 0.8943\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 258.39it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6282, Train Acc: 0.7680 | Val Loss: 0.4379, Val Acc: 0.8500 | Test Loss: 0.3172, Test Acc: 0.9091\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4144, Train Acc: 0.8510 | Val Loss: 0.4672, Val Acc: 0.8700 | Test Loss: 0.3669, Test Acc: 0.8884\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 288.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6074, Train Acc: 0.7830 | Val Loss: 0.4450, Val Acc: 0.8200 | Test Loss: 0.3326, Test Acc: 0.9020\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4024, Train Acc: 0.8670 | Val Loss: 0.4979, Val Acc: 0.8300 | Test Loss: 0.3857, Test Acc: 0.8802\n",
      "\n",
      "--- Outer Iteration 36/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 259.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5261, Train Acc: 0.8160 | Val Loss: 0.4458, Val Acc: 0.8300 | Test Loss: 0.3353, Test Acc: 0.9031\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3512, Train Acc: 0.8910 | Val Loss: 0.4934, Val Acc: 0.8500 | Test Loss: 0.3995, Test Acc: 0.8820\n",
      "\n",
      "--- Outer Iteration 37/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 202.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5280, Train Acc: 0.8040 | Val Loss: 0.4534, Val Acc: 0.8200 | Test Loss: 0.3428, Test Acc: 0.8986\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3581, Train Acc: 0.8850 | Val Loss: 0.4680, Val Acc: 0.8100 | Test Loss: 0.3698, Test Acc: 0.8859\n",
      "\n",
      "--- Outer Iteration 38/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4733, Train Acc: 0.8170 | Val Loss: 0.4321, Val Acc: 0.8500 | Test Loss: 0.3241, Test Acc: 0.9029\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3229, Train Acc: 0.8910 | Val Loss: 0.4751, Val Acc: 0.8600 | Test Loss: 0.3771, Test Acc: 0.8860\n",
      "\n",
      "--- Outer Iteration 39/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 294.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4826, Train Acc: 0.8170 | Val Loss: 0.4335, Val Acc: 0.8300 | Test Loss: 0.3295, Test Acc: 0.9017\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3148, Train Acc: 0.9010 | Val Loss: 0.4813, Val Acc: 0.8300 | Test Loss: 0.4070, Test Acc: 0.8678\n",
      "\n",
      "--- Outer Iteration 40/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 270.14it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5747, Train Acc: 0.7870 | Val Loss: 0.4532, Val Acc: 0.8500 | Test Loss: 0.3428, Test Acc: 0.8947\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3400, Train Acc: 0.8870 | Val Loss: 0.5195, Val Acc: 0.8500 | Test Loss: 0.4195, Test Acc: 0.8669\n",
      "\n",
      "--- Outer Iteration 41/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 238.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 209.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5803, Train Acc: 0.7870 | Val Loss: 0.4498, Val Acc: 0.8300 | Test Loss: 0.3468, Test Acc: 0.8932\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3410, Train Acc: 0.8840 | Val Loss: 0.4719, Val Acc: 0.8200 | Test Loss: 0.3799, Test Acc: 0.8751\n",
      "\n",
      "--- Outer Iteration 42/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5056, Train Acc: 0.8100 | Val Loss: 0.4473, Val Acc: 0.8600 | Test Loss: 0.3373, Test Acc: 0.8955\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2806, Train Acc: 0.9070 | Val Loss: 0.5042, Val Acc: 0.8700 | Test Loss: 0.4081, Test Acc: 0.8712\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0, epsilon=1: Test Loss: 0.3643, Test Accuracy: 0.8937\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0, epsilon=1: Test Loss: 0.4081, Test Accuracy: 0.8712\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.2, epsilon=0 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 197.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7017, Train Acc: 0.7910 | Val Loss: 1.8853, Val Acc: 0.6300 | Test Loss: 1.7737, Test Acc: 0.6604\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2794, Train Acc: 0.8930 | Val Loss: 2.0406, Val Acc: 0.6400 | Test Loss: 1.8559, Test Acc: 0.6515\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 326.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1367, Train Acc: 0.9510 | Val Loss: 2.0610, Val Acc: 0.6600 | Test Loss: 1.9088, Test Acc: 0.6435\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0934, Train Acc: 0.9760 | Val Loss: 2.1077, Val Acc: 0.6600 | Test Loss: 1.9246, Test Acc: 0.6447\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.39it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0612, Train Acc: 0.9830 | Val Loss: 2.0574, Val Acc: 0.6700 | Test Loss: 1.8423, Test Acc: 0.6561\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0446, Train Acc: 0.9970 | Val Loss: 2.1124, Val Acc: 0.6700 | Test Loss: 1.9227, Test Acc: 0.6513\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0579, Train Acc: 0.9910 | Val Loss: 2.1727, Val Acc: 0.6700 | Test Loss: 2.0028, Test Acc: 0.6430\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0305, Train Acc: 0.9980 | Val Loss: 2.1447, Val Acc: 0.6600 | Test Loss: 1.9688, Test Acc: 0.6481\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 298.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0315, Train Acc: 0.9970 | Val Loss: 2.1682, Val Acc: 0.6700 | Test Loss: 1.9593, Test Acc: 0.6527\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0252, Train Acc: 0.9970 | Val Loss: 2.2248, Val Acc: 0.6600 | Test Loss: 2.0313, Test Acc: 0.6477\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 142.40it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0248, Train Acc: 0.9990 | Val Loss: 2.2293, Val Acc: 0.6600 | Test Loss: 2.0443, Test Acc: 0.6494\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0171, Train Acc: 0.9990 | Val Loss: 2.2366, Val Acc: 0.6600 | Test Loss: 2.0493, Test Acc: 0.6494\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 199.28it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0163, Train Acc: 0.9980 | Val Loss: 2.2649, Val Acc: 0.6600 | Test Loss: 2.0755, Test Acc: 0.6462\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0212, Train Acc: 0.9970 | Val Loss: 2.2742, Val Acc: 0.6600 | Test Loss: 2.0960, Test Acc: 0.6454\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 261.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0382, Train Acc: 0.9950 | Val Loss: 2.3108, Val Acc: 0.6600 | Test Loss: 2.1465, Test Acc: 0.6399\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0195, Train Acc: 0.9980 | Val Loss: 2.3471, Val Acc: 0.6600 | Test Loss: 2.1765, Test Acc: 0.6453\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 222.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0256, Train Acc: 0.9950 | Val Loss: 2.2790, Val Acc: 0.6600 | Test Loss: 2.0940, Test Acc: 0.6548\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0148, Train Acc: 0.9980 | Val Loss: 2.3007, Val Acc: 0.6700 | Test Loss: 2.1089, Test Acc: 0.6550\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 190.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 154.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0542, Train Acc: 0.9900 | Val Loss: 2.3724, Val Acc: 0.6600 | Test Loss: 2.1959, Test Acc: 0.6413\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0222, Train Acc: 0.9950 | Val Loss: 2.2412, Val Acc: 0.6600 | Test Loss: 2.1420, Test Acc: 0.6455\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 215.03it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0445, Train Acc: 0.9910 | Val Loss: 2.2500, Val Acc: 0.6300 | Test Loss: 2.1415, Test Acc: 0.6478\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0232, Train Acc: 0.9930 | Val Loss: 2.3649, Val Acc: 0.6400 | Test Loss: 2.2334, Test Acc: 0.6424\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 220.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0318, Train Acc: 0.9970 | Val Loss: 2.4603, Val Acc: 0.6300 | Test Loss: 2.3053, Test Acc: 0.6342\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0235, Train Acc: 0.9940 | Val Loss: 2.3826, Val Acc: 0.6400 | Test Loss: 2.1695, Test Acc: 0.6437\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 326.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0208, Train Acc: 0.9970 | Val Loss: 2.3849, Val Acc: 0.6500 | Test Loss: 2.1443, Test Acc: 0.6450\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.2, epsilon=0: Test Loss: 1.8423, Test Accuracy: 0.6561\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.2, epsilon=0: Test Loss: 2.1443, Test Accuracy: 0.6450\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.2, epsilon=0.2 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.1738, Train Acc: 0.3780 | Val Loss: 0.9964, Val Acc: 0.7900 | Test Loss: 0.8769, Test Acc: 0.7797\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9042, Train Acc: 0.5980 | Val Loss: 0.9568, Val Acc: 0.8100 | Test Loss: 0.7174, Test Acc: 0.8195\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 227.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4902, Train Acc: 0.5260 | Val Loss: 0.9786, Val Acc: 0.8100 | Test Loss: 0.6325, Test Acc: 0.8457\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5823, Train Acc: 0.6260 | Val Loss: 1.0891, Val Acc: 0.8000 | Test Loss: 0.7273, Test Acc: 0.8380\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 186.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2536, Train Acc: 0.7030 | Val Loss: 0.9325, Val Acc: 0.8000 | Test Loss: 0.5845, Test Acc: 0.8569\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9270, Train Acc: 0.7320 | Val Loss: 0.8374, Val Acc: 0.8500 | Test Loss: 0.4998, Test Acc: 0.8643\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 150.52it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 169.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7528, Train Acc: 0.7840 | Val Loss: 0.8067, Val Acc: 0.8500 | Test Loss: 0.4684, Test Acc: 0.8730\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6006, Train Acc: 0.8100 | Val Loss: 0.7854, Val Acc: 0.8400 | Test Loss: 0.4761, Test Acc: 0.8741\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4903, Train Acc: 0.8450 | Val Loss: 0.7457, Val Acc: 0.8400 | Test Loss: 0.4575, Test Acc: 0.8785\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4246, Train Acc: 0.8640 | Val Loss: 0.7117, Val Acc: 0.8300 | Test Loss: 0.4322, Test Acc: 0.8809\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 316.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 170.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3579, Train Acc: 0.8840 | Val Loss: 0.7100, Val Acc: 0.8400 | Test Loss: 0.4260, Test Acc: 0.8835\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3126, Train Acc: 0.9110 | Val Loss: 0.7120, Val Acc: 0.8400 | Test Loss: 0.4370, Test Acc: 0.8840\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.07it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 226.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2708, Train Acc: 0.9150 | Val Loss: 0.6952, Val Acc: 0.8400 | Test Loss: 0.4161, Test Acc: 0.8862\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2304, Train Acc: 0.9340 | Val Loss: 0.6932, Val Acc: 0.8400 | Test Loss: 0.4081, Test Acc: 0.8863\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2111, Train Acc: 0.9370 | Val Loss: 0.7067, Val Acc: 0.8400 | Test Loss: 0.4097, Test Acc: 0.8879\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1913, Train Acc: 0.9570 | Val Loss: 0.7053, Val Acc: 0.8400 | Test Loss: 0.4198, Test Acc: 0.8892\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1677, Train Acc: 0.9500 | Val Loss: 0.6940, Val Acc: 0.8400 | Test Loss: 0.4157, Test Acc: 0.8902\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1637, Train Acc: 0.9580 | Val Loss: 0.6873, Val Acc: 0.8400 | Test Loss: 0.4132, Test Acc: 0.8876\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 236.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1620, Train Acc: 0.9640 | Val Loss: 0.6851, Val Acc: 0.8400 | Test Loss: 0.4131, Test Acc: 0.8882\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1338, Train Acc: 0.9710 | Val Loss: 0.6880, Val Acc: 0.8400 | Test Loss: 0.4268, Test Acc: 0.8888\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1464, Train Acc: 0.9580 | Val Loss: 0.6860, Val Acc: 0.8400 | Test Loss: 0.4235, Test Acc: 0.8899\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1123, Train Acc: 0.9740 | Val Loss: 0.6792, Val Acc: 0.8400 | Test Loss: 0.4048, Test Acc: 0.8909\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 215.18it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 297.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1124, Train Acc: 0.9770 | Val Loss: 0.6789, Val Acc: 0.8400 | Test Loss: 0.3984, Test Acc: 0.8942\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0917, Train Acc: 0.9800 | Val Loss: 0.7004, Val Acc: 0.8400 | Test Loss: 0.4141, Test Acc: 0.8933\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0948, Train Acc: 0.9810 | Val Loss: 0.6922, Val Acc: 0.8400 | Test Loss: 0.4108, Test Acc: 0.8935\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0867, Train Acc: 0.9850 | Val Loss: 0.6809, Val Acc: 0.8400 | Test Loss: 0.4010, Test Acc: 0.8944\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.2, epsilon=0.2: Test Loss: 0.4998, Test Accuracy: 0.8643\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.2, epsilon=0.2: Test Loss: 0.4010, Test Accuracy: 0.8944\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.2, epsilon=0.4 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 188.89it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 6.7318, Train Acc: 0.2650 | Val Loss: 1.1584, Val Acc: 0.7000 | Test Loss: 1.0514, Test Acc: 0.7007\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.3154, Train Acc: 0.3460 | Val Loss: 1.0928, Val Acc: 0.7000 | Test Loss: 0.9883, Test Acc: 0.7203\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 162.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.5134, Train Acc: 0.3060 | Val Loss: 1.0635, Val Acc: 0.7100 | Test Loss: 0.8815, Test Acc: 0.7619\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.1311, Train Acc: 0.3910 | Val Loss: 1.3231, Val Acc: 0.7000 | Test Loss: 1.1138, Test Acc: 0.7520\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5099, Train Acc: 0.4820 | Val Loss: 1.0271, Val Acc: 0.7200 | Test Loss: 0.8610, Test Acc: 0.7936\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9790, Train Acc: 0.5310 | Val Loss: 0.8867, Val Acc: 0.7800 | Test Loss: 0.7126, Test Acc: 0.8203\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 293.65it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 169.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5490, Train Acc: 0.5670 | Val Loss: 0.8735, Val Acc: 0.8100 | Test Loss: 0.6819, Test Acc: 0.8302\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2969, Train Acc: 0.6060 | Val Loss: 0.8592, Val Acc: 0.7900 | Test Loss: 0.6624, Test Acc: 0.8372\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 245.71it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 159.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1553, Train Acc: 0.6460 | Val Loss: 0.7611, Val Acc: 0.8200 | Test Loss: 0.5682, Test Acc: 0.8525\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0311, Train Acc: 0.6820 | Val Loss: 0.6790, Val Acc: 0.8500 | Test Loss: 0.4949, Test Acc: 0.8632\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9157, Train Acc: 0.6920 | Val Loss: 0.6707, Val Acc: 0.8500 | Test Loss: 0.4857, Test Acc: 0.8671\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8197, Train Acc: 0.7250 | Val Loss: 0.6573, Val Acc: 0.8500 | Test Loss: 0.4794, Test Acc: 0.8696\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 242.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 356.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7506, Train Acc: 0.7510 | Val Loss: 0.6353, Val Acc: 0.8500 | Test Loss: 0.4507, Test Acc: 0.8758\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6852, Train Acc: 0.7760 | Val Loss: 0.6264, Val Acc: 0.8500 | Test Loss: 0.4319, Test Acc: 0.8796\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6346, Train Acc: 0.7820 | Val Loss: 0.6106, Val Acc: 0.8600 | Test Loss: 0.4133, Test Acc: 0.8849\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5877, Train Acc: 0.7990 | Val Loss: 0.5944, Val Acc: 0.8600 | Test Loss: 0.3955, Test Acc: 0.8899\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5358, Train Acc: 0.8220 | Val Loss: 0.6008, Val Acc: 0.8600 | Test Loss: 0.3885, Test Acc: 0.8899\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5118, Train Acc: 0.8210 | Val Loss: 0.5990, Val Acc: 0.8600 | Test Loss: 0.3788, Test Acc: 0.8920\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 274.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4775, Train Acc: 0.8450 | Val Loss: 0.5827, Val Acc: 0.8600 | Test Loss: 0.3658, Test Acc: 0.8951\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4553, Train Acc: 0.8470 | Val Loss: 0.5785, Val Acc: 0.8600 | Test Loss: 0.3573, Test Acc: 0.8985\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 351.28it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4241, Train Acc: 0.8530 | Val Loss: 0.5700, Val Acc: 0.8600 | Test Loss: 0.3490, Test Acc: 0.8997\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3923, Train Acc: 0.8720 | Val Loss: 0.5624, Val Acc: 0.8600 | Test Loss: 0.3422, Test Acc: 0.9016\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 271.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3755, Train Acc: 0.8810 | Val Loss: 0.5746, Val Acc: 0.8600 | Test Loss: 0.3479, Test Acc: 0.9000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3456, Train Acc: 0.8970 | Val Loss: 0.5711, Val Acc: 0.8600 | Test Loss: 0.3422, Test Acc: 0.9013\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 232.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 148.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3177, Train Acc: 0.9010 | Val Loss: 0.5441, Val Acc: 0.8600 | Test Loss: 0.3233, Test Acc: 0.9058\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2937, Train Acc: 0.9140 | Val Loss: 0.5392, Val Acc: 0.8600 | Test Loss: 0.3183, Test Acc: 0.9073\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 359.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2922, Train Acc: 0.9030 | Val Loss: 0.5532, Val Acc: 0.8600 | Test Loss: 0.3263, Test Acc: 0.9063\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2699, Train Acc: 0.9230 | Val Loss: 0.5486, Val Acc: 0.8600 | Test Loss: 0.3305, Test Acc: 0.9072\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 257.87it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 286.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2654, Train Acc: 0.9190 | Val Loss: 0.5456, Val Acc: 0.8600 | Test Loss: 0.3205, Test Acc: 0.9074\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2320, Train Acc: 0.9350 | Val Loss: 0.5317, Val Acc: 0.8600 | Test Loss: 0.3138, Test Acc: 0.9074\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 281.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2576, Train Acc: 0.9250 | Val Loss: 0.5643, Val Acc: 0.8600 | Test Loss: 0.3331, Test Acc: 0.9074\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2234, Train Acc: 0.9390 | Val Loss: 0.5830, Val Acc: 0.8600 | Test Loss: 0.3746, Test Acc: 0.9026\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 256.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3063, Train Acc: 0.9140 | Val Loss: 0.5286, Val Acc: 0.8600 | Test Loss: 0.3106, Test Acc: 0.9097\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2153, Train Acc: 0.9370 | Val Loss: 0.5240, Val Acc: 0.8600 | Test Loss: 0.3195, Test Acc: 0.9050\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 228.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3234, Train Acc: 0.9030 | Val Loss: 0.5362, Val Acc: 0.8600 | Test Loss: 0.3284, Test Acc: 0.9104\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.2, epsilon=0.4: Test Loss: 0.4133, Test Accuracy: 0.8849\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.2, epsilon=0.4: Test Loss: 0.3284, Test Accuracy: 0.9104\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.2, epsilon=0.6 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 284.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 165.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.6117, Train Acc: 0.2480 | Val Loss: 1.1981, Val Acc: 0.6900 | Test Loss: 1.1085, Test Acc: 0.6587\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.4188, Train Acc: 0.2840 | Val Loss: 1.2611, Val Acc: 0.6000 | Test Loss: 1.1469, Test Acc: 0.6419\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 212.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.1562, Train Acc: 0.2280 | Val Loss: 1.1248, Val Acc: 0.7000 | Test Loss: 0.9945, Test Acc: 0.7168\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.7268, Train Acc: 0.3140 | Val Loss: 1.3027, Val Acc: 0.6700 | Test Loss: 1.1969, Test Acc: 0.7098\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 259.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 298.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.0874, Train Acc: 0.3890 | Val Loss: 1.0518, Val Acc: 0.6900 | Test Loss: 0.9578, Test Acc: 0.7296\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.4811, Train Acc: 0.4410 | Val Loss: 0.9549, Val Acc: 0.7200 | Test Loss: 0.8785, Test Acc: 0.7462\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 320.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.0005, Train Acc: 0.4480 | Val Loss: 0.9978, Val Acc: 0.7200 | Test Loss: 0.8834, Test Acc: 0.7691\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6729, Train Acc: 0.5120 | Val Loss: 0.9876, Val Acc: 0.7400 | Test Loss: 0.8783, Test Acc: 0.7830\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 368.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 142.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7629, Train Acc: 0.5360 | Val Loss: 0.7856, Val Acc: 0.7800 | Test Loss: 0.6736, Test Acc: 0.8159\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4620, Train Acc: 0.5860 | Val Loss: 0.7238, Val Acc: 0.7900 | Test Loss: 0.6141, Test Acc: 0.8193\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 333.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4024, Train Acc: 0.5530 | Val Loss: 0.7397, Val Acc: 0.7600 | Test Loss: 0.6124, Test Acc: 0.8286\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2375, Train Acc: 0.6010 | Val Loss: 0.7809, Val Acc: 0.7700 | Test Loss: 0.6375, Test Acc: 0.8316\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 274.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1339, Train Acc: 0.6400 | Val Loss: 0.6726, Val Acc: 0.8300 | Test Loss: 0.5344, Test Acc: 0.8514\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0197, Train Acc: 0.6780 | Val Loss: 0.6345, Val Acc: 0.8400 | Test Loss: 0.4878, Test Acc: 0.8618\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 274.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 172.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0339, Train Acc: 0.6430 | Val Loss: 0.6295, Val Acc: 0.8400 | Test Loss: 0.4808, Test Acc: 0.8658\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9423, Train Acc: 0.6740 | Val Loss: 0.6361, Val Acc: 0.8200 | Test Loss: 0.4824, Test Acc: 0.8677\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 227.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8610, Train Acc: 0.7050 | Val Loss: 0.5732, Val Acc: 0.8400 | Test Loss: 0.4230, Test Acc: 0.8799\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7830, Train Acc: 0.7400 | Val Loss: 0.5517, Val Acc: 0.8400 | Test Loss: 0.4063, Test Acc: 0.8830\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 252.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 308.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8443, Train Acc: 0.6900 | Val Loss: 0.5733, Val Acc: 0.8500 | Test Loss: 0.4161, Test Acc: 0.8825\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7471, Train Acc: 0.7230 | Val Loss: 0.6012, Val Acc: 0.8500 | Test Loss: 0.4453, Test Acc: 0.8756\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 267.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7332, Train Acc: 0.7500 | Val Loss: 0.5391, Val Acc: 0.8500 | Test Loss: 0.3810, Test Acc: 0.8906\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6518, Train Acc: 0.7820 | Val Loss: 0.5125, Val Acc: 0.8500 | Test Loss: 0.3637, Test Acc: 0.8923\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7641, Train Acc: 0.7060 | Val Loss: 0.5156, Val Acc: 0.8500 | Test Loss: 0.3595, Test Acc: 0.8989\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6582, Train Acc: 0.7570 | Val Loss: 0.5322, Val Acc: 0.8600 | Test Loss: 0.3845, Test Acc: 0.8917\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 270.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6536, Train Acc: 0.7710 | Val Loss: 0.4920, Val Acc: 0.8500 | Test Loss: 0.3261, Test Acc: 0.9056\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5659, Train Acc: 0.8010 | Val Loss: 0.4940, Val Acc: 0.8500 | Test Loss: 0.3391, Test Acc: 0.8949\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 207.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6772, Train Acc: 0.7590 | Val Loss: 0.5115, Val Acc: 0.8500 | Test Loss: 0.3359, Test Acc: 0.9010\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5552, Train Acc: 0.8110 | Val Loss: 0.5361, Val Acc: 0.8500 | Test Loss: 0.3711, Test Acc: 0.8953\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.68it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6093, Train Acc: 0.7770 | Val Loss: 0.4664, Val Acc: 0.8600 | Test Loss: 0.2941, Test Acc: 0.9116\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4895, Train Acc: 0.8420 | Val Loss: 0.4641, Val Acc: 0.8500 | Test Loss: 0.3078, Test Acc: 0.9026\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 224.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6186, Train Acc: 0.7690 | Val Loss: 0.4778, Val Acc: 0.8600 | Test Loss: 0.3071, Test Acc: 0.9076\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5139, Train Acc: 0.8280 | Val Loss: 0.5314, Val Acc: 0.8700 | Test Loss: 0.3602, Test Acc: 0.8962\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 287.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 335.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5299, Train Acc: 0.8130 | Val Loss: 0.4827, Val Acc: 0.8500 | Test Loss: 0.3007, Test Acc: 0.9093\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4255, Train Acc: 0.8730 | Val Loss: 0.4479, Val Acc: 0.8500 | Test Loss: 0.2886, Test Acc: 0.9091\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 280.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5132, Train Acc: 0.8240 | Val Loss: 0.4544, Val Acc: 0.8600 | Test Loss: 0.2890, Test Acc: 0.9114\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4177, Train Acc: 0.8560 | Val Loss: 0.5051, Val Acc: 0.8800 | Test Loss: 0.3379, Test Acc: 0.9025\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 318.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 308.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4685, Train Acc: 0.8300 | Val Loss: 0.4700, Val Acc: 0.8600 | Test Loss: 0.2898, Test Acc: 0.9116\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3686, Train Acc: 0.8740 | Val Loss: 0.4514, Val Acc: 0.8600 | Test Loss: 0.2791, Test Acc: 0.9116\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 246.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4724, Train Acc: 0.8200 | Val Loss: 0.4364, Val Acc: 0.8700 | Test Loss: 0.2650, Test Acc: 0.9169\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3865, Train Acc: 0.8630 | Val Loss: 0.4540, Val Acc: 0.8800 | Test Loss: 0.2944, Test Acc: 0.9112\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 176.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4069, Train Acc: 0.8620 | Val Loss: 0.4406, Val Acc: 0.8600 | Test Loss: 0.2689, Test Acc: 0.9174\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3332, Train Acc: 0.8860 | Val Loss: 0.4363, Val Acc: 0.8600 | Test Loss: 0.2676, Test Acc: 0.9157\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3720, Train Acc: 0.8650 | Val Loss: 0.4401, Val Acc: 0.8600 | Test Loss: 0.2682, Test Acc: 0.9163\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3064, Train Acc: 0.9060 | Val Loss: 0.4574, Val Acc: 0.8800 | Test Loss: 0.2901, Test Acc: 0.9132\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 319.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3350, Train Acc: 0.8750 | Val Loss: 0.4496, Val Acc: 0.8600 | Test Loss: 0.2627, Test Acc: 0.9177\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2777, Train Acc: 0.9100 | Val Loss: 0.4480, Val Acc: 0.8600 | Test Loss: 0.2543, Test Acc: 0.9192\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3551, Train Acc: 0.8700 | Val Loss: 0.4163, Val Acc: 0.8700 | Test Loss: 0.2490, Test Acc: 0.9213\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2980, Train Acc: 0.9060 | Val Loss: 0.4237, Val Acc: 0.8800 | Test Loss: 0.2633, Test Acc: 0.9194\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 255.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 229.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3218, Train Acc: 0.8960 | Val Loss: 0.4379, Val Acc: 0.8600 | Test Loss: 0.2548, Test Acc: 0.9180\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2623, Train Acc: 0.9220 | Val Loss: 0.4765, Val Acc: 0.8600 | Test Loss: 0.2651, Test Acc: 0.9140\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3397, Train Acc: 0.8740 | Val Loss: 0.4351, Val Acc: 0.8700 | Test Loss: 0.2481, Test Acc: 0.9206\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2683, Train Acc: 0.9150 | Val Loss: 0.4079, Val Acc: 0.8700 | Test Loss: 0.2528, Test Acc: 0.9225\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3751, Train Acc: 0.8540 | Val Loss: 0.4295, Val Acc: 0.8700 | Test Loss: 0.2473, Test Acc: 0.9202\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2830, Train Acc: 0.8990 | Val Loss: 0.4820, Val Acc: 0.8600 | Test Loss: 0.2788, Test Acc: 0.9090\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.49it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 140.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3641, Train Acc: 0.8570 | Val Loss: 0.4314, Val Acc: 0.8800 | Test Loss: 0.2481, Test Acc: 0.9202\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2687, Train Acc: 0.9100 | Val Loss: 0.3943, Val Acc: 0.8900 | Test Loss: 0.2558, Test Acc: 0.9225\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 201.63it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 299.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4069, Train Acc: 0.8450 | Val Loss: 0.4170, Val Acc: 0.8800 | Test Loss: 0.2393, Test Acc: 0.9244\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2647, Train Acc: 0.9170 | Val Loss: 0.4700, Val Acc: 0.8600 | Test Loss: 0.2763, Test Acc: 0.9098\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.45it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4276, Train Acc: 0.8460 | Val Loss: 0.4349, Val Acc: 0.8700 | Test Loss: 0.2487, Test Acc: 0.9212\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2583, Train Acc: 0.9130 | Val Loss: 0.4146, Val Acc: 0.8800 | Test Loss: 0.2751, Test Acc: 0.9192\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 238.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3944, Train Acc: 0.8560 | Val Loss: 0.4390, Val Acc: 0.8800 | Test Loss: 0.2498, Test Acc: 0.9228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2606, Train Acc: 0.9150 | Val Loss: 0.4781, Val Acc: 0.8800 | Test Loss: 0.2769, Test Acc: 0.9131\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 169.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3466, Train Acc: 0.8660 | Val Loss: 0.4559, Val Acc: 0.8800 | Test Loss: 0.2527, Test Acc: 0.9224\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2340, Train Acc: 0.9200 | Val Loss: 0.4365, Val Acc: 0.8800 | Test Loss: 0.2803, Test Acc: 0.9227\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 336.00it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 217.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2959, Train Acc: 0.8930 | Val Loss: 0.4584, Val Acc: 0.8700 | Test Loss: 0.2598, Test Acc: 0.9212\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2037, Train Acc: 0.9290 | Val Loss: 0.4808, Val Acc: 0.8600 | Test Loss: 0.2710, Test Acc: 0.9132\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 201.00it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2529, Train Acc: 0.9150 | Val Loss: 0.4688, Val Acc: 0.8800 | Test Loss: 0.2578, Test Acc: 0.9206\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1831, Train Acc: 0.9470 | Val Loss: 0.4523, Val Acc: 0.8800 | Test Loss: 0.2755, Test Acc: 0.9217\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2794, Train Acc: 0.9120 | Val Loss: 0.4402, Val Acc: 0.8700 | Test Loss: 0.2426, Test Acc: 0.9240\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1851, Train Acc: 0.9370 | Val Loss: 0.4324, Val Acc: 0.8700 | Test Loss: 0.2457, Test Acc: 0.9193\n",
      "\n",
      "--- Outer Iteration 36/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 329.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2681, Train Acc: 0.9120 | Val Loss: 0.4249, Val Acc: 0.8700 | Test Loss: 0.2304, Test Acc: 0.9292\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1743, Train Acc: 0.9520 | Val Loss: 0.4392, Val Acc: 0.8800 | Test Loss: 0.2540, Test Acc: 0.9248\n",
      "\n",
      "--- Outer Iteration 37/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2162, Train Acc: 0.9230 | Val Loss: 0.4569, Val Acc: 0.8700 | Test Loss: 0.2423, Test Acc: 0.9262\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1544, Train Acc: 0.9600 | Val Loss: 0.4750, Val Acc: 0.8700 | Test Loss: 0.2489, Test Acc: 0.9206\n",
      "\n",
      "--- Outer Iteration 38/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2215, Train Acc: 0.9230 | Val Loss: 0.4424, Val Acc: 0.8700 | Test Loss: 0.2334, Test Acc: 0.9278\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1588, Train Acc: 0.9580 | Val Loss: 0.4351, Val Acc: 0.8700 | Test Loss: 0.2384, Test Acc: 0.9273\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.2, epsilon=0.6: Test Loss: 0.2558, Test Accuracy: 0.9225\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.2, epsilon=0.6: Test Loss: 0.2384, Test Accuracy: 0.9273\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.2, epsilon=0.8 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.77it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.0172, Train Acc: 0.2430 | Val Loss: 1.3057, Val Acc: 0.6200 | Test Loss: 1.2355, Test Acc: 0.6127\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.9605, Train Acc: 0.2710 | Val Loss: 1.4345, Val Acc: 0.5200 | Test Loss: 1.2890, Test Acc: 0.5795\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 291.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 239.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.5291, Train Acc: 0.1900 | Val Loss: 1.1394, Val Acc: 0.6400 | Test Loss: 1.0169, Test Acc: 0.6968\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.0326, Train Acc: 0.2540 | Val Loss: 1.3359, Val Acc: 0.6600 | Test Loss: 1.2497, Test Acc: 0.6782\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 296.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 187.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.4312, Train Acc: 0.3430 | Val Loss: 1.0939, Val Acc: 0.6400 | Test Loss: 1.0487, Test Acc: 0.6811\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.7927, Train Acc: 0.3870 | Val Loss: 1.0860, Val Acc: 0.6400 | Test Loss: 1.0482, Test Acc: 0.6781\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 244.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.3220, Train Acc: 0.3780 | Val Loss: 1.0597, Val Acc: 0.7100 | Test Loss: 0.9640, Test Acc: 0.7408\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9800, Train Acc: 0.4480 | Val Loss: 1.1234, Val Acc: 0.7100 | Test Loss: 1.0102, Test Acc: 0.7418\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 244.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.1542, Train Acc: 0.4610 | Val Loss: 0.8686, Val Acc: 0.7400 | Test Loss: 0.7980, Test Acc: 0.7663\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8101, Train Acc: 0.5270 | Val Loss: 0.8814, Val Acc: 0.7300 | Test Loss: 0.7936, Test Acc: 0.7527\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 377.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7172, Train Acc: 0.4510 | Val Loss: 0.7940, Val Acc: 0.7700 | Test Loss: 0.6897, Test Acc: 0.8059\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5051, Train Acc: 0.5130 | Val Loss: 0.8672, Val Acc: 0.7500 | Test Loss: 0.7397, Test Acc: 0.8011\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 300.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4358, Train Acc: 0.5890 | Val Loss: 0.7067, Val Acc: 0.7900 | Test Loss: 0.6002, Test Acc: 0.8318\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2604, Train Acc: 0.6340 | Val Loss: 0.7071, Val Acc: 0.8000 | Test Loss: 0.5860, Test Acc: 0.8300\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 211.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4205, Train Acc: 0.4950 | Val Loss: 0.6610, Val Acc: 0.8100 | Test Loss: 0.5384, Test Acc: 0.8530\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2820, Train Acc: 0.5360 | Val Loss: 0.7336, Val Acc: 0.7700 | Test Loss: 0.6087, Test Acc: 0.8311\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1226, Train Acc: 0.6330 | Val Loss: 0.6114, Val Acc: 0.8200 | Test Loss: 0.5000, Test Acc: 0.8681\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9865, Train Acc: 0.6830 | Val Loss: 0.6082, Val Acc: 0.8200 | Test Loss: 0.4915, Test Acc: 0.8662\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 279.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2348, Train Acc: 0.5680 | Val Loss: 0.5703, Val Acc: 0.8300 | Test Loss: 0.4443, Test Acc: 0.8814\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1063, Train Acc: 0.6140 | Val Loss: 0.6263, Val Acc: 0.8000 | Test Loss: 0.4993, Test Acc: 0.8580\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9733, Train Acc: 0.6690 | Val Loss: 0.5770, Val Acc: 0.8200 | Test Loss: 0.4490, Test Acc: 0.8804\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8675, Train Acc: 0.7100 | Val Loss: 0.5673, Val Acc: 0.8300 | Test Loss: 0.4414, Test Acc: 0.8772\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0261, Train Acc: 0.6310 | Val Loss: 0.5502, Val Acc: 0.8300 | Test Loss: 0.4151, Test Acc: 0.8880\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9122, Train Acc: 0.6800 | Val Loss: 0.5730, Val Acc: 0.8100 | Test Loss: 0.4417, Test Acc: 0.8713\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8635, Train Acc: 0.7090 | Val Loss: 0.5164, Val Acc: 0.8300 | Test Loss: 0.3891, Test Acc: 0.9001\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7601, Train Acc: 0.7540 | Val Loss: 0.5150, Val Acc: 0.8500 | Test Loss: 0.3942, Test Acc: 0.8936\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 190.03it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9400, Train Acc: 0.6590 | Val Loss: 0.4946, Val Acc: 0.8400 | Test Loss: 0.3798, Test Acc: 0.8979\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8107, Train Acc: 0.7250 | Val Loss: 0.5314, Val Acc: 0.8200 | Test Loss: 0.4179, Test Acc: 0.8824\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 233.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7681, Train Acc: 0.7480 | Val Loss: 0.5020, Val Acc: 0.8300 | Test Loss: 0.3714, Test Acc: 0.8989\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6545, Train Acc: 0.7850 | Val Loss: 0.5166, Val Acc: 0.8300 | Test Loss: 0.3948, Test Acc: 0.8851\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 242.86it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7882, Train Acc: 0.7110 | Val Loss: 0.4906, Val Acc: 0.8500 | Test Loss: 0.3653, Test Acc: 0.8987\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6587, Train Acc: 0.7710 | Val Loss: 0.5132, Val Acc: 0.8400 | Test Loss: 0.4010, Test Acc: 0.8912\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 197.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 224.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7646, Train Acc: 0.7290 | Val Loss: 0.4714, Val Acc: 0.8600 | Test Loss: 0.3430, Test Acc: 0.9083\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6394, Train Acc: 0.7840 | Val Loss: 0.4869, Val Acc: 0.8400 | Test Loss: 0.3729, Test Acc: 0.8920\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 211.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7789, Train Acc: 0.7070 | Val Loss: 0.4456, Val Acc: 0.8500 | Test Loss: 0.3296, Test Acc: 0.9067\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6610, Train Acc: 0.7600 | Val Loss: 0.4895, Val Acc: 0.8400 | Test Loss: 0.3914, Test Acc: 0.8902\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 216.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 187.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6673, Train Acc: 0.7650 | Val Loss: 0.4469, Val Acc: 0.8600 | Test Loss: 0.3303, Test Acc: 0.9075\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5385, Train Acc: 0.8140 | Val Loss: 0.4676, Val Acc: 0.8400 | Test Loss: 0.3631, Test Acc: 0.8939\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 230.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 225.65it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6631, Train Acc: 0.7660 | Val Loss: 0.4328, Val Acc: 0.8500 | Test Loss: 0.3193, Test Acc: 0.9063\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5565, Train Acc: 0.8210 | Val Loss: 0.4731, Val Acc: 0.8500 | Test Loss: 0.3654, Test Acc: 0.8911\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 288.89it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5989, Train Acc: 0.7910 | Val Loss: 0.4326, Val Acc: 0.8600 | Test Loss: 0.3136, Test Acc: 0.9101\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4907, Train Acc: 0.8380 | Val Loss: 0.4602, Val Acc: 0.8700 | Test Loss: 0.3503, Test Acc: 0.8940\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 254.61it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6018, Train Acc: 0.7930 | Val Loss: 0.4331, Val Acc: 0.8500 | Test Loss: 0.3112, Test Acc: 0.9065\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5115, Train Acc: 0.8200 | Val Loss: 0.4535, Val Acc: 0.8400 | Test Loss: 0.3417, Test Acc: 0.8953\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 353.31it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 164.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5519, Train Acc: 0.8030 | Val Loss: 0.4121, Val Acc: 0.8600 | Test Loss: 0.3001, Test Acc: 0.9101\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4548, Train Acc: 0.8520 | Val Loss: 0.4588, Val Acc: 0.8600 | Test Loss: 0.3365, Test Acc: 0.8952\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 367.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5350, Train Acc: 0.8120 | Val Loss: 0.4257, Val Acc: 0.8400 | Test Loss: 0.3065, Test Acc: 0.9054\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4378, Train Acc: 0.8570 | Val Loss: 0.4652, Val Acc: 0.8500 | Test Loss: 0.3491, Test Acc: 0.8911\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5521, Train Acc: 0.8040 | Val Loss: 0.4310, Val Acc: 0.8500 | Test Loss: 0.3054, Test Acc: 0.9047\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4514, Train Acc: 0.8570 | Val Loss: 0.4398, Val Acc: 0.8600 | Test Loss: 0.3315, Test Acc: 0.8954\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4935, Train Acc: 0.8100 | Val Loss: 0.4263, Val Acc: 0.8500 | Test Loss: 0.3074, Test Acc: 0.9024\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3876, Train Acc: 0.8700 | Val Loss: 0.4493, Val Acc: 0.8400 | Test Loss: 0.3304, Test Acc: 0.8977\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 186.88it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4866, Train Acc: 0.8310 | Val Loss: 0.4216, Val Acc: 0.8600 | Test Loss: 0.2901, Test Acc: 0.9101\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3778, Train Acc: 0.8860 | Val Loss: 0.4231, Val Acc: 0.8600 | Test Loss: 0.3240, Test Acc: 0.8965\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 191.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4941, Train Acc: 0.8240 | Val Loss: 0.4012, Val Acc: 0.8400 | Test Loss: 0.3019, Test Acc: 0.9065\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3656, Train Acc: 0.8860 | Val Loss: 0.4285, Val Acc: 0.8500 | Test Loss: 0.3315, Test Acc: 0.8978\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 170.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5483, Train Acc: 0.8000 | Val Loss: 0.3925, Val Acc: 0.8700 | Test Loss: 0.2746, Test Acc: 0.9130\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4143, Train Acc: 0.8590 | Val Loss: 0.4255, Val Acc: 0.8400 | Test Loss: 0.3094, Test Acc: 0.9006\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 233.86it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5099, Train Acc: 0.8070 | Val Loss: 0.3988, Val Acc: 0.8600 | Test Loss: 0.2840, Test Acc: 0.9107\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3727, Train Acc: 0.8770 | Val Loss: 0.4409, Val Acc: 0.8500 | Test Loss: 0.3343, Test Acc: 0.8951\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 221.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4976, Train Acc: 0.8160 | Val Loss: 0.4001, Val Acc: 0.8700 | Test Loss: 0.2945, Test Acc: 0.9055\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3351, Train Acc: 0.8840 | Val Loss: 0.4219, Val Acc: 0.8700 | Test Loss: 0.3507, Test Acc: 0.8897\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.2, epsilon=0.8: Test Loss: 0.3503, Test Accuracy: 0.8940\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.2, epsilon=0.8: Test Loss: 0.3507, Test Accuracy: 0.8897\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.2, epsilon=1 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.2276, Train Acc: 0.2390 | Val Loss: 1.4091, Val Acc: 0.5900 | Test Loss: 1.3595, Test Acc: 0.5613\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 6.1673, Train Acc: 0.2640 | Val Loss: 1.5601, Val Acc: 0.4400 | Test Loss: 1.4233, Test Acc: 0.5222\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 226.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.7570, Train Acc: 0.1670 | Val Loss: 1.1984, Val Acc: 0.6300 | Test Loss: 1.1139, Test Acc: 0.6630\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2989, Train Acc: 0.2280 | Val Loss: 1.3949, Val Acc: 0.6300 | Test Loss: 1.3425, Test Acc: 0.6540\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 333.81it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.7188, Train Acc: 0.3050 | Val Loss: 1.2351, Val Acc: 0.5900 | Test Loss: 1.2318, Test Acc: 0.6022\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.9707, Train Acc: 0.3540 | Val Loss: 1.3266, Val Acc: 0.5500 | Test Loss: 1.3130, Test Acc: 0.5768\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.32it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 224.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5900, Train Acc: 0.2900 | Val Loss: 1.1215, Val Acc: 0.6800 | Test Loss: 1.0582, Test Acc: 0.7100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.1947, Train Acc: 0.3620 | Val Loss: 1.2939, Val Acc: 0.6800 | Test Loss: 1.1926, Test Acc: 0.6930\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 315.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.6155, Train Acc: 0.4060 | Val Loss: 1.1069, Val Acc: 0.6300 | Test Loss: 1.0540, Test Acc: 0.6573\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.1107, Train Acc: 0.4680 | Val Loss: 1.2463, Val Acc: 0.5700 | Test Loss: 1.1649, Test Acc: 0.6008\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 209.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 236.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.1495, Train Acc: 0.3200 | Val Loss: 0.9010, Val Acc: 0.7000 | Test Loss: 0.8604, Test Acc: 0.7585\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8529, Train Acc: 0.4140 | Val Loss: 0.9581, Val Acc: 0.7000 | Test Loss: 0.8821, Test Acc: 0.7688\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 238.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6802, Train Acc: 0.4980 | Val Loss: 0.8497, Val Acc: 0.7400 | Test Loss: 0.7736, Test Acc: 0.7674\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4813, Train Acc: 0.5590 | Val Loss: 0.9101, Val Acc: 0.6900 | Test Loss: 0.8025, Test Acc: 0.7376\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.63it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7111, Train Acc: 0.4290 | Val Loss: 0.7340, Val Acc: 0.7800 | Test Loss: 0.6360, Test Acc: 0.8289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4798, Train Acc: 0.4740 | Val Loss: 0.7827, Val Acc: 0.7900 | Test Loss: 0.6809, Test Acc: 0.8115\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3989, Train Acc: 0.5740 | Val Loss: 0.7091, Val Acc: 0.8100 | Test Loss: 0.6178, Test Acc: 0.8458\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2108, Train Acc: 0.6260 | Val Loss: 0.7393, Val Acc: 0.7800 | Test Loss: 0.6483, Test Acc: 0.8168\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.28it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5556, Train Acc: 0.4540 | Val Loss: 0.6259, Val Acc: 0.8100 | Test Loss: 0.5324, Test Acc: 0.8640\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3873, Train Acc: 0.5250 | Val Loss: 0.6887, Val Acc: 0.7900 | Test Loss: 0.5903, Test Acc: 0.8372\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 233.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 301.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2812, Train Acc: 0.5910 | Val Loss: 0.6461, Val Acc: 0.8100 | Test Loss: 0.5559, Test Acc: 0.8681\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1354, Train Acc: 0.6510 | Val Loss: 0.6956, Val Acc: 0.7800 | Test Loss: 0.5921, Test Acc: 0.8571\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3823, Train Acc: 0.5020 | Val Loss: 0.6000, Val Acc: 0.8100 | Test Loss: 0.4970, Test Acc: 0.8762\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2128, Train Acc: 0.5730 | Val Loss: 0.6745, Val Acc: 0.7700 | Test Loss: 0.5750, Test Acc: 0.8416\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.96it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9933, Train Acc: 0.6740 | Val Loss: 0.6373, Val Acc: 0.8000 | Test Loss: 0.5335, Test Acc: 0.8711\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8703, Train Acc: 0.7190 | Val Loss: 0.6504, Val Acc: 0.8200 | Test Loss: 0.5512, Test Acc: 0.8695\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 314.74it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2335, Train Acc: 0.5700 | Val Loss: 0.5727, Val Acc: 0.8200 | Test Loss: 0.4739, Test Acc: 0.8763\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0847, Train Acc: 0.6340 | Val Loss: 0.6397, Val Acc: 0.7800 | Test Loss: 0.5436, Test Acc: 0.8428\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 229.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8548, Train Acc: 0.7180 | Val Loss: 0.5965, Val Acc: 0.8200 | Test Loss: 0.4868, Test Acc: 0.8822\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7225, Train Acc: 0.7650 | Val Loss: 0.6256, Val Acc: 0.8100 | Test Loss: 0.5182, Test Acc: 0.8715\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 143.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0960, Train Acc: 0.6020 | Val Loss: 0.5634, Val Acc: 0.8400 | Test Loss: 0.4705, Test Acc: 0.8742\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9588, Train Acc: 0.6720 | Val Loss: 0.6023, Val Acc: 0.8000 | Test Loss: 0.5124, Test Acc: 0.8483\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 314.37it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7944, Train Acc: 0.7330 | Val Loss: 0.5771, Val Acc: 0.8100 | Test Loss: 0.4679, Test Acc: 0.8757\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6787, Train Acc: 0.7860 | Val Loss: 0.5951, Val Acc: 0.8300 | Test Loss: 0.4768, Test Acc: 0.8723\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.61it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 232.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9564, Train Acc: 0.6700 | Val Loss: 0.5584, Val Acc: 0.8300 | Test Loss: 0.4440, Test Acc: 0.8825\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8285, Train Acc: 0.7200 | Val Loss: 0.6048, Val Acc: 0.8100 | Test Loss: 0.5053, Test Acc: 0.8604\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 189.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 230.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8117, Train Acc: 0.7170 | Val Loss: 0.5425, Val Acc: 0.8400 | Test Loss: 0.4281, Test Acc: 0.8925\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6629, Train Acc: 0.7780 | Val Loss: 0.5548, Val Acc: 0.8300 | Test Loss: 0.4561, Test Acc: 0.8850\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0144, Train Acc: 0.6260 | Val Loss: 0.5283, Val Acc: 0.8300 | Test Loss: 0.4280, Test Acc: 0.8874\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8561, Train Acc: 0.6890 | Val Loss: 0.5960, Val Acc: 0.8000 | Test Loss: 0.4923, Test Acc: 0.8605\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 336.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6303, Train Acc: 0.7760 | Val Loss: 0.5373, Val Acc: 0.8400 | Test Loss: 0.4306, Test Acc: 0.8894\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5225, Train Acc: 0.8290 | Val Loss: 0.5398, Val Acc: 0.8500 | Test Loss: 0.4221, Test Acc: 0.8884\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 251.80it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 160.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7854, Train Acc: 0.7430 | Val Loss: 0.5185, Val Acc: 0.8400 | Test Loss: 0.4053, Test Acc: 0.8914\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6560, Train Acc: 0.7910 | Val Loss: 0.5495, Val Acc: 0.8500 | Test Loss: 0.4436, Test Acc: 0.8751\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 203.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6482, Train Acc: 0.7800 | Val Loss: 0.5032, Val Acc: 0.8500 | Test Loss: 0.3965, Test Acc: 0.8932\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5212, Train Acc: 0.8280 | Val Loss: 0.5128, Val Acc: 0.8400 | Test Loss: 0.4078, Test Acc: 0.8886\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 198.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8244, Train Acc: 0.7080 | Val Loss: 0.4992, Val Acc: 0.8300 | Test Loss: 0.3969, Test Acc: 0.8924\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6562, Train Acc: 0.7760 | Val Loss: 0.5413, Val Acc: 0.8200 | Test Loss: 0.4422, Test Acc: 0.8745\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 260.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5808, Train Acc: 0.8010 | Val Loss: 0.4942, Val Acc: 0.8500 | Test Loss: 0.3883, Test Acc: 0.8936\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4548, Train Acc: 0.8490 | Val Loss: 0.5103, Val Acc: 0.8300 | Test Loss: 0.4163, Test Acc: 0.8838\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 214.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 227.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7252, Train Acc: 0.7540 | Val Loss: 0.4842, Val Acc: 0.8400 | Test Loss: 0.3763, Test Acc: 0.8939\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5446, Train Acc: 0.8200 | Val Loss: 0.5294, Val Acc: 0.8400 | Test Loss: 0.4229, Test Acc: 0.8794\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6483, Train Acc: 0.7800 | Val Loss: 0.4736, Val Acc: 0.8500 | Test Loss: 0.3678, Test Acc: 0.8940\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4743, Train Acc: 0.8500 | Val Loss: 0.4900, Val Acc: 0.8300 | Test Loss: 0.4018, Test Acc: 0.8767\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 173.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7706, Train Acc: 0.7320 | Val Loss: 0.4686, Val Acc: 0.8500 | Test Loss: 0.3671, Test Acc: 0.8957\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5658, Train Acc: 0.8140 | Val Loss: 0.5454, Val Acc: 0.8500 | Test Loss: 0.4375, Test Acc: 0.8711\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 329.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 226.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5284, Train Acc: 0.8170 | Val Loss: 0.4719, Val Acc: 0.8300 | Test Loss: 0.3761, Test Acc: 0.8885\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3879, Train Acc: 0.8780 | Val Loss: 0.4746, Val Acc: 0.8300 | Test Loss: 0.3980, Test Acc: 0.8744\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5822, Train Acc: 0.7920 | Val Loss: 0.4820, Val Acc: 0.8500 | Test Loss: 0.3751, Test Acc: 0.8893\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4308, Train Acc: 0.8620 | Val Loss: 0.5565, Val Acc: 0.8600 | Test Loss: 0.4411, Test Acc: 0.8733\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 212.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5620, Train Acc: 0.8030 | Val Loss: 0.4917, Val Acc: 0.8600 | Test Loss: 0.3765, Test Acc: 0.8862\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3933, Train Acc: 0.8760 | Val Loss: 0.5035, Val Acc: 0.8400 | Test Loss: 0.4154, Test Acc: 0.8682\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 316.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6128, Train Acc: 0.7840 | Val Loss: 0.4762, Val Acc: 0.8500 | Test Loss: 0.3635, Test Acc: 0.8914\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4272, Train Acc: 0.8630 | Val Loss: 0.5404, Val Acc: 0.8500 | Test Loss: 0.4303, Test Acc: 0.8738\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.73it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 150.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5846, Train Acc: 0.7970 | Val Loss: 0.4944, Val Acc: 0.8300 | Test Loss: 0.3806, Test Acc: 0.8801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3873, Train Acc: 0.8640 | Val Loss: 0.5216, Val Acc: 0.8300 | Test Loss: 0.4193, Test Acc: 0.8586\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 258.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5689, Train Acc: 0.7860 | Val Loss: 0.4781, Val Acc: 0.8400 | Test Loss: 0.3555, Test Acc: 0.8937\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3728, Train Acc: 0.8820 | Val Loss: 0.5055, Val Acc: 0.8800 | Test Loss: 0.4112, Test Acc: 0.8730\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 222.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6068, Train Acc: 0.7870 | Val Loss: 0.4981, Val Acc: 0.8400 | Test Loss: 0.3928, Test Acc: 0.8723\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3840, Train Acc: 0.8760 | Val Loss: 0.5669, Val Acc: 0.8100 | Test Loss: 0.4649, Test Acc: 0.8332\n",
      "\n",
      "--- Outer Iteration 36/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 314.07it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 225.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6235, Train Acc: 0.7590 | Val Loss: 0.4764, Val Acc: 0.8700 | Test Loss: 0.3678, Test Acc: 0.8880\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3904, Train Acc: 0.8700 | Val Loss: 0.5187, Val Acc: 0.8800 | Test Loss: 0.4306, Test Acc: 0.8707\n",
      "\n",
      "--- Outer Iteration 37/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6582, Train Acc: 0.7600 | Val Loss: 0.4868, Val Acc: 0.8300 | Test Loss: 0.3787, Test Acc: 0.8786\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3710, Train Acc: 0.8860 | Val Loss: 0.5640, Val Acc: 0.8100 | Test Loss: 0.4582, Test Acc: 0.8352\n",
      "\n",
      "--- Outer Iteration 38/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 331.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6477, Train Acc: 0.7630 | Val Loss: 0.4840, Val Acc: 0.8500 | Test Loss: 0.3595, Test Acc: 0.8885\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3781, Train Acc: 0.8790 | Val Loss: 0.5218, Val Acc: 0.8700 | Test Loss: 0.4026, Test Acc: 0.8759\n",
      "\n",
      "--- Outer Iteration 39/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 279.32it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5767, Train Acc: 0.7920 | Val Loss: 0.4998, Val Acc: 0.8200 | Test Loss: 0.3723, Test Acc: 0.8790\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3528, Train Acc: 0.8770 | Val Loss: 0.5619, Val Acc: 0.8200 | Test Loss: 0.4097, Test Acc: 0.8525\n",
      "\n",
      "--- Outer Iteration 40/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 284.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 274.40it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5640, Train Acc: 0.7930 | Val Loss: 0.4856, Val Acc: 0.8300 | Test Loss: 0.3429, Test Acc: 0.8923\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3784, Train Acc: 0.8750 | Val Loss: 0.4935, Val Acc: 0.8800 | Test Loss: 0.3760, Test Acc: 0.8823\n",
      "\n",
      "--- Outer Iteration 41/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 184.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5778, Train Acc: 0.7810 | Val Loss: 0.4962, Val Acc: 0.8300 | Test Loss: 0.3649, Test Acc: 0.8821\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4006, Train Acc: 0.8740 | Val Loss: 0.5557, Val Acc: 0.8200 | Test Loss: 0.4164, Test Acc: 0.8526\n",
      "\n",
      "--- Outer Iteration 42/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 257.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5197, Train Acc: 0.8170 | Val Loss: 0.5166, Val Acc: 0.8700 | Test Loss: 0.3829, Test Acc: 0.8735\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3277, Train Acc: 0.9020 | Val Loss: 0.5543, Val Acc: 0.8900 | Test Loss: 0.4330, Test Acc: 0.8586\n",
      "\n",
      "--- Outer Iteration 43/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 292.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5479, Train Acc: 0.8030 | Val Loss: 0.4883, Val Acc: 0.8400 | Test Loss: 0.3776, Test Acc: 0.8751\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3454, Train Acc: 0.8860 | Val Loss: 0.5441, Val Acc: 0.8400 | Test Loss: 0.4272, Test Acc: 0.8536\n",
      "\n",
      "--- Outer Iteration 44/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5385, Train Acc: 0.8200 | Val Loss: 0.5086, Val Acc: 0.8300 | Test Loss: 0.3763, Test Acc: 0.8713\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3194, Train Acc: 0.9070 | Val Loss: 0.5691, Val Acc: 0.8700 | Test Loss: 0.4321, Test Acc: 0.8573\n",
      "\n",
      "--- Outer Iteration 45/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 261.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 366.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7342, Train Acc: 0.7240 | Val Loss: 0.5136, Val Acc: 0.8600 | Test Loss: 0.3692, Test Acc: 0.8775\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4528, Train Acc: 0.8440 | Val Loss: 0.5294, Val Acc: 0.8500 | Test Loss: 0.3749, Test Acc: 0.8760\n",
      "\n",
      "--- Outer Iteration 46/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 180.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5475, Train Acc: 0.8010 | Val Loss: 0.5301, Val Acc: 0.8300 | Test Loss: 0.3803, Test Acc: 0.8717\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3017, Train Acc: 0.9040 | Val Loss: 0.5784, Val Acc: 0.8100 | Test Loss: 0.4432, Test Acc: 0.8487\n",
      "\n",
      "--- Outer Iteration 47/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 370.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 207.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6920, Train Acc: 0.7480 | Val Loss: 0.5091, Val Acc: 0.8400 | Test Loss: 0.3790, Test Acc: 0.8698\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4076, Train Acc: 0.8520 | Val Loss: 0.5462, Val Acc: 0.8300 | Test Loss: 0.4039, Test Acc: 0.8618\n",
      "\n",
      "--- Outer Iteration 48/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 250.43it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 169.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4995, Train Acc: 0.8260 | Val Loss: 0.4886, Val Acc: 0.8500 | Test Loss: 0.3633, Test Acc: 0.8823\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3156, Train Acc: 0.8960 | Val Loss: 0.5284, Val Acc: 0.8300 | Test Loss: 0.4199, Test Acc: 0.8543\n",
      "\n",
      "--- Outer Iteration 49/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 291.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6854, Train Acc: 0.7440 | Val Loss: 0.5009, Val Acc: 0.8500 | Test Loss: 0.3767, Test Acc: 0.8738\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4137, Train Acc: 0.8540 | Val Loss: 0.5672, Val Acc: 0.8300 | Test Loss: 0.4191, Test Acc: 0.8513\n",
      "\n",
      "--- Outer Iteration 50/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 332.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 310.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7011, Train Acc: 0.7490 | Val Loss: 0.4901, Val Acc: 0.8600 | Test Loss: 0.3705, Test Acc: 0.8755\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3528, Train Acc: 0.8840 | Val Loss: 0.5543, Val Acc: 0.8300 | Test Loss: 0.4424, Test Acc: 0.8523\n",
      "\n",
      "--- Outer Iteration 51/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7128, Train Acc: 0.7310 | Val Loss: 0.4874, Val Acc: 0.8500 | Test Loss: 0.3628, Test Acc: 0.8842\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3893, Train Acc: 0.8630 | Val Loss: 0.5701, Val Acc: 0.8000 | Test Loss: 0.4376, Test Acc: 0.8527\n",
      "\n",
      "--- Outer Iteration 52/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 289.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 162.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5201, Train Acc: 0.8050 | Val Loss: 0.4558, Val Acc: 0.8800 | Test Loss: 0.3434, Test Acc: 0.8914\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2649, Train Acc: 0.9220 | Val Loss: 0.4926, Val Acc: 0.8600 | Test Loss: 0.3876, Test Acc: 0.8687\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.2, epsilon=1: Test Loss: 0.4330, Test Accuracy: 0.8586\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.2, epsilon=1: Test Loss: 0.3876, Test Accuracy: 0.8687\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.4, epsilon=0 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7074, Train Acc: 0.7810 | Val Loss: 1.8426, Val Acc: 0.6100 | Test Loss: 1.8325, Test Acc: 0.6548\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2883, Train Acc: 0.9030 | Val Loss: 2.1823, Val Acc: 0.6500 | Test Loss: 1.9577, Test Acc: 0.6428\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 234.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1687, Train Acc: 0.9430 | Val Loss: 2.1220, Val Acc: 0.6600 | Test Loss: 1.9130, Test Acc: 0.6475\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0885, Train Acc: 0.9810 | Val Loss: 2.0178, Val Acc: 0.6600 | Test Loss: 1.8734, Test Acc: 0.6515\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 343.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0607, Train Acc: 0.9910 | Val Loss: 2.0320, Val Acc: 0.6600 | Test Loss: 1.8863, Test Acc: 0.6519\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0527, Train Acc: 0.9880 | Val Loss: 2.0929, Val Acc: 0.6700 | Test Loss: 1.9171, Test Acc: 0.6472\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 192.74it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0389, Train Acc: 0.9960 | Val Loss: 2.1222, Val Acc: 0.6700 | Test Loss: 1.9585, Test Acc: 0.6453\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0408, Train Acc: 0.9950 | Val Loss: 2.1050, Val Acc: 0.6700 | Test Loss: 1.9583, Test Acc: 0.6477\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 169.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0259, Train Acc: 0.9970 | Val Loss: 2.1068, Val Acc: 0.6500 | Test Loss: 1.9562, Test Acc: 0.6486\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0211, Train Acc: 0.9990 | Val Loss: 2.1379, Val Acc: 0.6600 | Test Loss: 1.9809, Test Acc: 0.6515\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 244.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 307.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0297, Train Acc: 0.9970 | Val Loss: 2.2016, Val Acc: 0.6700 | Test Loss: 2.0442, Test Acc: 0.6487\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0197, Train Acc: 0.9980 | Val Loss: 2.2494, Val Acc: 0.6500 | Test Loss: 2.1030, Test Acc: 0.6438\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0161, Train Acc: 1.0000 | Val Loss: 2.2547, Val Acc: 0.6500 | Test Loss: 2.1014, Test Acc: 0.6428\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0120, Train Acc: 1.0000 | Val Loss: 2.2331, Val Acc: 0.6600 | Test Loss: 2.0824, Test Acc: 0.6481\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0130, Train Acc: 0.9990 | Val Loss: 2.2304, Val Acc: 0.6600 | Test Loss: 2.0836, Test Acc: 0.6506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0140, Train Acc: 0.9990 | Val Loss: 2.2585, Val Acc: 0.6500 | Test Loss: 2.1075, Test Acc: 0.6512\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0253, Train Acc: 0.9980 | Val Loss: 2.2082, Val Acc: 0.6500 | Test Loss: 2.0591, Test Acc: 0.6548\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0214, Train Acc: 0.9950 | Val Loss: 2.2028, Val Acc: 0.6500 | Test Loss: 2.0516, Test Acc: 0.6526\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.23it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 184.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0449, Train Acc: 0.9940 | Val Loss: 2.2386, Val Acc: 0.6400 | Test Loss: 2.1277, Test Acc: 0.6488\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0224, Train Acc: 0.9920 | Val Loss: 2.2860, Val Acc: 0.6400 | Test Loss: 2.0990, Test Acc: 0.6480\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 184.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0306, Train Acc: 0.9930 | Val Loss: 2.4106, Val Acc: 0.6300 | Test Loss: 2.1714, Test Acc: 0.6450\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0284, Train Acc: 0.9890 | Val Loss: 2.4250, Val Acc: 0.6500 | Test Loss: 2.2209, Test Acc: 0.6402\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.79it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0180, Train Acc: 0.9970 | Val Loss: 2.4460, Val Acc: 0.6500 | Test Loss: 2.2278, Test Acc: 0.6409\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0136, Train Acc: 0.9970 | Val Loss: 2.3713, Val Acc: 0.6600 | Test Loss: 2.1201, Test Acc: 0.6502\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 363.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0126, Train Acc: 0.9990 | Val Loss: 2.3760, Val Acc: 0.6200 | Test Loss: 2.1766, Test Acc: 0.6462\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0082, Train Acc: 0.9990 | Val Loss: 2.3925, Val Acc: 0.6200 | Test Loss: 2.2220, Test Acc: 0.6424\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.4, epsilon=0: Test Loss: 1.9171, Test Accuracy: 0.6472\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.4, epsilon=0: Test Loss: 2.2220, Test Accuracy: 0.6424\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.4, epsilon=0.2 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 173.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.0893, Train Acc: 0.3790 | Val Loss: 0.9399, Val Acc: 0.7900 | Test Loss: 0.8649, Test Acc: 0.7794\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8515, Train Acc: 0.6010 | Val Loss: 0.9183, Val Acc: 0.8100 | Test Loss: 0.7243, Test Acc: 0.8191\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4591, Train Acc: 0.5370 | Val Loss: 0.9274, Val Acc: 0.8100 | Test Loss: 0.6287, Test Acc: 0.8455\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5641, Train Acc: 0.6330 | Val Loss: 1.0227, Val Acc: 0.7900 | Test Loss: 0.6890, Test Acc: 0.8449\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3286, Train Acc: 0.6790 | Val Loss: 0.9091, Val Acc: 0.8400 | Test Loss: 0.5545, Test Acc: 0.8615\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0002, Train Acc: 0.7370 | Val Loss: 0.8038, Val Acc: 0.8500 | Test Loss: 0.4699, Test Acc: 0.8710\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 282.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7821, Train Acc: 0.7670 | Val Loss: 0.7482, Val Acc: 0.8500 | Test Loss: 0.4310, Test Acc: 0.8789\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6275, Train Acc: 0.7980 | Val Loss: 0.7208, Val Acc: 0.8500 | Test Loss: 0.4489, Test Acc: 0.8781\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 153.68it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4999, Train Acc: 0.8400 | Val Loss: 0.6913, Val Acc: 0.8400 | Test Loss: 0.4307, Test Acc: 0.8813\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4182, Train Acc: 0.8630 | Val Loss: 0.6752, Val Acc: 0.8400 | Test Loss: 0.4081, Test Acc: 0.8822\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3292, Train Acc: 0.9030 | Val Loss: 0.6791, Val Acc: 0.8400 | Test Loss: 0.4073, Test Acc: 0.8846\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2928, Train Acc: 0.9130 | Val Loss: 0.6742, Val Acc: 0.8400 | Test Loss: 0.4118, Test Acc: 0.8871\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 266.86it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2387, Train Acc: 0.9290 | Val Loss: 0.6529, Val Acc: 0.8500 | Test Loss: 0.3965, Test Acc: 0.8910\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2209, Train Acc: 0.9420 | Val Loss: 0.6369, Val Acc: 0.8500 | Test Loss: 0.3864, Test Acc: 0.8919\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 257.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1932, Train Acc: 0.9490 | Val Loss: 0.6604, Val Acc: 0.8400 | Test Loss: 0.4032, Test Acc: 0.8884\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1665, Train Acc: 0.9610 | Val Loss: 0.6794, Val Acc: 0.8400 | Test Loss: 0.4289, Test Acc: 0.8843\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1565, Train Acc: 0.9580 | Val Loss: 0.6516, Val Acc: 0.8400 | Test Loss: 0.4062, Test Acc: 0.8913\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1415, Train Acc: 0.9620 | Val Loss: 0.6364, Val Acc: 0.8400 | Test Loss: 0.3895, Test Acc: 0.8943\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 156.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 226.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1363, Train Acc: 0.9600 | Val Loss: 0.6446, Val Acc: 0.8400 | Test Loss: 0.4056, Test Acc: 0.8923\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1089, Train Acc: 0.9780 | Val Loss: 0.6655, Val Acc: 0.8400 | Test Loss: 0.4301, Test Acc: 0.8879\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 229.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1026, Train Acc: 0.9800 | Val Loss: 0.6705, Val Acc: 0.8400 | Test Loss: 0.4256, Test Acc: 0.8883\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1017, Train Acc: 0.9780 | Val Loss: 0.6665, Val Acc: 0.8400 | Test Loss: 0.4140, Test Acc: 0.8898\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 189.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0902, Train Acc: 0.9780 | Val Loss: 0.6627, Val Acc: 0.8400 | Test Loss: 0.4148, Test Acc: 0.8902\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0744, Train Acc: 0.9880 | Val Loss: 0.6714, Val Acc: 0.8400 | Test Loss: 0.4306, Test Acc: 0.8925\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 239.39it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 210.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0738, Train Acc: 0.9880 | Val Loss: 0.6715, Val Acc: 0.8400 | Test Loss: 0.4267, Test Acc: 0.8923\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0691, Train Acc: 0.9890 | Val Loss: 0.6700, Val Acc: 0.8400 | Test Loss: 0.4063, Test Acc: 0.8935\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.4, epsilon=0.2: Test Loss: 0.4699, Test Accuracy: 0.8710\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.4, epsilon=0.2: Test Loss: 0.4063, Test Accuracy: 0.8935\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.4, epsilon=0.4 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 328.64it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 6.6912, Train Acc: 0.2640 | Val Loss: 1.1143, Val Acc: 0.7200 | Test Loss: 1.0197, Test Acc: 0.7167\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2549, Train Acc: 0.3330 | Val Loss: 1.0072, Val Acc: 0.7700 | Test Loss: 0.9232, Test Acc: 0.7387\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 299.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.5198, Train Acc: 0.3070 | Val Loss: 0.9969, Val Acc: 0.7400 | Test Loss: 0.8391, Test Acc: 0.7828\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.0958, Train Acc: 0.4030 | Val Loss: 1.2523, Val Acc: 0.7100 | Test Loss: 1.0763, Test Acc: 0.7685\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 209.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4558, Train Acc: 0.4830 | Val Loss: 0.9593, Val Acc: 0.7300 | Test Loss: 0.8044, Test Acc: 0.8036\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9605, Train Acc: 0.5450 | Val Loss: 0.8454, Val Acc: 0.7800 | Test Loss: 0.6790, Test Acc: 0.8221\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 333.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4674, Train Acc: 0.5710 | Val Loss: 0.8355, Val Acc: 0.8000 | Test Loss: 0.6491, Test Acc: 0.8384\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2415, Train Acc: 0.6170 | Val Loss: 0.8252, Val Acc: 0.8000 | Test Loss: 0.6381, Test Acc: 0.8450\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.71it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 211.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1458, Train Acc: 0.6540 | Val Loss: 0.7380, Val Acc: 0.8200 | Test Loss: 0.5511, Test Acc: 0.8573\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0091, Train Acc: 0.6830 | Val Loss: 0.6621, Val Acc: 0.8500 | Test Loss: 0.4903, Test Acc: 0.8656\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 296.63it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8902, Train Acc: 0.7130 | Val Loss: 0.6487, Val Acc: 0.8500 | Test Loss: 0.4847, Test Acc: 0.8683\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8073, Train Acc: 0.7220 | Val Loss: 0.6230, Val Acc: 0.8500 | Test Loss: 0.4646, Test Acc: 0.8757\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 326.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7228, Train Acc: 0.7650 | Val Loss: 0.6015, Val Acc: 0.8500 | Test Loss: 0.4323, Test Acc: 0.8821\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6583, Train Acc: 0.7840 | Val Loss: 0.5884, Val Acc: 0.8600 | Test Loss: 0.4115, Test Acc: 0.8831\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.17it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6191, Train Acc: 0.7980 | Val Loss: 0.5911, Val Acc: 0.8500 | Test Loss: 0.4053, Test Acc: 0.8855\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5453, Train Acc: 0.8190 | Val Loss: 0.5940, Val Acc: 0.8600 | Test Loss: 0.4236, Test Acc: 0.8845\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 219.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5477, Train Acc: 0.8210 | Val Loss: 0.5672, Val Acc: 0.8600 | Test Loss: 0.3724, Test Acc: 0.8923\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4918, Train Acc: 0.8400 | Val Loss: 0.5578, Val Acc: 0.8600 | Test Loss: 0.3611, Test Acc: 0.8926\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 266.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5113, Train Acc: 0.8360 | Val Loss: 0.5683, Val Acc: 0.8600 | Test Loss: 0.3587, Test Acc: 0.8969\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4427, Train Acc: 0.8530 | Val Loss: 0.5841, Val Acc: 0.8600 | Test Loss: 0.3885, Test Acc: 0.8955\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.23it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4432, Train Acc: 0.8550 | Val Loss: 0.5411, Val Acc: 0.8600 | Test Loss: 0.3440, Test Acc: 0.9005\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3758, Train Acc: 0.8790 | Val Loss: 0.5261, Val Acc: 0.8500 | Test Loss: 0.3380, Test Acc: 0.8982\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.87it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 308.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4175, Train Acc: 0.8550 | Val Loss: 0.5400, Val Acc: 0.8600 | Test Loss: 0.3409, Test Acc: 0.9002\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3432, Train Acc: 0.8880 | Val Loss: 0.5836, Val Acc: 0.8600 | Test Loss: 0.3785, Test Acc: 0.8983\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.40it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3586, Train Acc: 0.8830 | Val Loss: 0.5493, Val Acc: 0.8600 | Test Loss: 0.3455, Test Acc: 0.9025\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3001, Train Acc: 0.9120 | Val Loss: 0.5298, Val Acc: 0.8500 | Test Loss: 0.3272, Test Acc: 0.9030\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.24it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 252.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2944, Train Acc: 0.9090 | Val Loss: 0.5400, Val Acc: 0.8600 | Test Loss: 0.3378, Test Acc: 0.9028\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2758, Train Acc: 0.9260 | Val Loss: 0.5568, Val Acc: 0.8600 | Test Loss: 0.3601, Test Acc: 0.9013\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.49it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 319.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2935, Train Acc: 0.9040 | Val Loss: 0.5461, Val Acc: 0.8500 | Test Loss: 0.3339, Test Acc: 0.9047\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2404, Train Acc: 0.9380 | Val Loss: 0.5421, Val Acc: 0.8500 | Test Loss: 0.3182, Test Acc: 0.9061\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.42it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2423, Train Acc: 0.9310 | Val Loss: 0.5502, Val Acc: 0.8600 | Test Loss: 0.3168, Test Acc: 0.9083\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2103, Train Acc: 0.9520 | Val Loss: 0.5539, Val Acc: 0.8600 | Test Loss: 0.3296, Test Acc: 0.9071\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 295.73it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2137, Train Acc: 0.9420 | Val Loss: 0.5374, Val Acc: 0.8600 | Test Loss: 0.3163, Test Acc: 0.9103\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1917, Train Acc: 0.9520 | Val Loss: 0.5432, Val Acc: 0.8500 | Test Loss: 0.3147, Test Acc: 0.9097\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.4, epsilon=0.4: Test Loss: 0.4115, Test Accuracy: 0.8831\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.4, epsilon=0.4: Test Loss: 0.3147, Test Accuracy: 0.9097\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.4, epsilon=0.6 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 255.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.4976, Train Acc: 0.2470 | Val Loss: 1.1939, Val Acc: 0.6800 | Test Loss: 1.1430, Test Acc: 0.6504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.3474, Train Acc: 0.2860 | Val Loss: 1.2776, Val Acc: 0.6100 | Test Loss: 1.1752, Test Acc: 0.6312\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.1764, Train Acc: 0.2240 | Val Loss: 1.1066, Val Acc: 0.7200 | Test Loss: 1.0008, Test Acc: 0.7197\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.7613, Train Acc: 0.3070 | Val Loss: 1.2743, Val Acc: 0.6900 | Test Loss: 1.2145, Test Acc: 0.7143\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 258.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.1270, Train Acc: 0.3790 | Val Loss: 1.0285, Val Acc: 0.7000 | Test Loss: 0.9648, Test Acc: 0.7358\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.5113, Train Acc: 0.4370 | Val Loss: 0.9219, Val Acc: 0.7400 | Test Loss: 0.8648, Test Acc: 0.7567\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 368.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.9648, Train Acc: 0.4540 | Val Loss: 0.9290, Val Acc: 0.7600 | Test Loss: 0.8352, Test Acc: 0.7780\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6768, Train Acc: 0.5110 | Val Loss: 0.9667, Val Acc: 0.7600 | Test Loss: 0.8542, Test Acc: 0.7890\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 188.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6630, Train Acc: 0.5340 | Val Loss: 0.7644, Val Acc: 0.7800 | Test Loss: 0.6698, Test Acc: 0.8160\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4347, Train Acc: 0.5930 | Val Loss: 0.7008, Val Acc: 0.8000 | Test Loss: 0.6114, Test Acc: 0.8237\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 263.65it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3573, Train Acc: 0.5630 | Val Loss: 0.7103, Val Acc: 0.7700 | Test Loss: 0.6045, Test Acc: 0.8335\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2082, Train Acc: 0.6000 | Val Loss: 0.7636, Val Acc: 0.7800 | Test Loss: 0.6419, Test Acc: 0.8298\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 188.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0936, Train Acc: 0.6410 | Val Loss: 0.6406, Val Acc: 0.8400 | Test Loss: 0.5326, Test Acc: 0.8533\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9938, Train Acc: 0.6830 | Val Loss: 0.6000, Val Acc: 0.8400 | Test Loss: 0.4757, Test Acc: 0.8698\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 274.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0020, Train Acc: 0.6260 | Val Loss: 0.5950, Val Acc: 0.8400 | Test Loss: 0.4692, Test Acc: 0.8676\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8941, Train Acc: 0.6690 | Val Loss: 0.6171, Val Acc: 0.8300 | Test Loss: 0.4911, Test Acc: 0.8607\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 359.14it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8136, Train Acc: 0.7300 | Val Loss: 0.5762, Val Acc: 0.8400 | Test Loss: 0.4536, Test Acc: 0.8734\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7536, Train Acc: 0.7550 | Val Loss: 0.5472, Val Acc: 0.8400 | Test Loss: 0.4207, Test Acc: 0.8841\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.86it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7681, Train Acc: 0.7140 | Val Loss: 0.5348, Val Acc: 0.8500 | Test Loss: 0.4036, Test Acc: 0.8866\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7075, Train Acc: 0.7440 | Val Loss: 0.5391, Val Acc: 0.8500 | Test Loss: 0.4051, Test Acc: 0.8818\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6770, Train Acc: 0.7560 | Val Loss: 0.5261, Val Acc: 0.8500 | Test Loss: 0.3897, Test Acc: 0.8882\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6180, Train Acc: 0.7910 | Val Loss: 0.5157, Val Acc: 0.8400 | Test Loss: 0.3866, Test Acc: 0.8897\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 353.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6739, Train Acc: 0.7730 | Val Loss: 0.4906, Val Acc: 0.8500 | Test Loss: 0.3567, Test Acc: 0.8934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6083, Train Acc: 0.7830 | Val Loss: 0.5019, Val Acc: 0.8700 | Test Loss: 0.3701, Test Acc: 0.8874\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 187.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6371, Train Acc: 0.7690 | Val Loss: 0.5013, Val Acc: 0.8600 | Test Loss: 0.3589, Test Acc: 0.8967\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5476, Train Acc: 0.8210 | Val Loss: 0.5004, Val Acc: 0.8700 | Test Loss: 0.3703, Test Acc: 0.8988\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 369.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6133, Train Acc: 0.7890 | Val Loss: 0.4770, Val Acc: 0.8500 | Test Loss: 0.3281, Test Acc: 0.9030\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5210, Train Acc: 0.8230 | Val Loss: 0.4853, Val Acc: 0.8500 | Test Loss: 0.3459, Test Acc: 0.8923\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 330.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 213.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5510, Train Acc: 0.8090 | Val Loss: 0.4825, Val Acc: 0.8600 | Test Loss: 0.3285, Test Acc: 0.9024\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4636, Train Acc: 0.8480 | Val Loss: 0.4883, Val Acc: 0.8700 | Test Loss: 0.3444, Test Acc: 0.9022\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 262.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5302, Train Acc: 0.8260 | Val Loss: 0.4589, Val Acc: 0.8600 | Test Loss: 0.3088, Test Acc: 0.9073\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4606, Train Acc: 0.8480 | Val Loss: 0.4591, Val Acc: 0.8500 | Test Loss: 0.3228, Test Acc: 0.9005\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 220.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4813, Train Acc: 0.8220 | Val Loss: 0.4543, Val Acc: 0.8700 | Test Loss: 0.3039, Test Acc: 0.9080\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4241, Train Acc: 0.8580 | Val Loss: 0.4867, Val Acc: 0.8600 | Test Loss: 0.3415, Test Acc: 0.9014\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4499, Train Acc: 0.8430 | Val Loss: 0.4388, Val Acc: 0.8600 | Test Loss: 0.2971, Test Acc: 0.9070\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3769, Train Acc: 0.8710 | Val Loss: 0.4537, Val Acc: 0.8500 | Test Loss: 0.3131, Test Acc: 0.9029\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 323.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4583, Train Acc: 0.8270 | Val Loss: 0.4445, Val Acc: 0.8700 | Test Loss: 0.2877, Test Acc: 0.9136\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3654, Train Acc: 0.8670 | Val Loss: 0.4808, Val Acc: 0.8600 | Test Loss: 0.3284, Test Acc: 0.9048\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 294.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4331, Train Acc: 0.8610 | Val Loss: 0.4449, Val Acc: 0.8600 | Test Loss: 0.2872, Test Acc: 0.9116\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3564, Train Acc: 0.8880 | Val Loss: 0.4538, Val Acc: 0.8500 | Test Loss: 0.3160, Test Acc: 0.9028\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4128, Train Acc: 0.8470 | Val Loss: 0.4304, Val Acc: 0.8700 | Test Loss: 0.2757, Test Acc: 0.9153\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3256, Train Acc: 0.8950 | Val Loss: 0.4455, Val Acc: 0.8700 | Test Loss: 0.3036, Test Acc: 0.9111\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 212.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4085, Train Acc: 0.8540 | Val Loss: 0.4261, Val Acc: 0.8800 | Test Loss: 0.2839, Test Acc: 0.9118\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3139, Train Acc: 0.8910 | Val Loss: 0.4315, Val Acc: 0.8500 | Test Loss: 0.2998, Test Acc: 0.9081\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 252.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 145.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3496, Train Acc: 0.8740 | Val Loss: 0.4335, Val Acc: 0.8500 | Test Loss: 0.2751, Test Acc: 0.9127\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2856, Train Acc: 0.9090 | Val Loss: 0.4540, Val Acc: 0.8700 | Test Loss: 0.2903, Test Acc: 0.9113\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 293.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 208.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3002, Train Acc: 0.8950 | Val Loss: 0.4154, Val Acc: 0.8800 | Test Loss: 0.2675, Test Acc: 0.9166\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2490, Train Acc: 0.9260 | Val Loss: 0.4288, Val Acc: 0.8700 | Test Loss: 0.2788, Test Acc: 0.9142\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 148.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 218.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3129, Train Acc: 0.8930 | Val Loss: 0.4381, Val Acc: 0.8900 | Test Loss: 0.2650, Test Acc: 0.9184\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2728, Train Acc: 0.9200 | Val Loss: 0.4686, Val Acc: 0.8600 | Test Loss: 0.2815, Test Acc: 0.9136\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2932, Train Acc: 0.9010 | Val Loss: 0.4332, Val Acc: 0.8600 | Test Loss: 0.2667, Test Acc: 0.9150\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2356, Train Acc: 0.9250 | Val Loss: 0.4637, Val Acc: 0.8500 | Test Loss: 0.2913, Test Acc: 0.9099\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 223.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3165, Train Acc: 0.8990 | Val Loss: 0.4457, Val Acc: 0.8600 | Test Loss: 0.2634, Test Acc: 0.9156\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2350, Train Acc: 0.9170 | Val Loss: 0.4552, Val Acc: 0.8600 | Test Loss: 0.2741, Test Acc: 0.9140\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3169, Train Acc: 0.8870 | Val Loss: 0.4184, Val Acc: 0.8600 | Test Loss: 0.2655, Test Acc: 0.9160\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2249, Train Acc: 0.9340 | Val Loss: 0.4366, Val Acc: 0.8700 | Test Loss: 0.3048, Test Acc: 0.9070\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 164.54it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3797, Train Acc: 0.8660 | Val Loss: 0.4320, Val Acc: 0.8600 | Test Loss: 0.2649, Test Acc: 0.9160\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2499, Train Acc: 0.9220 | Val Loss: 0.4717, Val Acc: 0.8500 | Test Loss: 0.2827, Test Acc: 0.9072\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 149.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 154.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3561, Train Acc: 0.8770 | Val Loss: 0.4231, Val Acc: 0.8700 | Test Loss: 0.2555, Test Acc: 0.9189\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2094, Train Acc: 0.9320 | Val Loss: 0.4354, Val Acc: 0.8800 | Test Loss: 0.2964, Test Acc: 0.9119\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.77it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3447, Train Acc: 0.8800 | Val Loss: 0.4157, Val Acc: 0.8600 | Test Loss: 0.2499, Test Acc: 0.9218\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2023, Train Acc: 0.9360 | Val Loss: 0.4488, Val Acc: 0.8400 | Test Loss: 0.2809, Test Acc: 0.9064\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 333.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 236.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3609, Train Acc: 0.8630 | Val Loss: 0.4369, Val Acc: 0.8600 | Test Loss: 0.2597, Test Acc: 0.9201\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2139, Train Acc: 0.9300 | Val Loss: 0.4720, Val Acc: 0.8800 | Test Loss: 0.2991, Test Acc: 0.9154\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.17it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3075, Train Acc: 0.8820 | Val Loss: 0.4318, Val Acc: 0.8700 | Test Loss: 0.2644, Test Acc: 0.9183\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2077, Train Acc: 0.9360 | Val Loss: 0.4377, Val Acc: 0.8600 | Test Loss: 0.2762, Test Acc: 0.9096\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.87it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 188.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2645, Train Acc: 0.9040 | Val Loss: 0.4065, Val Acc: 0.8700 | Test Loss: 0.2477, Test Acc: 0.9214\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1826, Train Acc: 0.9470 | Val Loss: 0.4018, Val Acc: 0.8800 | Test Loss: 0.2573, Test Acc: 0.9242\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 251.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2246, Train Acc: 0.9260 | Val Loss: 0.4195, Val Acc: 0.8600 | Test Loss: 0.2500, Test Acc: 0.9226\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.4, epsilon=0.6: Test Loss: 0.2650, Test Accuracy: 0.9184\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.4, epsilon=0.6: Test Loss: 0.2500, Test Accuracy: 0.9226\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.4, epsilon=0.8 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 257.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.9613, Train Acc: 0.2460 | Val Loss: 1.2603, Val Acc: 0.6400 | Test Loss: 1.1921, Test Acc: 0.6254\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.8750, Train Acc: 0.2680 | Val Loss: 1.3984, Val Acc: 0.5200 | Test Loss: 1.2705, Test Acc: 0.5845\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.4655, Train Acc: 0.2080 | Val Loss: 1.1381, Val Acc: 0.6500 | Test Loss: 1.0526, Test Acc: 0.6897\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.0623, Train Acc: 0.2780 | Val Loss: 1.3229, Val Acc: 0.6600 | Test Loss: 1.2811, Test Acc: 0.6813\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 380.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.4323, Train Acc: 0.3360 | Val Loss: 1.0834, Val Acc: 0.6600 | Test Loss: 1.0610, Test Acc: 0.6752\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.7548, Train Acc: 0.3930 | Val Loss: 1.0920, Val Acc: 0.6700 | Test Loss: 1.0668, Test Acc: 0.6691\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 325.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 172.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.3009, Train Acc: 0.3620 | Val Loss: 1.0649, Val Acc: 0.7200 | Test Loss: 0.9952, Test Acc: 0.7393\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9143, Train Acc: 0.4330 | Val Loss: 1.1564, Val Acc: 0.7100 | Test Loss: 1.0667, Test Acc: 0.7356\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.2284, Train Acc: 0.4640 | Val Loss: 0.8722, Val Acc: 0.7500 | Test Loss: 0.8164, Test Acc: 0.7580\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8284, Train Acc: 0.5390 | Val Loss: 0.9062, Val Acc: 0.7100 | Test Loss: 0.8328, Test Acc: 0.7392\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7710, Train Acc: 0.4420 | Val Loss: 0.7791, Val Acc: 0.7600 | Test Loss: 0.7166, Test Acc: 0.8054\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5438, Train Acc: 0.5070 | Val Loss: 0.8608, Val Acc: 0.7600 | Test Loss: 0.7741, Test Acc: 0.7958\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 231.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4546, Train Acc: 0.5850 | Val Loss: 0.7084, Val Acc: 0.8100 | Test Loss: 0.6126, Test Acc: 0.8289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2576, Train Acc: 0.6330 | Val Loss: 0.7162, Val Acc: 0.7800 | Test Loss: 0.5978, Test Acc: 0.8240\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 158.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3664, Train Acc: 0.5200 | Val Loss: 0.6400, Val Acc: 0.8200 | Test Loss: 0.5276, Test Acc: 0.8561\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2212, Train Acc: 0.5760 | Val Loss: 0.6798, Val Acc: 0.7800 | Test Loss: 0.5637, Test Acc: 0.8398\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.52it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1595, Train Acc: 0.6260 | Val Loss: 0.5955, Val Acc: 0.8300 | Test Loss: 0.4868, Test Acc: 0.8718\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0315, Train Acc: 0.6680 | Val Loss: 0.6015, Val Acc: 0.8100 | Test Loss: 0.4948, Test Acc: 0.8652\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 280.23it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1896, Train Acc: 0.5700 | Val Loss: 0.5598, Val Acc: 0.8300 | Test Loss: 0.4519, Test Acc: 0.8787\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0668, Train Acc: 0.6270 | Val Loss: 0.5964, Val Acc: 0.8100 | Test Loss: 0.4857, Test Acc: 0.8617\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 239.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9746, Train Acc: 0.6670 | Val Loss: 0.5492, Val Acc: 0.8300 | Test Loss: 0.4405, Test Acc: 0.8819\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8879, Train Acc: 0.7030 | Val Loss: 0.5541, Val Acc: 0.8300 | Test Loss: 0.4444, Test Acc: 0.8774\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9744, Train Acc: 0.6560 | Val Loss: 0.5244, Val Acc: 0.8300 | Test Loss: 0.4162, Test Acc: 0.8868\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8715, Train Acc: 0.7060 | Val Loss: 0.5496, Val Acc: 0.8300 | Test Loss: 0.4447, Test Acc: 0.8713\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8487, Train Acc: 0.7040 | Val Loss: 0.5026, Val Acc: 0.8400 | Test Loss: 0.3966, Test Acc: 0.8932\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7670, Train Acc: 0.7350 | Val Loss: 0.5197, Val Acc: 0.8300 | Test Loss: 0.4147, Test Acc: 0.8765\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.80it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 347.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9263, Train Acc: 0.6600 | Val Loss: 0.5030, Val Acc: 0.8300 | Test Loss: 0.3879, Test Acc: 0.8919\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7990, Train Acc: 0.7070 | Val Loss: 0.5426, Val Acc: 0.8300 | Test Loss: 0.4373, Test Acc: 0.8707\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 238.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 212.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7918, Train Acc: 0.7260 | Val Loss: 0.4857, Val Acc: 0.8400 | Test Loss: 0.3800, Test Acc: 0.8956\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6820, Train Acc: 0.7710 | Val Loss: 0.5047, Val Acc: 0.8200 | Test Loss: 0.4075, Test Acc: 0.8758\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8052, Train Acc: 0.7090 | Val Loss: 0.4721, Val Acc: 0.8500 | Test Loss: 0.3614, Test Acc: 0.8991\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7072, Train Acc: 0.7580 | Val Loss: 0.5146, Val Acc: 0.8400 | Test Loss: 0.4100, Test Acc: 0.8818\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 210.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7071, Train Acc: 0.7300 | Val Loss: 0.4598, Val Acc: 0.8600 | Test Loss: 0.3530, Test Acc: 0.9000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5992, Train Acc: 0.7920 | Val Loss: 0.4728, Val Acc: 0.8400 | Test Loss: 0.3783, Test Acc: 0.8830\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 240.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7604, Train Acc: 0.7300 | Val Loss: 0.4619, Val Acc: 0.8600 | Test Loss: 0.3498, Test Acc: 0.9014\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6095, Train Acc: 0.7800 | Val Loss: 0.4871, Val Acc: 0.8600 | Test Loss: 0.3758, Test Acc: 0.8920\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 149.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 223.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6307, Train Acc: 0.7880 | Val Loss: 0.4428, Val Acc: 0.8600 | Test Loss: 0.3302, Test Acc: 0.9067\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5056, Train Acc: 0.8250 | Val Loss: 0.4525, Val Acc: 0.8500 | Test Loss: 0.3590, Test Acc: 0.8871\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 338.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6132, Train Acc: 0.7750 | Val Loss: 0.4510, Val Acc: 0.8600 | Test Loss: 0.3364, Test Acc: 0.9039\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5041, Train Acc: 0.8230 | Val Loss: 0.4730, Val Acc: 0.8600 | Test Loss: 0.3621, Test Acc: 0.8967\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.81it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 353.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5607, Train Acc: 0.7910 | Val Loss: 0.4202, Val Acc: 0.8600 | Test Loss: 0.3000, Test Acc: 0.9137\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4605, Train Acc: 0.8350 | Val Loss: 0.4378, Val Acc: 0.8500 | Test Loss: 0.3193, Test Acc: 0.9003\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 296.43it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5781, Train Acc: 0.7870 | Val Loss: 0.4301, Val Acc: 0.8500 | Test Loss: 0.3077, Test Acc: 0.9103\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4747, Train Acc: 0.8200 | Val Loss: 0.4582, Val Acc: 0.8600 | Test Loss: 0.3477, Test Acc: 0.9015\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 253.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4983, Train Acc: 0.8350 | Val Loss: 0.4276, Val Acc: 0.8600 | Test Loss: 0.3004, Test Acc: 0.9110\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4020, Train Acc: 0.8550 | Val Loss: 0.4440, Val Acc: 0.8600 | Test Loss: 0.3382, Test Acc: 0.8924\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5806, Train Acc: 0.7720 | Val Loss: 0.4301, Val Acc: 0.8500 | Test Loss: 0.2992, Test Acc: 0.9128\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4588, Train Acc: 0.8270 | Val Loss: 0.4554, Val Acc: 0.8400 | Test Loss: 0.3348, Test Acc: 0.9045\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 174.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 254.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5102, Train Acc: 0.8170 | Val Loss: 0.4073, Val Acc: 0.8700 | Test Loss: 0.2961, Test Acc: 0.9118\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3997, Train Acc: 0.8780 | Val Loss: 0.4423, Val Acc: 0.8600 | Test Loss: 0.3567, Test Acc: 0.8852\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 211.31it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5655, Train Acc: 0.7810 | Val Loss: 0.4520, Val Acc: 0.8400 | Test Loss: 0.3224, Test Acc: 0.9036\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4273, Train Acc: 0.8550 | Val Loss: 0.5208, Val Acc: 0.8300 | Test Loss: 0.3619, Test Acc: 0.8943\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 210.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5244, Train Acc: 0.8110 | Val Loss: 0.4242, Val Acc: 0.8500 | Test Loss: 0.2951, Test Acc: 0.9113\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3548, Train Acc: 0.8970 | Val Loss: 0.5010, Val Acc: 0.8500 | Test Loss: 0.3760, Test Acc: 0.8802\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 276.37it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5805, Train Acc: 0.7890 | Val Loss: 0.4488, Val Acc: 0.8500 | Test Loss: 0.3091, Test Acc: 0.9075\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4198, Train Acc: 0.8660 | Val Loss: 0.5296, Val Acc: 0.8300 | Test Loss: 0.3619, Test Acc: 0.8927\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 217.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 395.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5119, Train Acc: 0.8110 | Val Loss: 0.4216, Val Acc: 0.8500 | Test Loss: 0.2968, Test Acc: 0.9104\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3495, Train Acc: 0.8760 | Val Loss: 0.4837, Val Acc: 0.8700 | Test Loss: 0.3607, Test Acc: 0.8865\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5145, Train Acc: 0.7980 | Val Loss: 0.4594, Val Acc: 0.8400 | Test Loss: 0.3032, Test Acc: 0.9072\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3785, Train Acc: 0.8600 | Val Loss: 0.5107, Val Acc: 0.8200 | Test Loss: 0.3350, Test Acc: 0.8965\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 227.44it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 155.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4549, Train Acc: 0.8330 | Val Loss: 0.4113, Val Acc: 0.8600 | Test Loss: 0.2862, Test Acc: 0.9104\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3474, Train Acc: 0.8880 | Val Loss: 0.4320, Val Acc: 0.8600 | Test Loss: 0.3681, Test Acc: 0.8812\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 289.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4843, Train Acc: 0.8000 | Val Loss: 0.4454, Val Acc: 0.8400 | Test Loss: 0.3275, Test Acc: 0.9014\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3452, Train Acc: 0.8820 | Val Loss: 0.5071, Val Acc: 0.8300 | Test Loss: 0.3732, Test Acc: 0.8930\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 231.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4598, Train Acc: 0.8250 | Val Loss: 0.3978, Val Acc: 0.8600 | Test Loss: 0.2863, Test Acc: 0.9116\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3117, Train Acc: 0.9020 | Val Loss: 0.4203, Val Acc: 0.8500 | Test Loss: 0.3504, Test Acc: 0.8892\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.89it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 170.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4749, Train Acc: 0.8140 | Val Loss: 0.4426, Val Acc: 0.8600 | Test Loss: 0.3060, Test Acc: 0.9056\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3308, Train Acc: 0.8980 | Val Loss: 0.5274, Val Acc: 0.8300 | Test Loss: 0.3531, Test Acc: 0.8921\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 329.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3554, Train Acc: 0.8790 | Val Loss: 0.4095, Val Acc: 0.8500 | Test Loss: 0.2895, Test Acc: 0.9109\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.4, epsilon=0.8: Test Loss: 0.2961, Test Accuracy: 0.9118\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.4, epsilon=0.8: Test Loss: 0.2895, Test Accuracy: 0.9109\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.4, epsilon=1 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 232.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.2355, Train Acc: 0.2410 | Val Loss: 1.3869, Val Acc: 0.5900 | Test Loss: 1.3489, Test Acc: 0.5630\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 6.1570, Train Acc: 0.2640 | Val Loss: 1.5053, Val Acc: 0.4400 | Test Loss: 1.3900, Test Acc: 0.5285\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 278.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.8077, Train Acc: 0.1690 | Val Loss: 1.1809, Val Acc: 0.6500 | Test Loss: 1.0843, Test Acc: 0.6742\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.3011, Train Acc: 0.2280 | Val Loss: 1.4028, Val Acc: 0.6200 | Test Loss: 1.3356, Test Acc: 0.6545\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 148.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.7535, Train Acc: 0.3090 | Val Loss: 1.2217, Val Acc: 0.5700 | Test Loss: 1.2143, Test Acc: 0.6123\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.9937, Train Acc: 0.3670 | Val Loss: 1.3439, Val Acc: 0.5100 | Test Loss: 1.3319, Test Acc: 0.5687\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5949, Train Acc: 0.3080 | Val Loss: 1.0934, Val Acc: 0.7000 | Test Loss: 1.0363, Test Acc: 0.7144\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.1873, Train Acc: 0.3660 | Val Loss: 1.2773, Val Acc: 0.7000 | Test Loss: 1.1888, Test Acc: 0.6955\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5444, Train Acc: 0.4070 | Val Loss: 1.0635, Val Acc: 0.6600 | Test Loss: 1.0176, Test Acc: 0.6756\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.0688, Train Acc: 0.4820 | Val Loss: 1.2072, Val Acc: 0.5700 | Test Loss: 1.1364, Test Acc: 0.6159\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 217.80it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.0269, Train Acc: 0.3490 | Val Loss: 0.8732, Val Acc: 0.7200 | Test Loss: 0.8308, Test Acc: 0.7670\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.7508, Train Acc: 0.4230 | Val Loss: 0.9252, Val Acc: 0.7400 | Test Loss: 0.8559, Test Acc: 0.7729\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 184.45it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 240.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6613, Train Acc: 0.5360 | Val Loss: 0.7965, Val Acc: 0.7500 | Test Loss: 0.7379, Test Acc: 0.7887\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4483, Train Acc: 0.5940 | Val Loss: 0.8557, Val Acc: 0.7000 | Test Loss: 0.7690, Test Acc: 0.7525\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 336.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6713, Train Acc: 0.4330 | Val Loss: 0.7243, Val Acc: 0.7600 | Test Loss: 0.6159, Test Acc: 0.8327\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4376, Train Acc: 0.5110 | Val Loss: 0.7724, Val Acc: 0.7700 | Test Loss: 0.6551, Test Acc: 0.8098\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 266.42it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 250.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3956, Train Acc: 0.5730 | Val Loss: 0.6604, Val Acc: 0.8200 | Test Loss: 0.5903, Test Acc: 0.8558\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2086, Train Acc: 0.6300 | Val Loss: 0.7119, Val Acc: 0.7700 | Test Loss: 0.6340, Test Acc: 0.8227\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 324.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 227.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5516, Train Acc: 0.4420 | Val Loss: 0.5939, Val Acc: 0.8100 | Test Loss: 0.5043, Test Acc: 0.8676\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3656, Train Acc: 0.5070 | Val Loss: 0.6928, Val Acc: 0.8000 | Test Loss: 0.5760, Test Acc: 0.8312\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2157, Train Acc: 0.6240 | Val Loss: 0.6293, Val Acc: 0.7800 | Test Loss: 0.5455, Test Acc: 0.8615\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0725, Train Acc: 0.6610 | Val Loss: 0.6932, Val Acc: 0.7800 | Test Loss: 0.6004, Test Acc: 0.8383\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 222.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2264, Train Acc: 0.5730 | Val Loss: 0.5783, Val Acc: 0.8200 | Test Loss: 0.4784, Test Acc: 0.8766\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0858, Train Acc: 0.6450 | Val Loss: 0.6330, Val Acc: 0.8100 | Test Loss: 0.5216, Test Acc: 0.8509\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 192.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 188.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0102, Train Acc: 0.6710 | Val Loss: 0.5961, Val Acc: 0.7900 | Test Loss: 0.5047, Test Acc: 0.8732\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8892, Train Acc: 0.7160 | Val Loss: 0.6640, Val Acc: 0.7800 | Test Loss: 0.5610, Test Acc: 0.8392\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 207.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1974, Train Acc: 0.5660 | Val Loss: 0.5593, Val Acc: 0.8300 | Test Loss: 0.4560, Test Acc: 0.8767\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0445, Train Acc: 0.6320 | Val Loss: 0.6005, Val Acc: 0.8200 | Test Loss: 0.4917, Test Acc: 0.8544\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 248.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9567, Train Acc: 0.6820 | Val Loss: 0.5659, Val Acc: 0.8100 | Test Loss: 0.4794, Test Acc: 0.8705\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8153, Train Acc: 0.7470 | Val Loss: 0.6449, Val Acc: 0.7900 | Test Loss: 0.5541, Test Acc: 0.8375\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0835, Train Acc: 0.6210 | Val Loss: 0.5604, Val Acc: 0.8300 | Test Loss: 0.4571, Test Acc: 0.8756\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8964, Train Acc: 0.6880 | Val Loss: 0.5908, Val Acc: 0.8100 | Test Loss: 0.4925, Test Acc: 0.8571\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8409, Train Acc: 0.7290 | Val Loss: 0.5422, Val Acc: 0.8200 | Test Loss: 0.4501, Test Acc: 0.8813\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7297, Train Acc: 0.7730 | Val Loss: 0.6048, Val Acc: 0.8100 | Test Loss: 0.5247, Test Acc: 0.8490\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 179.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 156.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9837, Train Acc: 0.6490 | Val Loss: 0.5313, Val Acc: 0.8400 | Test Loss: 0.4292, Test Acc: 0.8827\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8143, Train Acc: 0.7170 | Val Loss: 0.5973, Val Acc: 0.8000 | Test Loss: 0.4997, Test Acc: 0.8591\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 325.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8542, Train Acc: 0.7080 | Val Loss: 0.5378, Val Acc: 0.8100 | Test Loss: 0.4445, Test Acc: 0.8811\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6692, Train Acc: 0.7860 | Val Loss: 0.6008, Val Acc: 0.8000 | Test Loss: 0.5185, Test Acc: 0.8490\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.43it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 208.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8331, Train Acc: 0.7130 | Val Loss: 0.5080, Val Acc: 0.8500 | Test Loss: 0.4087, Test Acc: 0.8906\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6775, Train Acc: 0.7790 | Val Loss: 0.5853, Val Acc: 0.8200 | Test Loss: 0.4923, Test Acc: 0.8607\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 208.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7225, Train Acc: 0.7560 | Val Loss: 0.5184, Val Acc: 0.8300 | Test Loss: 0.4194, Test Acc: 0.8856\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5639, Train Acc: 0.8210 | Val Loss: 0.5979, Val Acc: 0.7900 | Test Loss: 0.5133, Test Acc: 0.8448\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8092, Train Acc: 0.7000 | Val Loss: 0.4991, Val Acc: 0.8400 | Test Loss: 0.4011, Test Acc: 0.8906\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6313, Train Acc: 0.7940 | Val Loss: 0.5689, Val Acc: 0.8300 | Test Loss: 0.4754, Test Acc: 0.8629\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 226.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7284, Train Acc: 0.7600 | Val Loss: 0.4960, Val Acc: 0.8500 | Test Loss: 0.4042, Test Acc: 0.8858\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5434, Train Acc: 0.8330 | Val Loss: 0.5559, Val Acc: 0.8000 | Test Loss: 0.4915, Test Acc: 0.8425\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 250.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 291.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7219, Train Acc: 0.7520 | Val Loss: 0.5108, Val Acc: 0.8500 | Test Loss: 0.4139, Test Acc: 0.8794\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5500, Train Acc: 0.8200 | Val Loss: 0.6184, Val Acc: 0.8400 | Test Loss: 0.5103, Test Acc: 0.8521\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 236.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7252, Train Acc: 0.7360 | Val Loss: 0.4830, Val Acc: 0.8300 | Test Loss: 0.3868, Test Acc: 0.8930\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5140, Train Acc: 0.8310 | Val Loss: 0.4904, Val Acc: 0.8200 | Test Loss: 0.4416, Test Acc: 0.8679\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.59it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7422, Train Acc: 0.7340 | Val Loss: 0.4557, Val Acc: 0.8600 | Test Loss: 0.3586, Test Acc: 0.8981\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5107, Train Acc: 0.8310 | Val Loss: 0.5319, Val Acc: 0.8400 | Test Loss: 0.4291, Test Acc: 0.8720\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.45it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6509, Train Acc: 0.7870 | Val Loss: 0.4530, Val Acc: 0.8300 | Test Loss: 0.3579, Test Acc: 0.8975\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4725, Train Acc: 0.8520 | Val Loss: 0.4651, Val Acc: 0.8600 | Test Loss: 0.4248, Test Acc: 0.8645\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 258.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6132, Train Acc: 0.7900 | Val Loss: 0.4646, Val Acc: 0.8400 | Test Loss: 0.3724, Test Acc: 0.8942\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4228, Train Acc: 0.8620 | Val Loss: 0.5436, Val Acc: 0.8500 | Test Loss: 0.4481, Test Acc: 0.8647\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 160.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6633, Train Acc: 0.7830 | Val Loss: 0.4458, Val Acc: 0.8700 | Test Loss: 0.3479, Test Acc: 0.9015\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4770, Train Acc: 0.8620 | Val Loss: 0.4853, Val Acc: 0.8300 | Test Loss: 0.4277, Test Acc: 0.8622\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6228, Train Acc: 0.7750 | Val Loss: 0.4602, Val Acc: 0.8500 | Test Loss: 0.3584, Test Acc: 0.8974\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4273, Train Acc: 0.8630 | Val Loss: 0.5343, Val Acc: 0.8200 | Test Loss: 0.4442, Test Acc: 0.8709\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 210.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5661, Train Acc: 0.8080 | Val Loss: 0.4558, Val Acc: 0.8700 | Test Loss: 0.3537, Test Acc: 0.8938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4002, Train Acc: 0.8710 | Val Loss: 0.4772, Val Acc: 0.8400 | Test Loss: 0.4125, Test Acc: 0.8661\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6105, Train Acc: 0.7730 | Val Loss: 0.4683, Val Acc: 0.8600 | Test Loss: 0.3645, Test Acc: 0.8881\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3720, Train Acc: 0.8810 | Val Loss: 0.5218, Val Acc: 0.8400 | Test Loss: 0.4498, Test Acc: 0.8640\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 334.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5891, Train Acc: 0.8080 | Val Loss: 0.4517, Val Acc: 0.8600 | Test Loss: 0.3642, Test Acc: 0.8906\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3833, Train Acc: 0.8810 | Val Loss: 0.5015, Val Acc: 0.8400 | Test Loss: 0.4376, Test Acc: 0.8554\n",
      "\n",
      "--- Outer Iteration 34/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.71it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 233.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6143, Train Acc: 0.7740 | Val Loss: 0.4756, Val Acc: 0.8500 | Test Loss: 0.3636, Test Acc: 0.8860\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3948, Train Acc: 0.8600 | Val Loss: 0.5739, Val Acc: 0.8000 | Test Loss: 0.4570, Test Acc: 0.8539\n",
      "\n",
      "--- Outer Iteration 35/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 270.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 164.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6574, Train Acc: 0.7500 | Val Loss: 0.4462, Val Acc: 0.8600 | Test Loss: 0.3600, Test Acc: 0.8906\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3767, Train Acc: 0.8840 | Val Loss: 0.4832, Val Acc: 0.8700 | Test Loss: 0.4257, Test Acc: 0.8661\n",
      "\n",
      "--- Outer Iteration 36/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.74it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6321, Train Acc: 0.7670 | Val Loss: 0.5031, Val Acc: 0.8400 | Test Loss: 0.3666, Test Acc: 0.8849\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4013, Train Acc: 0.8750 | Val Loss: 0.6207, Val Acc: 0.8000 | Test Loss: 0.4792, Test Acc: 0.8398\n",
      "\n",
      "--- Outer Iteration 37/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.23it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6503, Train Acc: 0.7790 | Val Loss: 0.4766, Val Acc: 0.8400 | Test Loss: 0.3793, Test Acc: 0.8780\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4204, Train Acc: 0.8610 | Val Loss: 0.5212, Val Acc: 0.8600 | Test Loss: 0.4735, Test Acc: 0.8446\n",
      "\n",
      "--- Outer Iteration 38/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 252.71it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 172.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5963, Train Acc: 0.7880 | Val Loss: 0.5240, Val Acc: 0.8300 | Test Loss: 0.3896, Test Acc: 0.8703\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3754, Train Acc: 0.8610 | Val Loss: 0.6512, Val Acc: 0.8100 | Test Loss: 0.4917, Test Acc: 0.8374\n",
      "\n",
      "--- Outer Iteration 39/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 276.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5944, Train Acc: 0.7870 | Val Loss: 0.4924, Val Acc: 0.8200 | Test Loss: 0.3583, Test Acc: 0.8856\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.4, epsilon=1: Test Loss: 0.3479, Test Accuracy: 0.9015\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.4, epsilon=1: Test Loss: 0.3583, Test Accuracy: 0.8856\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.6, epsilon=0 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 253.44it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6525, Train Acc: 0.8000 | Val Loss: 1.8822, Val Acc: 0.6400 | Test Loss: 1.7880, Test Acc: 0.6556\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2489, Train Acc: 0.9100 | Val Loss: 2.0394, Val Acc: 0.6500 | Test Loss: 1.8492, Test Acc: 0.6499\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 147.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1551, Train Acc: 0.9520 | Val Loss: 2.1351, Val Acc: 0.6500 | Test Loss: 1.9331, Test Acc: 0.6419\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1018, Train Acc: 0.9690 | Val Loss: 2.1180, Val Acc: 0.6400 | Test Loss: 1.9354, Test Acc: 0.6480\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 299.18it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0638, Train Acc: 0.9890 | Val Loss: 2.0224, Val Acc: 0.6500 | Test Loss: 1.8499, Test Acc: 0.6614\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0554, Train Acc: 0.9910 | Val Loss: 2.1007, Val Acc: 0.6600 | Test Loss: 1.8999, Test Acc: 0.6550\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0483, Train Acc: 0.9940 | Val Loss: 2.1067, Val Acc: 0.6700 | Test Loss: 1.9256, Test Acc: 0.6512\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0366, Train Acc: 0.9940 | Val Loss: 2.1418, Val Acc: 0.6600 | Test Loss: 1.9339, Test Acc: 0.6528\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0305, Train Acc: 0.9960 | Val Loss: 2.2586, Val Acc: 0.6600 | Test Loss: 2.0021, Test Acc: 0.6485\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0242, Train Acc: 0.9980 | Val Loss: 2.2638, Val Acc: 0.6400 | Test Loss: 2.0231, Test Acc: 0.6455\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 211.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 299.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0183, Train Acc: 0.9990 | Val Loss: 2.2405, Val Acc: 0.6500 | Test Loss: 2.0351, Test Acc: 0.6497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0155, Train Acc: 0.9990 | Val Loss: 2.2246, Val Acc: 0.6600 | Test Loss: 2.0381, Test Acc: 0.6504\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 218.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0196, Train Acc: 0.9980 | Val Loss: 2.2223, Val Acc: 0.6600 | Test Loss: 2.0254, Test Acc: 0.6531\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0114, Train Acc: 0.9990 | Val Loss: 2.2932, Val Acc: 0.6600 | Test Loss: 2.0886, Test Acc: 0.6538\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 279.23it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0400, Train Acc: 0.9950 | Val Loss: 2.3062, Val Acc: 0.6400 | Test Loss: 2.1081, Test Acc: 0.6490\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0283, Train Acc: 0.9920 | Val Loss: 2.2856, Val Acc: 0.6400 | Test Loss: 2.0745, Test Acc: 0.6533\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 141.14it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 213.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0381, Train Acc: 0.9930 | Val Loss: 2.2701, Val Acc: 0.6400 | Test Loss: 2.0616, Test Acc: 0.6555\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0209, Train Acc: 0.9940 | Val Loss: 2.2666, Val Acc: 0.6500 | Test Loss: 2.0427, Test Acc: 0.6548\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 155.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0170, Train Acc: 0.9980 | Val Loss: 2.2942, Val Acc: 0.6400 | Test Loss: 2.0830, Test Acc: 0.6508\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0090, Train Acc: 0.9990 | Val Loss: 2.2815, Val Acc: 0.6400 | Test Loss: 2.0672, Test Acc: 0.6509\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 299.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0134, Train Acc: 0.9990 | Val Loss: 2.2664, Val Acc: 0.6400 | Test Loss: 2.0557, Test Acc: 0.6522\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0070, Train Acc: 0.9990 | Val Loss: 2.2866, Val Acc: 0.6300 | Test Loss: 2.0821, Test Acc: 0.6518\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.52it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0352, Train Acc: 0.9950 | Val Loss: 2.3667, Val Acc: 0.6300 | Test Loss: 2.1779, Test Acc: 0.6459\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0140, Train Acc: 0.9980 | Val Loss: 2.5942, Val Acc: 0.6300 | Test Loss: 2.3463, Test Acc: 0.6362\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 292.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0116, Train Acc: 0.9980 | Val Loss: 2.4341, Val Acc: 0.6200 | Test Loss: 2.1633, Test Acc: 0.6505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0075, Train Acc: 1.0000 | Val Loss: 2.3320, Val Acc: 0.6400 | Test Loss: 2.0631, Test Acc: 0.6601\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 379.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0407, Train Acc: 0.9950 | Val Loss: 2.4471, Val Acc: 0.6300 | Test Loss: 2.1043, Test Acc: 0.6573\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.6, epsilon=0: Test Loss: 1.9256, Test Accuracy: 0.6512\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.6, epsilon=0: Test Loss: 2.1043, Test Accuracy: 0.6573\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.6, epsilon=0.2 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 254.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.1108, Train Acc: 0.3910 | Val Loss: 0.9766, Val Acc: 0.8000 | Test Loss: 0.8423, Test Acc: 0.7891\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8709, Train Acc: 0.6030 | Val Loss: 0.9630, Val Acc: 0.8100 | Test Loss: 0.7348, Test Acc: 0.8173\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 278.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 286.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4776, Train Acc: 0.5350 | Val Loss: 0.9516, Val Acc: 0.8200 | Test Loss: 0.6421, Test Acc: 0.8467\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6135, Train Acc: 0.6350 | Val Loss: 1.0116, Val Acc: 0.8000 | Test Loss: 0.6948, Test Acc: 0.8466\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 219.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3417, Train Acc: 0.6810 | Val Loss: 0.9242, Val Acc: 0.8300 | Test Loss: 0.5828, Test Acc: 0.8588\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0230, Train Acc: 0.7300 | Val Loss: 0.8322, Val Acc: 0.8500 | Test Loss: 0.4940, Test Acc: 0.8681\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7532, Train Acc: 0.7800 | Val Loss: 0.7900, Val Acc: 0.8500 | Test Loss: 0.4695, Test Acc: 0.8750\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6254, Train Acc: 0.8110 | Val Loss: 0.7485, Val Acc: 0.8500 | Test Loss: 0.4689, Test Acc: 0.8774\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 261.07it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4857, Train Acc: 0.8450 | Val Loss: 0.7237, Val Acc: 0.8400 | Test Loss: 0.4547, Test Acc: 0.8790\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4287, Train Acc: 0.8600 | Val Loss: 0.6890, Val Acc: 0.8500 | Test Loss: 0.4322, Test Acc: 0.8824\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.65it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3233, Train Acc: 0.8950 | Val Loss: 0.7051, Val Acc: 0.8500 | Test Loss: 0.4383, Test Acc: 0.8798\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3100, Train Acc: 0.9020 | Val Loss: 0.7159, Val Acc: 0.8500 | Test Loss: 0.4448, Test Acc: 0.8813\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 170.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2379, Train Acc: 0.9260 | Val Loss: 0.6784, Val Acc: 0.8500 | Test Loss: 0.4267, Test Acc: 0.8848\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2199, Train Acc: 0.9380 | Val Loss: 0.6585, Val Acc: 0.8500 | Test Loss: 0.4169, Test Acc: 0.8854\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1855, Train Acc: 0.9450 | Val Loss: 0.6555, Val Acc: 0.8500 | Test Loss: 0.4144, Test Acc: 0.8885\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1689, Train Acc: 0.9540 | Val Loss: 0.6754, Val Acc: 0.8500 | Test Loss: 0.4319, Test Acc: 0.8863\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1493, Train Acc: 0.9610 | Val Loss: 0.6599, Val Acc: 0.8500 | Test Loss: 0.4204, Test Acc: 0.8886\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1293, Train Acc: 0.9700 | Val Loss: 0.6658, Val Acc: 0.8500 | Test Loss: 0.4161, Test Acc: 0.8875\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 299.88it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1209, Train Acc: 0.9680 | Val Loss: 0.6718, Val Acc: 0.8500 | Test Loss: 0.4284, Test Acc: 0.8882\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1055, Train Acc: 0.9780 | Val Loss: 0.6797, Val Acc: 0.8500 | Test Loss: 0.4548, Test Acc: 0.8861\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 167.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1368, Train Acc: 0.9720 | Val Loss: 0.6623, Val Acc: 0.8500 | Test Loss: 0.4365, Test Acc: 0.8879\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1074, Train Acc: 0.9810 | Val Loss: 0.6588, Val Acc: 0.8500 | Test Loss: 0.4226, Test Acc: 0.8859\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 213.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 264.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1082, Train Acc: 0.9760 | Val Loss: 0.6928, Val Acc: 0.8500 | Test Loss: 0.4400, Test Acc: 0.8857\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0966, Train Acc: 0.9780 | Val Loss: 0.7202, Val Acc: 0.8400 | Test Loss: 0.4795, Test Acc: 0.8842\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 236.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 162.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1023, Train Acc: 0.9790 | Val Loss: 0.6796, Val Acc: 0.8500 | Test Loss: 0.4486, Test Acc: 0.8880\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0842, Train Acc: 0.9820 | Val Loss: 0.6623, Val Acc: 0.8500 | Test Loss: 0.4262, Test Acc: 0.8872\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.6, epsilon=0.2: Test Loss: 0.4940, Test Accuracy: 0.8681\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.6, epsilon=0.2: Test Loss: 0.4262, Test Accuracy: 0.8872\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.6, epsilon=0.4 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 166.31it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 267.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 6.7056, Train Acc: 0.2600 | Val Loss: 1.1807, Val Acc: 0.6900 | Test Loss: 1.0667, Test Acc: 0.7024\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2716, Train Acc: 0.3470 | Val Loss: 1.0923, Val Acc: 0.7100 | Test Loss: 0.9876, Test Acc: 0.7233\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.5441, Train Acc: 0.3070 | Val Loss: 1.0460, Val Acc: 0.7200 | Test Loss: 0.8812, Test Acc: 0.7688\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.1458, Train Acc: 0.3900 | Val Loss: 1.2567, Val Acc: 0.7000 | Test Loss: 1.0863, Test Acc: 0.7596\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 283.63it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 190.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5614, Train Acc: 0.4780 | Val Loss: 0.9562, Val Acc: 0.7400 | Test Loss: 0.7937, Test Acc: 0.8010\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9534, Train Acc: 0.5340 | Val Loss: 0.8602, Val Acc: 0.7900 | Test Loss: 0.6846, Test Acc: 0.8219\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 205.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5037, Train Acc: 0.5700 | Val Loss: 0.8351, Val Acc: 0.7800 | Test Loss: 0.6538, Test Acc: 0.8339\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2695, Train Acc: 0.6240 | Val Loss: 0.8018, Val Acc: 0.8000 | Test Loss: 0.6254, Test Acc: 0.8440\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 315.17it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 170.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1937, Train Acc: 0.6320 | Val Loss: 0.7237, Val Acc: 0.8300 | Test Loss: 0.5527, Test Acc: 0.8566\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0073, Train Acc: 0.6890 | Val Loss: 0.6844, Val Acc: 0.8300 | Test Loss: 0.5223, Test Acc: 0.8643\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 272.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 228.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8985, Train Acc: 0.7080 | Val Loss: 0.6771, Val Acc: 0.8300 | Test Loss: 0.5182, Test Acc: 0.8651\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8373, Train Acc: 0.7420 | Val Loss: 0.6731, Val Acc: 0.8200 | Test Loss: 0.5140, Test Acc: 0.8684\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7482, Train Acc: 0.7630 | Val Loss: 0.6141, Val Acc: 0.8500 | Test Loss: 0.4537, Test Acc: 0.8802\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6643, Train Acc: 0.7790 | Val Loss: 0.5893, Val Acc: 0.8500 | Test Loss: 0.4207, Test Acc: 0.8849\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 139.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 217.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6342, Train Acc: 0.7900 | Val Loss: 0.6114, Val Acc: 0.8600 | Test Loss: 0.4357, Test Acc: 0.8829\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5672, Train Acc: 0.8230 | Val Loss: 0.6127, Val Acc: 0.8500 | Test Loss: 0.4429, Test Acc: 0.8816\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 285.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5422, Train Acc: 0.8190 | Val Loss: 0.5793, Val Acc: 0.8600 | Test Loss: 0.4085, Test Acc: 0.8879\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4802, Train Acc: 0.8420 | Val Loss: 0.5591, Val Acc: 0.8600 | Test Loss: 0.4011, Test Acc: 0.8884\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 257.24it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5040, Train Acc: 0.8300 | Val Loss: 0.5797, Val Acc: 0.8600 | Test Loss: 0.3968, Test Acc: 0.8914\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4239, Train Acc: 0.8590 | Val Loss: 0.6037, Val Acc: 0.8500 | Test Loss: 0.4367, Test Acc: 0.8897\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.43it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4620, Train Acc: 0.8480 | Val Loss: 0.5488, Val Acc: 0.8600 | Test Loss: 0.3703, Test Acc: 0.8970\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3825, Train Acc: 0.8790 | Val Loss: 0.5279, Val Acc: 0.8600 | Test Loss: 0.3587, Test Acc: 0.8955\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 237.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 257.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4098, Train Acc: 0.8560 | Val Loss: 0.5576, Val Acc: 0.8600 | Test Loss: 0.3595, Test Acc: 0.8982\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3494, Train Acc: 0.8850 | Val Loss: 0.6159, Val Acc: 0.8500 | Test Loss: 0.4235, Test Acc: 0.8904\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 316.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3552, Train Acc: 0.8750 | Val Loss: 0.5470, Val Acc: 0.8600 | Test Loss: 0.3625, Test Acc: 0.8995\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3020, Train Acc: 0.8990 | Val Loss: 0.5149, Val Acc: 0.8500 | Test Loss: 0.3426, Test Acc: 0.8999\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3184, Train Acc: 0.8910 | Val Loss: 0.5422, Val Acc: 0.8600 | Test Loss: 0.3458, Test Acc: 0.9018\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2795, Train Acc: 0.9150 | Val Loss: 0.5858, Val Acc: 0.8500 | Test Loss: 0.3818, Test Acc: 0.8966\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 315.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 217.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2742, Train Acc: 0.9050 | Val Loss: 0.5570, Val Acc: 0.8600 | Test Loss: 0.3520, Test Acc: 0.9016\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2408, Train Acc: 0.9340 | Val Loss: 0.5430, Val Acc: 0.8500 | Test Loss: 0.3435, Test Acc: 0.9022\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 282.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 277.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2503, Train Acc: 0.9270 | Val Loss: 0.5532, Val Acc: 0.8600 | Test Loss: 0.3425, Test Acc: 0.9031\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2071, Train Acc: 0.9480 | Val Loss: 0.5648, Val Acc: 0.8600 | Test Loss: 0.3508, Test Acc: 0.9013\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 204.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.51it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2113, Train Acc: 0.9440 | Val Loss: 0.5466, Val Acc: 0.8600 | Test Loss: 0.3286, Test Acc: 0.9050\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1843, Train Acc: 0.9540 | Val Loss: 0.5289, Val Acc: 0.8600 | Test Loss: 0.3172, Test Acc: 0.9064\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 296.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2032, Train Acc: 0.9380 | Val Loss: 0.5457, Val Acc: 0.8600 | Test Loss: 0.3277, Test Acc: 0.9062\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.6, epsilon=0.4: Test Loss: 0.4357, Test Accuracy: 0.8829\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.6, epsilon=0.4: Test Loss: 0.3277, Test Accuracy: 0.9062\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.6, epsilon=0.6 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 203.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.5421, Train Acc: 0.2520 | Val Loss: 1.1682, Val Acc: 0.6600 | Test Loss: 1.1038, Test Acc: 0.6615\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.3056, Train Acc: 0.2850 | Val Loss: 1.2325, Val Acc: 0.6300 | Test Loss: 1.1334, Test Acc: 0.6443\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 191.31it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 210.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.1458, Train Acc: 0.2370 | Val Loss: 1.0845, Val Acc: 0.7100 | Test Loss: 0.9779, Test Acc: 0.7241\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.7221, Train Acc: 0.3350 | Val Loss: 1.3156, Val Acc: 0.6800 | Test Loss: 1.2286, Test Acc: 0.7114\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.77it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.1559, Train Acc: 0.3840 | Val Loss: 0.9965, Val Acc: 0.7200 | Test Loss: 0.9288, Test Acc: 0.7399\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.5129, Train Acc: 0.4290 | Val Loss: 0.9198, Val Acc: 0.7300 | Test Loss: 0.8424, Test Acc: 0.7576\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 334.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 164.95it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.9544, Train Acc: 0.4550 | Val Loss: 0.9320, Val Acc: 0.7600 | Test Loss: 0.8345, Test Acc: 0.7829\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6397, Train Acc: 0.5130 | Val Loss: 0.9414, Val Acc: 0.7300 | Test Loss: 0.8366, Test Acc: 0.7907\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 149.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 241.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6860, Train Acc: 0.5380 | Val Loss: 0.7391, Val Acc: 0.7800 | Test Loss: 0.6429, Test Acc: 0.8216\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4876, Train Acc: 0.5880 | Val Loss: 0.7010, Val Acc: 0.7900 | Test Loss: 0.5993, Test Acc: 0.8285\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 251.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3310, Train Acc: 0.5630 | Val Loss: 0.7290, Val Acc: 0.7600 | Test Loss: 0.6121, Test Acc: 0.8323\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1777, Train Acc: 0.6230 | Val Loss: 0.7528, Val Acc: 0.7700 | Test Loss: 0.6305, Test Acc: 0.8328\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1105, Train Acc: 0.6300 | Val Loss: 0.6453, Val Acc: 0.8400 | Test Loss: 0.5196, Test Acc: 0.8559\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0077, Train Acc: 0.6700 | Val Loss: 0.6231, Val Acc: 0.8300 | Test Loss: 0.4812, Test Acc: 0.8667\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 187.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 164.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0334, Train Acc: 0.6210 | Val Loss: 0.6157, Val Acc: 0.8400 | Test Loss: 0.4752, Test Acc: 0.8674\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9319, Train Acc: 0.6720 | Val Loss: 0.6325, Val Acc: 0.8300 | Test Loss: 0.4984, Test Acc: 0.8612\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 254.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 288.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8437, Train Acc: 0.7220 | Val Loss: 0.5704, Val Acc: 0.8500 | Test Loss: 0.4403, Test Acc: 0.8777\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7647, Train Acc: 0.7550 | Val Loss: 0.5380, Val Acc: 0.8500 | Test Loss: 0.4153, Test Acc: 0.8817\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 288.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7828, Train Acc: 0.7140 | Val Loss: 0.5559, Val Acc: 0.8500 | Test Loss: 0.4263, Test Acc: 0.8799\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7252, Train Acc: 0.7430 | Val Loss: 0.5886, Val Acc: 0.8400 | Test Loss: 0.4469, Test Acc: 0.8755\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.60it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.97it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6954, Train Acc: 0.7540 | Val Loss: 0.5300, Val Acc: 0.8400 | Test Loss: 0.3867, Test Acc: 0.8883\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6093, Train Acc: 0.7960 | Val Loss: 0.5038, Val Acc: 0.8500 | Test Loss: 0.3662, Test Acc: 0.8920\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 265.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6798, Train Acc: 0.7490 | Val Loss: 0.5267, Val Acc: 0.8400 | Test Loss: 0.3817, Test Acc: 0.8905\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6036, Train Acc: 0.7820 | Val Loss: 0.5463, Val Acc: 0.8400 | Test Loss: 0.4170, Test Acc: 0.8871\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 223.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6152, Train Acc: 0.7880 | Val Loss: 0.4942, Val Acc: 0.8400 | Test Loss: 0.3504, Test Acc: 0.8980\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5221, Train Acc: 0.8230 | Val Loss: 0.4734, Val Acc: 0.8500 | Test Loss: 0.3435, Test Acc: 0.8952\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 355.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 192.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6498, Train Acc: 0.7590 | Val Loss: 0.4975, Val Acc: 0.8500 | Test Loss: 0.3471, Test Acc: 0.8975\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5125, Train Acc: 0.8140 | Val Loss: 0.5300, Val Acc: 0.8500 | Test Loss: 0.4076, Test Acc: 0.8891\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 212.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 240.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5692, Train Acc: 0.8120 | Val Loss: 0.4769, Val Acc: 0.8500 | Test Loss: 0.3254, Test Acc: 0.9033\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4370, Train Acc: 0.8600 | Val Loss: 0.4730, Val Acc: 0.8500 | Test Loss: 0.3357, Test Acc: 0.8941\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 233.52it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5727, Train Acc: 0.7880 | Val Loss: 0.4843, Val Acc: 0.8600 | Test Loss: 0.3213, Test Acc: 0.9041\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4490, Train Acc: 0.8570 | Val Loss: 0.5041, Val Acc: 0.8700 | Test Loss: 0.3730, Test Acc: 0.8970\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 184.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5114, Train Acc: 0.8070 | Val Loss: 0.4620, Val Acc: 0.8700 | Test Loss: 0.3107, Test Acc: 0.9071\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3934, Train Acc: 0.8710 | Val Loss: 0.4749, Val Acc: 0.8600 | Test Loss: 0.3256, Test Acc: 0.8955\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 334.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5179, Train Acc: 0.8190 | Val Loss: 0.4797, Val Acc: 0.8500 | Test Loss: 0.3107, Test Acc: 0.9060\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3902, Train Acc: 0.8790 | Val Loss: 0.5008, Val Acc: 0.8600 | Test Loss: 0.3605, Test Acc: 0.8970\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 243.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4630, Train Acc: 0.8280 | Val Loss: 0.4736, Val Acc: 0.8500 | Test Loss: 0.3130, Test Acc: 0.9043\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3476, Train Acc: 0.8750 | Val Loss: 0.4718, Val Acc: 0.8700 | Test Loss: 0.3109, Test Acc: 0.9008\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 408.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 139.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4126, Train Acc: 0.8530 | Val Loss: 0.4593, Val Acc: 0.8700 | Test Loss: 0.2989, Test Acc: 0.9070\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3313, Train Acc: 0.8920 | Val Loss: 0.4590, Val Acc: 0.8900 | Test Loss: 0.3149, Test Acc: 0.9051\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 295.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 191.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3868, Train Acc: 0.8530 | Val Loss: 0.4653, Val Acc: 0.8700 | Test Loss: 0.3053, Test Acc: 0.9084\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3169, Train Acc: 0.8940 | Val Loss: 0.4542, Val Acc: 0.8700 | Test Loss: 0.2975, Test Acc: 0.9060\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 160.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3347, Train Acc: 0.8760 | Val Loss: 0.4492, Val Acc: 0.8600 | Test Loss: 0.2926, Test Acc: 0.9081\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2902, Train Acc: 0.9070 | Val Loss: 0.4564, Val Acc: 0.8700 | Test Loss: 0.3017, Test Acc: 0.9080\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3005, Train Acc: 0.8980 | Val Loss: 0.4458, Val Acc: 0.8700 | Test Loss: 0.2867, Test Acc: 0.9113\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2664, Train Acc: 0.9120 | Val Loss: 0.4538, Val Acc: 0.8700 | Test Loss: 0.2904, Test Acc: 0.9053\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3090, Train Acc: 0.8960 | Val Loss: 0.4437, Val Acc: 0.8700 | Test Loss: 0.2875, Test Acc: 0.9096\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2581, Train Acc: 0.9260 | Val Loss: 0.4626, Val Acc: 0.8600 | Test Loss: 0.3075, Test Acc: 0.9069\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 297.88it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2985, Train Acc: 0.9040 | Val Loss: 0.4347, Val Acc: 0.8700 | Test Loss: 0.2753, Test Acc: 0.9150\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2455, Train Acc: 0.9310 | Val Loss: 0.4383, Val Acc: 0.8700 | Test Loss: 0.2767, Test Acc: 0.9101\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 278.14it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 193.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3362, Train Acc: 0.8810 | Val Loss: 0.4452, Val Acc: 0.8800 | Test Loss: 0.2799, Test Acc: 0.9134\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2522, Train Acc: 0.9160 | Val Loss: 0.5156, Val Acc: 0.8800 | Test Loss: 0.3353, Test Acc: 0.8999\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 220.01it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3659, Train Acc: 0.8730 | Val Loss: 0.4648, Val Acc: 0.8800 | Test Loss: 0.2742, Test Acc: 0.9150\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2599, Train Acc: 0.9300 | Val Loss: 0.5181, Val Acc: 0.8500 | Test Loss: 0.3080, Test Acc: 0.9007\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 182.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3776, Train Acc: 0.8580 | Val Loss: 0.4349, Val Acc: 0.8800 | Test Loss: 0.2702, Test Acc: 0.9147\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2503, Train Acc: 0.9190 | Val Loss: 0.4920, Val Acc: 0.8800 | Test Loss: 0.3440, Test Acc: 0.9000\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 193.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 167.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3876, Train Acc: 0.8680 | Val Loss: 0.4690, Val Acc: 0.8700 | Test Loss: 0.2806, Test Acc: 0.9127\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2503, Train Acc: 0.9250 | Val Loss: 0.5169, Val Acc: 0.8400 | Test Loss: 0.2956, Test Acc: 0.9021\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3790, Train Acc: 0.8610 | Val Loss: 0.4492, Val Acc: 0.8800 | Test Loss: 0.2684, Test Acc: 0.9164\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2564, Train Acc: 0.9180 | Val Loss: 0.4514, Val Acc: 0.8900 | Test Loss: 0.3297, Test Acc: 0.9043\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.6, epsilon=0.6: Test Loss: 0.3149, Test Accuracy: 0.9051\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.6, epsilon=0.6: Test Loss: 0.3297, Test Accuracy: 0.9043\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.6, epsilon=0.8 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 212.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.9978, Train Acc: 0.2470 | Val Loss: 1.2883, Val Acc: 0.6200 | Test Loss: 1.2192, Test Acc: 0.6145\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.8861, Train Acc: 0.2710 | Val Loss: 1.4030, Val Acc: 0.5100 | Test Loss: 1.2639, Test Acc: 0.5821\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.4563, Train Acc: 0.1940 | Val Loss: 1.1266, Val Acc: 0.6700 | Test Loss: 1.0289, Test Acc: 0.6943\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.0649, Train Acc: 0.2530 | Val Loss: 1.3175, Val Acc: 0.6400 | Test Loss: 1.2648, Test Acc: 0.6823\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 276.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 149.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.4695, Train Acc: 0.3320 | Val Loss: 1.0710, Val Acc: 0.6600 | Test Loss: 1.0371, Test Acc: 0.6853\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.7820, Train Acc: 0.3840 | Val Loss: 1.0863, Val Acc: 0.6500 | Test Loss: 1.0704, Test Acc: 0.6695\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 229.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.3257, Train Acc: 0.3680 | Val Loss: 1.0388, Val Acc: 0.6700 | Test Loss: 0.9698, Test Acc: 0.7374\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9366, Train Acc: 0.4210 | Val Loss: 1.1202, Val Acc: 0.7000 | Test Loss: 1.0351, Test Acc: 0.7331\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 202.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 213.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.1803, Train Acc: 0.4670 | Val Loss: 0.8590, Val Acc: 0.7500 | Test Loss: 0.7984, Test Acc: 0.7662\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8008, Train Acc: 0.5400 | Val Loss: 0.8899, Val Acc: 0.7200 | Test Loss: 0.8068, Test Acc: 0.7449\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.39it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7968, Train Acc: 0.4290 | Val Loss: 0.7872, Val Acc: 0.7700 | Test Loss: 0.7028, Test Acc: 0.8059\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5522, Train Acc: 0.4980 | Val Loss: 0.8576, Val Acc: 0.7600 | Test Loss: 0.7566, Test Acc: 0.7974\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4180, Train Acc: 0.5780 | Val Loss: 0.6943, Val Acc: 0.8100 | Test Loss: 0.6064, Test Acc: 0.8352\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2251, Train Acc: 0.6380 | Val Loss: 0.7139, Val Acc: 0.8000 | Test Loss: 0.6029, Test Acc: 0.8227\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 245.87it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3923, Train Acc: 0.5060 | Val Loss: 0.6647, Val Acc: 0.8000 | Test Loss: 0.5579, Test Acc: 0.8486\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2236, Train Acc: 0.5770 | Val Loss: 0.7200, Val Acc: 0.7800 | Test Loss: 0.6136, Test Acc: 0.8291\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 159.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1218, Train Acc: 0.6380 | Val Loss: 0.6101, Val Acc: 0.8300 | Test Loss: 0.5145, Test Acc: 0.8641\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0059, Train Acc: 0.6780 | Val Loss: 0.6289, Val Acc: 0.8000 | Test Loss: 0.5174, Test Acc: 0.8548\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 316.08it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 209.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2477, Train Acc: 0.5590 | Val Loss: 0.5577, Val Acc: 0.8300 | Test Loss: 0.4634, Test Acc: 0.8785\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1099, Train Acc: 0.6070 | Val Loss: 0.6037, Val Acc: 0.8400 | Test Loss: 0.5064, Test Acc: 0.8584\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 269.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9999, Train Acc: 0.6610 | Val Loss: 0.5642, Val Acc: 0.8400 | Test Loss: 0.4581, Test Acc: 0.8751\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8829, Train Acc: 0.7170 | Val Loss: 0.5779, Val Acc: 0.8300 | Test Loss: 0.4746, Test Acc: 0.8643\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 269.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 260.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0200, Train Acc: 0.6170 | Val Loss: 0.5606, Val Acc: 0.8500 | Test Loss: 0.4497, Test Acc: 0.8806\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9383, Train Acc: 0.6590 | Val Loss: 0.5908, Val Acc: 0.8300 | Test Loss: 0.4938, Test Acc: 0.8571\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8370, Train Acc: 0.7100 | Val Loss: 0.5231, Val Acc: 0.8600 | Test Loss: 0.4210, Test Acc: 0.8884\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7522, Train Acc: 0.7520 | Val Loss: 0.5350, Val Acc: 0.8700 | Test Loss: 0.4323, Test Acc: 0.8818\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 221.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 172.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9841, Train Acc: 0.6420 | Val Loss: 0.5074, Val Acc: 0.8500 | Test Loss: 0.4026, Test Acc: 0.8912\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8452, Train Acc: 0.6840 | Val Loss: 0.5386, Val Acc: 0.8500 | Test Loss: 0.4429, Test Acc: 0.8737\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 205.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7509, Train Acc: 0.7380 | Val Loss: 0.5096, Val Acc: 0.8700 | Test Loss: 0.4034, Test Acc: 0.8873\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6443, Train Acc: 0.7730 | Val Loss: 0.5293, Val Acc: 0.8600 | Test Loss: 0.4257, Test Acc: 0.8765\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 277.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7686, Train Acc: 0.7300 | Val Loss: 0.5112, Val Acc: 0.8500 | Test Loss: 0.3943, Test Acc: 0.8918\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6594, Train Acc: 0.7650 | Val Loss: 0.5359, Val Acc: 0.8400 | Test Loss: 0.4203, Test Acc: 0.8809\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.96it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6796, Train Acc: 0.7720 | Val Loss: 0.4747, Val Acc: 0.8700 | Test Loss: 0.3686, Test Acc: 0.8976\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5841, Train Acc: 0.8150 | Val Loss: 0.4828, Val Acc: 0.8700 | Test Loss: 0.3796, Test Acc: 0.8902\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 337.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6915, Train Acc: 0.7500 | Val Loss: 0.5067, Val Acc: 0.8400 | Test Loss: 0.3759, Test Acc: 0.8920\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5924, Train Acc: 0.7880 | Val Loss: 0.5525, Val Acc: 0.8200 | Test Loss: 0.4207, Test Acc: 0.8759\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 286.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5980, Train Acc: 0.7960 | Val Loss: 0.4613, Val Acc: 0.8700 | Test Loss: 0.3454, Test Acc: 0.9026\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4946, Train Acc: 0.8360 | Val Loss: 0.4481, Val Acc: 0.8600 | Test Loss: 0.3495, Test Acc: 0.8988\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 265.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6825, Train Acc: 0.7520 | Val Loss: 0.4575, Val Acc: 0.8600 | Test Loss: 0.3390, Test Acc: 0.9023\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5858, Train Acc: 0.7900 | Val Loss: 0.5239, Val Acc: 0.8500 | Test Loss: 0.3963, Test Acc: 0.8829\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 360.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 208.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5506, Train Acc: 0.7990 | Val Loss: 0.4426, Val Acc: 0.8800 | Test Loss: 0.3284, Test Acc: 0.9049\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4591, Train Acc: 0.8470 | Val Loss: 0.4221, Val Acc: 0.8700 | Test Loss: 0.3266, Test Acc: 0.9042\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 295.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5996, Train Acc: 0.7730 | Val Loss: 0.4493, Val Acc: 0.8600 | Test Loss: 0.3266, Test Acc: 0.8997\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4934, Train Acc: 0.8250 | Val Loss: 0.5166, Val Acc: 0.8500 | Test Loss: 0.3841, Test Acc: 0.8801\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 299.63it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5417, Train Acc: 0.8110 | Val Loss: 0.4406, Val Acc: 0.8600 | Test Loss: 0.3158, Test Acc: 0.9079\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4560, Train Acc: 0.8410 | Val Loss: 0.4369, Val Acc: 0.8600 | Test Loss: 0.3182, Test Acc: 0.9036\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.96it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 252.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5818, Train Acc: 0.7720 | Val Loss: 0.4357, Val Acc: 0.8600 | Test Loss: 0.3085, Test Acc: 0.9058\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4639, Train Acc: 0.8440 | Val Loss: 0.5028, Val Acc: 0.8500 | Test Loss: 0.3742, Test Acc: 0.8859\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4599, Train Acc: 0.8230 | Val Loss: 0.4153, Val Acc: 0.8800 | Test Loss: 0.3135, Test Acc: 0.9031\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3708, Train Acc: 0.8670 | Val Loss: 0.4142, Val Acc: 0.8800 | Test Loss: 0.3266, Test Acc: 0.9008\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 192.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.64it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5465, Train Acc: 0.7900 | Val Loss: 0.4279, Val Acc: 0.8600 | Test Loss: 0.3058, Test Acc: 0.9052\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4208, Train Acc: 0.8610 | Val Loss: 0.4859, Val Acc: 0.8600 | Test Loss: 0.3636, Test Acc: 0.8872\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 318.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4921, Train Acc: 0.8220 | Val Loss: 0.4035, Val Acc: 0.8600 | Test Loss: 0.2924, Test Acc: 0.9097\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3717, Train Acc: 0.8810 | Val Loss: 0.4428, Val Acc: 0.8600 | Test Loss: 0.3348, Test Acc: 0.8920\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 265.87it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5061, Train Acc: 0.8180 | Val Loss: 0.4490, Val Acc: 0.8800 | Test Loss: 0.3103, Test Acc: 0.9037\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3451, Train Acc: 0.8880 | Val Loss: 0.5349, Val Acc: 0.8400 | Test Loss: 0.4051, Test Acc: 0.8742\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 326.40it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5631, Train Acc: 0.7980 | Val Loss: 0.4151, Val Acc: 0.8500 | Test Loss: 0.3216, Test Acc: 0.9016\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3716, Train Acc: 0.8850 | Val Loss: 0.4976, Val Acc: 0.8500 | Test Loss: 0.4106, Test Acc: 0.8677\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 262.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6402, Train Acc: 0.7480 | Val Loss: 0.4351, Val Acc: 0.8500 | Test Loss: 0.3065, Test Acc: 0.9057\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3936, Train Acc: 0.8510 | Val Loss: 0.5559, Val Acc: 0.8200 | Test Loss: 0.3951, Test Acc: 0.8809\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 154.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6501, Train Acc: 0.7560 | Val Loss: 0.4231, Val Acc: 0.8500 | Test Loss: 0.3017, Test Acc: 0.9062\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.6, epsilon=0.8: Test Loss: 0.3284, Test Accuracy: 0.9049\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.6, epsilon=0.8: Test Loss: 0.3017, Test Accuracy: 0.9062\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.6, epsilon=1 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 297.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 237.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.2427, Train Acc: 0.2430 | Val Loss: 1.4039, Val Acc: 0.5800 | Test Loss: 1.3543, Test Acc: 0.5631\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 6.1656, Train Acc: 0.2580 | Val Loss: 1.5417, Val Acc: 0.4400 | Test Loss: 1.4094, Test Acc: 0.5274\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.7383, Train Acc: 0.1830 | Val Loss: 1.1976, Val Acc: 0.6500 | Test Loss: 1.1048, Test Acc: 0.6707\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2917, Train Acc: 0.2460 | Val Loss: 1.4225, Val Acc: 0.6200 | Test Loss: 1.3611, Test Acc: 0.6527\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 287.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.8105, Train Acc: 0.3130 | Val Loss: 1.2470, Val Acc: 0.5600 | Test Loss: 1.2405, Test Acc: 0.6018\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.0162, Train Acc: 0.3530 | Val Loss: 1.3844, Val Acc: 0.5200 | Test Loss: 1.3703, Test Acc: 0.5439\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 220.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5937, Train Acc: 0.2780 | Val Loss: 1.1116, Val Acc: 0.6900 | Test Loss: 1.0465, Test Acc: 0.7047\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.2102, Train Acc: 0.3510 | Val Loss: 1.2715, Val Acc: 0.6800 | Test Loss: 1.1824, Test Acc: 0.6905\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.68it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5487, Train Acc: 0.3990 | Val Loss: 1.0703, Val Acc: 0.6500 | Test Loss: 1.0312, Test Acc: 0.6760\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.0861, Train Acc: 0.4630 | Val Loss: 1.1843, Val Acc: 0.6100 | Test Loss: 1.1228, Test Acc: 0.6174\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 237.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.0718, Train Acc: 0.3290 | Val Loss: 0.8571, Val Acc: 0.7200 | Test Loss: 0.8303, Test Acc: 0.7726\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8075, Train Acc: 0.4120 | Val Loss: 0.9032, Val Acc: 0.7500 | Test Loss: 0.8498, Test Acc: 0.7752\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6409, Train Acc: 0.5090 | Val Loss: 0.7892, Val Acc: 0.7900 | Test Loss: 0.7318, Test Acc: 0.7944\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4173, Train Acc: 0.5890 | Val Loss: 0.8772, Val Acc: 0.7000 | Test Loss: 0.7878, Test Acc: 0.7445\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 157.90it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 245.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6502, Train Acc: 0.4440 | Val Loss: 0.7223, Val Acc: 0.8000 | Test Loss: 0.6233, Test Acc: 0.8339\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4299, Train Acc: 0.5120 | Val Loss: 0.8008, Val Acc: 0.7700 | Test Loss: 0.6924, Test Acc: 0.7943\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 312.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3663, Train Acc: 0.5670 | Val Loss: 0.6762, Val Acc: 0.8100 | Test Loss: 0.6149, Test Acc: 0.8474\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1835, Train Acc: 0.6260 | Val Loss: 0.7416, Val Acc: 0.8000 | Test Loss: 0.6676, Test Acc: 0.8207\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 187.32it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 162.77it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5187, Train Acc: 0.4620 | Val Loss: 0.6167, Val Acc: 0.8100 | Test Loss: 0.5245, Test Acc: 0.8666\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3248, Train Acc: 0.5340 | Val Loss: 0.6855, Val Acc: 0.8000 | Test Loss: 0.5877, Test Acc: 0.8333\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 253.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2007, Train Acc: 0.5980 | Val Loss: 0.6431, Val Acc: 0.7800 | Test Loss: 0.5662, Test Acc: 0.8507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0659, Train Acc: 0.6510 | Val Loss: 0.6804, Val Acc: 0.7900 | Test Loss: 0.6009, Test Acc: 0.8329\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.99it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2068, Train Acc: 0.5690 | Val Loss: 0.6065, Val Acc: 0.8300 | Test Loss: 0.5051, Test Acc: 0.8702\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0551, Train Acc: 0.6520 | Val Loss: 0.6512, Val Acc: 0.7900 | Test Loss: 0.5414, Test Acc: 0.8438\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 201.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 137.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0105, Train Acc: 0.6680 | Val Loss: 0.5780, Val Acc: 0.8400 | Test Loss: 0.5076, Test Acc: 0.8736\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9090, Train Acc: 0.7150 | Val Loss: 0.6306, Val Acc: 0.8100 | Test Loss: 0.5672, Test Acc: 0.8427\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1187, Train Acc: 0.6000 | Val Loss: 0.5723, Val Acc: 0.8300 | Test Loss: 0.4799, Test Acc: 0.8697\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9856, Train Acc: 0.6590 | Val Loss: 0.6325, Val Acc: 0.8000 | Test Loss: 0.5393, Test Acc: 0.8424\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 312.96it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 221.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9479, Train Acc: 0.6860 | Val Loss: 0.5648, Val Acc: 0.8400 | Test Loss: 0.4889, Test Acc: 0.8736\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8294, Train Acc: 0.7290 | Val Loss: 0.6065, Val Acc: 0.8200 | Test Loss: 0.5295, Test Acc: 0.8520\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 283.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9691, Train Acc: 0.6490 | Val Loss: 0.5323, Val Acc: 0.8300 | Test Loss: 0.4353, Test Acc: 0.8834\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8454, Train Acc: 0.7110 | Val Loss: 0.5759, Val Acc: 0.8300 | Test Loss: 0.4763, Test Acc: 0.8576\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.27it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 179.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8129, Train Acc: 0.7280 | Val Loss: 0.5423, Val Acc: 0.8200 | Test Loss: 0.4631, Test Acc: 0.8707\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7135, Train Acc: 0.7640 | Val Loss: 0.5981, Val Acc: 0.8000 | Test Loss: 0.5226, Test Acc: 0.8458\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8853, Train Acc: 0.6840 | Val Loss: 0.5270, Val Acc: 0.8500 | Test Loss: 0.4347, Test Acc: 0.8825\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7333, Train Acc: 0.7480 | Val Loss: 0.5843, Val Acc: 0.8300 | Test Loss: 0.4856, Test Acc: 0.8591\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 141.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 213.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8846, Train Acc: 0.6970 | Val Loss: 0.5418, Val Acc: 0.8200 | Test Loss: 0.4485, Test Acc: 0.8699\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7375, Train Acc: 0.7510 | Val Loss: 0.5856, Val Acc: 0.7800 | Test Loss: 0.5146, Test Acc: 0.8459\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 200.04it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 148.95it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8260, Train Acc: 0.6960 | Val Loss: 0.5058, Val Acc: 0.8500 | Test Loss: 0.4181, Test Acc: 0.8842\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6923, Train Acc: 0.7540 | Val Loss: 0.5607, Val Acc: 0.8200 | Test Loss: 0.4815, Test Acc: 0.8648\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 197.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 204.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7431, Train Acc: 0.7470 | Val Loss: 0.5097, Val Acc: 0.8400 | Test Loss: 0.4393, Test Acc: 0.8674\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6314, Train Acc: 0.7870 | Val Loss: 0.5924, Val Acc: 0.8100 | Test Loss: 0.5434, Test Acc: 0.8285\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 211.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7438, Train Acc: 0.7410 | Val Loss: 0.5191, Val Acc: 0.8500 | Test Loss: 0.4297, Test Acc: 0.8813\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5817, Train Acc: 0.8130 | Val Loss: 0.5856, Val Acc: 0.8400 | Test Loss: 0.4950, Test Acc: 0.8559\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 279.74it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8068, Train Acc: 0.7190 | Val Loss: 0.5084, Val Acc: 0.8600 | Test Loss: 0.4191, Test Acc: 0.8739\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6258, Train Acc: 0.7980 | Val Loss: 0.5646, Val Acc: 0.8300 | Test Loss: 0.5024, Test Acc: 0.8368\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 165.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7453, Train Acc: 0.7290 | Val Loss: 0.4801, Val Acc: 0.8500 | Test Loss: 0.3980, Test Acc: 0.8888\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5191, Train Acc: 0.8190 | Val Loss: 0.5438, Val Acc: 0.8200 | Test Loss: 0.4792, Test Acc: 0.8647\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 192.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7433, Train Acc: 0.7630 | Val Loss: 0.4864, Val Acc: 0.8400 | Test Loss: 0.4137, Test Acc: 0.8713\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5652, Train Acc: 0.8220 | Val Loss: 0.5704, Val Acc: 0.8200 | Test Loss: 0.5252, Test Acc: 0.8224\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 267.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 164.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7043, Train Acc: 0.7450 | Val Loss: 0.4908, Val Acc: 0.8500 | Test Loss: 0.3952, Test Acc: 0.8876\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4914, Train Acc: 0.8320 | Val Loss: 0.5774, Val Acc: 0.8300 | Test Loss: 0.4739, Test Acc: 0.8534\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 316.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7613, Train Acc: 0.7290 | Val Loss: 0.4909, Val Acc: 0.8300 | Test Loss: 0.3998, Test Acc: 0.8754\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5573, Train Acc: 0.8190 | Val Loss: 0.5648, Val Acc: 0.8100 | Test Loss: 0.5013, Test Acc: 0.8290\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 174.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6378, Train Acc: 0.7420 | Val Loss: 0.5046, Val Acc: 0.8600 | Test Loss: 0.4168, Test Acc: 0.8849\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3992, Train Acc: 0.8780 | Val Loss: 0.6060, Val Acc: 0.7900 | Test Loss: 0.5296, Test Acc: 0.8479\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 235.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 172.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7643, Train Acc: 0.7620 | Val Loss: 0.4696, Val Acc: 0.8300 | Test Loss: 0.3995, Test Acc: 0.8756\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5062, Train Acc: 0.8460 | Val Loss: 0.5556, Val Acc: 0.8200 | Test Loss: 0.5400, Test Acc: 0.8231\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 291.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 153.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7578, Train Acc: 0.7080 | Val Loss: 0.4969, Val Acc: 0.8300 | Test Loss: 0.4039, Test Acc: 0.8808\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4877, Train Acc: 0.8230 | Val Loss: 0.6012, Val Acc: 0.7900 | Test Loss: 0.4968, Test Acc: 0.8542\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 177.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.34it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6605, Train Acc: 0.7610 | Val Loss: 0.4917, Val Acc: 0.8400 | Test Loss: 0.4017, Test Acc: 0.8729\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4421, Train Acc: 0.8560 | Val Loss: 0.5575, Val Acc: 0.8400 | Test Loss: 0.5068, Test Acc: 0.8322\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.01it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 367.62it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6368, Train Acc: 0.7700 | Val Loss: 0.5134, Val Acc: 0.8200 | Test Loss: 0.4101, Test Acc: 0.8810\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3962, Train Acc: 0.8740 | Val Loss: 0.6028, Val Acc: 0.8100 | Test Loss: 0.5167, Test Acc: 0.8512\n",
      "\n",
      "--- Outer Iteration 33/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 195.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6420, Train Acc: 0.7870 | Val Loss: 0.4527, Val Acc: 0.8400 | Test Loss: 0.3753, Test Acc: 0.8832\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.6, epsilon=1: Test Loss: 0.4191, Test Accuracy: 0.8739\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.6, epsilon=1: Test Loss: 0.3753, Test Accuracy: 0.8832\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.9, epsilon=0 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 264.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 248.05it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7252, Train Acc: 0.7940 | Val Loss: 1.8553, Val Acc: 0.6400 | Test Loss: 1.8223, Test Acc: 0.6554\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2818, Train Acc: 0.9000 | Val Loss: 2.1527, Val Acc: 0.6500 | Test Loss: 1.9542, Test Acc: 0.6412\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 184.25it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1632, Train Acc: 0.9480 | Val Loss: 2.0916, Val Acc: 0.6600 | Test Loss: 1.8959, Test Acc: 0.6511\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0952, Train Acc: 0.9780 | Val Loss: 2.0398, Val Acc: 0.6700 | Test Loss: 1.8295, Test Acc: 0.6552\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 247.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0693, Train Acc: 0.9870 | Val Loss: 2.0467, Val Acc: 0.6700 | Test Loss: 1.8546, Test Acc: 0.6573\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0524, Train Acc: 0.9890 | Val Loss: 2.1221, Val Acc: 0.6700 | Test Loss: 1.9400, Test Acc: 0.6528\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 295.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 233.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0438, Train Acc: 0.9940 | Val Loss: 2.1765, Val Acc: 0.6700 | Test Loss: 1.9866, Test Acc: 0.6473\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0351, Train Acc: 0.9960 | Val Loss: 2.1759, Val Acc: 0.6600 | Test Loss: 1.9727, Test Acc: 0.6495\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 218.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0387, Train Acc: 0.9920 | Val Loss: 2.2364, Val Acc: 0.6600 | Test Loss: 2.0008, Test Acc: 0.6479\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0306, Train Acc: 0.9960 | Val Loss: 2.2711, Val Acc: 0.6400 | Test Loss: 2.0511, Test Acc: 0.6452\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 178.68it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0243, Train Acc: 0.9980 | Val Loss: 2.2658, Val Acc: 0.6400 | Test Loss: 2.0555, Test Acc: 0.6450\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0165, Train Acc: 0.9990 | Val Loss: 2.2853, Val Acc: 0.6500 | Test Loss: 2.0795, Test Acc: 0.6457\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 254.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0238, Train Acc: 0.9960 | Val Loss: 2.2521, Val Acc: 0.6500 | Test Loss: 2.0356, Test Acc: 0.6517\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0160, Train Acc: 0.9990 | Val Loss: 2.2398, Val Acc: 0.6500 | Test Loss: 2.0025, Test Acc: 0.6528\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 192.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0244, Train Acc: 0.9960 | Val Loss: 2.2289, Val Acc: 0.6700 | Test Loss: 1.9829, Test Acc: 0.6528\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0163, Train Acc: 0.9980 | Val Loss: 2.2869, Val Acc: 0.6400 | Test Loss: 2.0590, Test Acc: 0.6436\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 235.07it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0272, Train Acc: 0.9970 | Val Loss: 2.2944, Val Acc: 0.6400 | Test Loss: 2.0566, Test Acc: 0.6496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0096, Train Acc: 0.9990 | Val Loss: 2.2910, Val Acc: 0.6500 | Test Loss: 2.0355, Test Acc: 0.6539\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 260.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 252.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0245, Train Acc: 0.9960 | Val Loss: 2.2862, Val Acc: 0.6500 | Test Loss: 2.0352, Test Acc: 0.6573\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0150, Train Acc: 0.9980 | Val Loss: 2.2900, Val Acc: 0.6500 | Test Loss: 2.0450, Test Acc: 0.6554\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 166.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0139, Train Acc: 0.9990 | Val Loss: 2.3333, Val Acc: 0.6500 | Test Loss: 2.0937, Test Acc: 0.6496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0202, Train Acc: 0.9960 | Val Loss: 2.2877, Val Acc: 0.6400 | Test Loss: 2.0335, Test Acc: 0.6583\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 215.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0174, Train Acc: 0.9980 | Val Loss: 2.2941, Val Acc: 0.6400 | Test Loss: 2.0286, Test Acc: 0.6580\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0122, Train Acc: 0.9990 | Val Loss: 2.3188, Val Acc: 0.6400 | Test Loss: 2.0821, Test Acc: 0.6559\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.9, epsilon=0: Test Loss: 1.8295, Test Accuracy: 0.6552\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.9, epsilon=0: Test Loss: 2.0821, Test Accuracy: 0.6559\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.9, epsilon=0.2 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 265.73it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 163.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.0927, Train Acc: 0.3840 | Val Loss: 0.9854, Val Acc: 0.8100 | Test Loss: 0.8723, Test Acc: 0.7814\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8634, Train Acc: 0.5850 | Val Loss: 0.9322, Val Acc: 0.8200 | Test Loss: 0.7120, Test Acc: 0.8209\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 231.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 222.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.5139, Train Acc: 0.5220 | Val Loss: 0.9130, Val Acc: 0.8200 | Test Loss: 0.6087, Test Acc: 0.8487\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6787, Train Acc: 0.6430 | Val Loss: 1.0018, Val Acc: 0.8000 | Test Loss: 0.6584, Test Acc: 0.8492\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 274.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.3482, Train Acc: 0.6860 | Val Loss: 0.8857, Val Acc: 0.8300 | Test Loss: 0.5390, Test Acc: 0.8647\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9981, Train Acc: 0.7300 | Val Loss: 0.7921, Val Acc: 0.8400 | Test Loss: 0.4569, Test Acc: 0.8739\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 230.68it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8163, Train Acc: 0.7570 | Val Loss: 0.7560, Val Acc: 0.8400 | Test Loss: 0.4328, Test Acc: 0.8788\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6651, Train Acc: 0.7990 | Val Loss: 0.7160, Val Acc: 0.8400 | Test Loss: 0.4430, Test Acc: 0.8805\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 252.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5400, Train Acc: 0.8370 | Val Loss: 0.6884, Val Acc: 0.8400 | Test Loss: 0.4265, Test Acc: 0.8848\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4857, Train Acc: 0.8510 | Val Loss: 0.6706, Val Acc: 0.8400 | Test Loss: 0.4017, Test Acc: 0.8863\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 289.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4159, Train Acc: 0.8760 | Val Loss: 0.6498, Val Acc: 0.8400 | Test Loss: 0.3908, Test Acc: 0.8884\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3971, Train Acc: 0.8810 | Val Loss: 0.6449, Val Acc: 0.8400 | Test Loss: 0.3962, Test Acc: 0.8886\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 247.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3418, Train Acc: 0.8990 | Val Loss: 0.6250, Val Acc: 0.8400 | Test Loss: 0.3782, Test Acc: 0.8922\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2957, Train Acc: 0.9060 | Val Loss: 0.6198, Val Acc: 0.8400 | Test Loss: 0.3711, Test Acc: 0.8935\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 226.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2620, Train Acc: 0.9210 | Val Loss: 0.6226, Val Acc: 0.8300 | Test Loss: 0.3735, Test Acc: 0.8938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2532, Train Acc: 0.9270 | Val Loss: 0.6245, Val Acc: 0.8300 | Test Loss: 0.3699, Test Acc: 0.8952\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 383.18it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 266.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2094, Train Acc: 0.9410 | Val Loss: 0.6031, Val Acc: 0.8400 | Test Loss: 0.3604, Test Acc: 0.8966\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1943, Train Acc: 0.9400 | Val Loss: 0.5880, Val Acc: 0.8500 | Test Loss: 0.3474, Test Acc: 0.8996\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 249.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1698, Train Acc: 0.9570 | Val Loss: 0.6025, Val Acc: 0.8400 | Test Loss: 0.3537, Test Acc: 0.8976\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1520, Train Acc: 0.9610 | Val Loss: 0.6030, Val Acc: 0.8400 | Test Loss: 0.3506, Test Acc: 0.8989\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 242.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 170.09it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1374, Train Acc: 0.9720 | Val Loss: 0.6107, Val Acc: 0.8300 | Test Loss: 0.3551, Test Acc: 0.8992\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1167, Train Acc: 0.9840 | Val Loss: 0.6101, Val Acc: 0.8400 | Test Loss: 0.3517, Test Acc: 0.8995\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 195.37it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.00it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1087, Train Acc: 0.9790 | Val Loss: 0.6134, Val Acc: 0.8500 | Test Loss: 0.3437, Test Acc: 0.9020\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1025, Train Acc: 0.9860 | Val Loss: 0.6209, Val Acc: 0.8400 | Test Loss: 0.3450, Test Acc: 0.9025\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 246.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0882, Train Acc: 0.9860 | Val Loss: 0.6228, Val Acc: 0.8600 | Test Loss: 0.3474, Test Acc: 0.9031\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0819, Train Acc: 0.9870 | Val Loss: 0.6225, Val Acc: 0.8600 | Test Loss: 0.3471, Test Acc: 0.9036\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 244.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0717, Train Acc: 0.9940 | Val Loss: 0.6308, Val Acc: 0.8600 | Test Loss: 0.3524, Test Acc: 0.9031\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0696, Train Acc: 0.9950 | Val Loss: 0.6505, Val Acc: 0.8600 | Test Loss: 0.3694, Test Acc: 0.8998\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 346.42it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 156.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0674, Train Acc: 0.9890 | Val Loss: 0.6378, Val Acc: 0.8600 | Test Loss: 0.3562, Test Acc: 0.9022\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0558, Train Acc: 0.9930 | Val Loss: 0.6415, Val Acc: 0.8600 | Test Loss: 0.3464, Test Acc: 0.9040\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 214.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 185.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0539, Train Acc: 0.9960 | Val Loss: 0.6437, Val Acc: 0.8600 | Test Loss: 0.3438, Test Acc: 0.9057\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0503, Train Acc: 0.9940 | Val Loss: 0.6573, Val Acc: 0.8600 | Test Loss: 0.3535, Test Acc: 0.9036\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 167.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.22it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0465, Train Acc: 0.9980 | Val Loss: 0.6450, Val Acc: 0.8600 | Test Loss: 0.3529, Test Acc: 0.9059\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0451, Train Acc: 0.9950 | Val Loss: 0.6501, Val Acc: 0.8700 | Test Loss: 0.3546, Test Acc: 0.9057\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 217.96it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0395, Train Acc: 0.9970 | Val Loss: 0.6532, Val Acc: 0.8600 | Test Loss: 0.3493, Test Acc: 0.9062\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0355, Train Acc: 0.9990 | Val Loss: 0.6683, Val Acc: 0.8600 | Test Loss: 0.3578, Test Acc: 0.9036\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.56it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.65it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0371, Train Acc: 0.9980 | Val Loss: 0.6613, Val Acc: 0.8600 | Test Loss: 0.3563, Test Acc: 0.9061\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0322, Train Acc: 0.9990 | Val Loss: 0.6603, Val Acc: 0.8600 | Test Loss: 0.3526, Test Acc: 0.9072\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 297.72it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0292, Train Acc: 0.9980 | Val Loss: 0.6609, Val Acc: 0.8600 | Test Loss: 0.3520, Test Acc: 0.9076\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0269, Train Acc: 0.9980 | Val Loss: 0.6638, Val Acc: 0.8600 | Test Loss: 0.3535, Test Acc: 0.9066\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.39it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0251, Train Acc: 1.0000 | Val Loss: 0.6646, Val Acc: 0.8600 | Test Loss: 0.3526, Test Acc: 0.9080\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0254, Train Acc: 1.0000 | Val Loss: 0.6746, Val Acc: 0.8600 | Test Loss: 0.3525, Test Acc: 0.9087\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 343.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0233, Train Acc: 0.9980 | Val Loss: 0.6709, Val Acc: 0.8600 | Test Loss: 0.3536, Test Acc: 0.9092\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0228, Train Acc: 0.9990 | Val Loss: 0.6856, Val Acc: 0.8600 | Test Loss: 0.3545, Test Acc: 0.9087\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 335.13it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 319.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0188, Train Acc: 0.9990 | Val Loss: 0.6699, Val Acc: 0.8600 | Test Loss: 0.3491, Test Acc: 0.9097\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0201, Train Acc: 1.0000 | Val Loss: 0.6774, Val Acc: 0.8700 | Test Loss: 0.3535, Test Acc: 0.9087\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 190.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 182.80it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0188, Train Acc: 1.0000 | Val Loss: 0.6998, Val Acc: 0.8600 | Test Loss: 0.3596, Test Acc: 0.9076\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0203, Train Acc: 0.9990 | Val Loss: 0.6897, Val Acc: 0.8600 | Test Loss: 0.3560, Test Acc: 0.9096\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.62it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.02it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0186, Train Acc: 1.0000 | Val Loss: 0.6880, Val Acc: 0.8600 | Test Loss: 0.3551, Test Acc: 0.9101\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0164, Train Acc: 1.0000 | Val Loss: 0.6801, Val Acc: 0.8700 | Test Loss: 0.3503, Test Acc: 0.9105\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.49it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0144, Train Acc: 1.0000 | Val Loss: 0.6953, Val Acc: 0.8600 | Test Loss: 0.3566, Test Acc: 0.9092\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0139, Train Acc: 0.9990 | Val Loss: 0.6915, Val Acc: 0.8600 | Test Loss: 0.3572, Test Acc: 0.9098\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 277.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.0144, Train Acc: 1.0000 | Val Loss: 0.6914, Val Acc: 0.8600 | Test Loss: 0.3541, Test Acc: 0.9105\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.0139, Train Acc: 1.0000 | Val Loss: 0.6985, Val Acc: 0.8700 | Test Loss: 0.3593, Test Acc: 0.9093\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.9, epsilon=0.2: Test Loss: 0.3546, Test Accuracy: 0.9057\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.9, epsilon=0.2: Test Loss: 0.3593, Test Accuracy: 0.9093\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.9, epsilon=0.4 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 318.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 6.7314, Train Acc: 0.2640 | Val Loss: 1.1046, Val Acc: 0.7100 | Test Loss: 1.0162, Test Acc: 0.7085\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.3066, Train Acc: 0.3420 | Val Loss: 1.0568, Val Acc: 0.7600 | Test Loss: 0.9540, Test Acc: 0.7305\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 317.89it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 262.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 4.5948, Train Acc: 0.3010 | Val Loss: 1.0093, Val Acc: 0.7100 | Test Loss: 0.8549, Test Acc: 0.7700\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.2899, Train Acc: 0.3920 | Val Loss: 1.1748, Val Acc: 0.7000 | Test Loss: 1.0155, Test Acc: 0.7680\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.6509, Train Acc: 0.4610 | Val Loss: 0.9608, Val Acc: 0.7500 | Test Loss: 0.8067, Test Acc: 0.8007\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.0697, Train Acc: 0.5200 | Val Loss: 0.8392, Val Acc: 0.8100 | Test Loss: 0.6675, Test Acc: 0.8232\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.24it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 202.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6610, Train Acc: 0.5540 | Val Loss: 0.8065, Val Acc: 0.8000 | Test Loss: 0.6265, Test Acc: 0.8345\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3990, Train Acc: 0.5940 | Val Loss: 0.7448, Val Acc: 0.8200 | Test Loss: 0.5631, Test Acc: 0.8462\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 337.29it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2166, Train Acc: 0.6440 | Val Loss: 0.6699, Val Acc: 0.8400 | Test Loss: 0.4863, Test Acc: 0.8611\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0550, Train Acc: 0.6810 | Val Loss: 0.6165, Val Acc: 0.8400 | Test Loss: 0.4334, Test Acc: 0.8716\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 239.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 149.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9616, Train Acc: 0.6780 | Val Loss: 0.5903, Val Acc: 0.8400 | Test Loss: 0.4111, Test Acc: 0.8786\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8719, Train Acc: 0.7000 | Val Loss: 0.5826, Val Acc: 0.8400 | Test Loss: 0.4038, Test Acc: 0.8827\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 197.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 252.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7854, Train Acc: 0.7390 | Val Loss: 0.5517, Val Acc: 0.8400 | Test Loss: 0.3734, Test Acc: 0.8887\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7183, Train Acc: 0.7710 | Val Loss: 0.5357, Val Acc: 0.8400 | Test Loss: 0.3558, Test Acc: 0.8909\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 287.11it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.50it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6902, Train Acc: 0.7740 | Val Loss: 0.5351, Val Acc: 0.8400 | Test Loss: 0.3521, Test Acc: 0.8938\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6176, Train Acc: 0.7910 | Val Loss: 0.5207, Val Acc: 0.8500 | Test Loss: 0.3529, Test Acc: 0.8941\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.06it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6164, Train Acc: 0.7950 | Val Loss: 0.5127, Val Acc: 0.8500 | Test Loss: 0.3266, Test Acc: 0.9021\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5407, Train Acc: 0.8230 | Val Loss: 0.5013, Val Acc: 0.8500 | Test Loss: 0.3181, Test Acc: 0.9040\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 304.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 218.95it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5410, Train Acc: 0.7990 | Val Loss: 0.4910, Val Acc: 0.8600 | Test Loss: 0.3098, Test Acc: 0.9078\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4760, Train Acc: 0.8350 | Val Loss: 0.5035, Val Acc: 0.8600 | Test Loss: 0.3234, Test Acc: 0.9029\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.26it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.65it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4655, Train Acc: 0.8380 | Val Loss: 0.4817, Val Acc: 0.8600 | Test Loss: 0.3035, Test Acc: 0.9091\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4224, Train Acc: 0.8510 | Val Loss: 0.4819, Val Acc: 0.8500 | Test Loss: 0.3001, Test Acc: 0.9095\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 228.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4263, Train Acc: 0.8570 | Val Loss: 0.4931, Val Acc: 0.8600 | Test Loss: 0.2948, Test Acc: 0.9111\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3723, Train Acc: 0.8760 | Val Loss: 0.5139, Val Acc: 0.8700 | Test Loss: 0.3122, Test Acc: 0.9059\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 275.88it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3654, Train Acc: 0.8670 | Val Loss: 0.4876, Val Acc: 0.8600 | Test Loss: 0.2921, Test Acc: 0.9123\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3315, Train Acc: 0.8980 | Val Loss: 0.4608, Val Acc: 0.8500 | Test Loss: 0.2835, Test Acc: 0.9157\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 229.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 165.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3363, Train Acc: 0.8890 | Val Loss: 0.4711, Val Acc: 0.8700 | Test Loss: 0.2809, Test Acc: 0.9148\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2893, Train Acc: 0.9140 | Val Loss: 0.4924, Val Acc: 0.8700 | Test Loss: 0.2996, Test Acc: 0.9101\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 241.10it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2993, Train Acc: 0.9060 | Val Loss: 0.4667, Val Acc: 0.8600 | Test Loss: 0.2748, Test Acc: 0.9171\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2547, Train Acc: 0.9280 | Val Loss: 0.4649, Val Acc: 0.8600 | Test Loss: 0.2711, Test Acc: 0.9188\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 167.57it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2917, Train Acc: 0.8950 | Val Loss: 0.4732, Val Acc: 0.8700 | Test Loss: 0.2714, Test Acc: 0.9179\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2290, Train Acc: 0.9250 | Val Loss: 0.5018, Val Acc: 0.8500 | Test Loss: 0.2928, Test Acc: 0.9122\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 267.88it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 199.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2505, Train Acc: 0.9260 | Val Loss: 0.4643, Val Acc: 0.8600 | Test Loss: 0.2639, Test Acc: 0.9192\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.2089, Train Acc: 0.9380 | Val Loss: 0.4373, Val Acc: 0.8600 | Test Loss: 0.2492, Test Acc: 0.9232\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 269.77it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.2158, Train Acc: 0.9330 | Val Loss: 0.4533, Val Acc: 0.8600 | Test Loss: 0.2559, Test Acc: 0.9202\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1806, Train Acc: 0.9470 | Val Loss: 0.4725, Val Acc: 0.8600 | Test Loss: 0.2754, Test Acc: 0.9159\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 298.15it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 207.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1901, Train Acc: 0.9460 | Val Loss: 0.4715, Val Acc: 0.8600 | Test Loss: 0.2626, Test Acc: 0.9200\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1568, Train Acc: 0.9610 | Val Loss: 0.4641, Val Acc: 0.8600 | Test Loss: 0.2535, Test Acc: 0.9234\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 224.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 208.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1710, Train Acc: 0.9550 | Val Loss: 0.4635, Val Acc: 0.8600 | Test Loss: 0.2515, Test Acc: 0.9236\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1413, Train Acc: 0.9710 | Val Loss: 0.4650, Val Acc: 0.8600 | Test Loss: 0.2591, Test Acc: 0.9213\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 281.73it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 230.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1555, Train Acc: 0.9610 | Val Loss: 0.4723, Val Acc: 0.8600 | Test Loss: 0.2540, Test Acc: 0.9234\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1267, Train Acc: 0.9780 | Val Loss: 0.4712, Val Acc: 0.8700 | Test Loss: 0.2527, Test Acc: 0.9243\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 293.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 192.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.1398, Train Acc: 0.9620 | Val Loss: 0.4650, Val Acc: 0.8600 | Test Loss: 0.2532, Test Acc: 0.9234\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.1130, Train Acc: 0.9780 | Val Loss: 0.4664, Val Acc: 0.8600 | Test Loss: 0.2563, Test Acc: 0.9230\n",
      "Early stopping at Epoch 2\n",
      "Best Val-Test Results for num_base_model=10, rho=0.9, epsilon=0.4: Test Loss: 0.3122, Test Accuracy: 0.9059\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.9, epsilon=0.4: Test Loss: 0.2563, Test Accuracy: 0.9230\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.9, epsilon=0.6 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.36it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.5170, Train Acc: 0.2540 | Val Loss: 1.2010, Val Acc: 0.6900 | Test Loss: 1.0961, Test Acc: 0.6639\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.3715, Train Acc: 0.2860 | Val Loss: 1.2572, Val Acc: 0.6300 | Test Loss: 1.1329, Test Acc: 0.6431\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 384.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 230.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.2650, Train Acc: 0.2250 | Val Loss: 1.1003, Val Acc: 0.7200 | Test Loss: 0.9568, Test Acc: 0.7243\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.8487, Train Acc: 0.3020 | Val Loss: 1.2618, Val Acc: 0.6800 | Test Loss: 1.1587, Test Acc: 0.7154\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.35it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 309.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.2318, Train Acc: 0.3710 | Val Loss: 0.9699, Val Acc: 0.7200 | Test Loss: 0.8820, Test Acc: 0.7469\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.5469, Train Acc: 0.4310 | Val Loss: 0.8922, Val Acc: 0.7800 | Test Loss: 0.8145, Test Acc: 0.7606\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 245.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.1002, Train Acc: 0.4320 | Val Loss: 0.8962, Val Acc: 0.7800 | Test Loss: 0.7898, Test Acc: 0.7838\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8061, Train Acc: 0.4830 | Val Loss: 0.9115, Val Acc: 0.7700 | Test Loss: 0.7976, Test Acc: 0.7923\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 302.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 196.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.7512, Train Acc: 0.5260 | Val Loss: 0.7155, Val Acc: 0.8200 | Test Loss: 0.6036, Test Acc: 0.8283\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.5123, Train Acc: 0.5770 | Val Loss: 0.6617, Val Acc: 0.8200 | Test Loss: 0.5488, Test Acc: 0.8379\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 179.37it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 212.75it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4453, Train Acc: 0.5490 | Val Loss: 0.6678, Val Acc: 0.8100 | Test Loss: 0.5393, Test Acc: 0.8413\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.2695, Train Acc: 0.5940 | Val Loss: 0.6896, Val Acc: 0.8000 | Test Loss: 0.5571, Test Acc: 0.8421\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 315.95it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 183.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1876, Train Acc: 0.6280 | Val Loss: 0.5942, Val Acc: 0.8400 | Test Loss: 0.4649, Test Acc: 0.8710\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0520, Train Acc: 0.6630 | Val Loss: 0.5708, Val Acc: 0.8400 | Test Loss: 0.4336, Test Acc: 0.8783\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.76it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 168.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0772, Train Acc: 0.6030 | Val Loss: 0.5576, Val Acc: 0.8500 | Test Loss: 0.4121, Test Acc: 0.8837\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9734, Train Acc: 0.6550 | Val Loss: 0.5727, Val Acc: 0.8600 | Test Loss: 0.4252, Test Acc: 0.8748\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 292.12it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8910, Train Acc: 0.6980 | Val Loss: 0.5199, Val Acc: 0.8500 | Test Loss: 0.3825, Test Acc: 0.8922\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8250, Train Acc: 0.7220 | Val Loss: 0.4950, Val Acc: 0.8500 | Test Loss: 0.3661, Test Acc: 0.8947\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 292.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 203.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8815, Train Acc: 0.6870 | Val Loss: 0.4993, Val Acc: 0.8600 | Test Loss: 0.3588, Test Acc: 0.8979\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8027, Train Acc: 0.7170 | Val Loss: 0.5193, Val Acc: 0.8500 | Test Loss: 0.3737, Test Acc: 0.8934\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7470, Train Acc: 0.7320 | Val Loss: 0.4726, Val Acc: 0.8500 | Test Loss: 0.3375, Test Acc: 0.9025\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6684, Train Acc: 0.7660 | Val Loss: 0.4709, Val Acc: 0.8700 | Test Loss: 0.3348, Test Acc: 0.9004\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 185.40it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 155.52it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7782, Train Acc: 0.7050 | Val Loss: 0.4641, Val Acc: 0.8500 | Test Loss: 0.3206, Test Acc: 0.9089\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6696, Train Acc: 0.7690 | Val Loss: 0.5258, Val Acc: 0.8300 | Test Loss: 0.3591, Test Acc: 0.8970\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 291.98it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6875, Train Acc: 0.7460 | Val Loss: 0.4483, Val Acc: 0.8800 | Test Loss: 0.3064, Test Acc: 0.9109\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5816, Train Acc: 0.7860 | Val Loss: 0.4559, Val Acc: 0.8700 | Test Loss: 0.3193, Test Acc: 0.9037\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 297.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6998, Train Acc: 0.7490 | Val Loss: 0.4497, Val Acc: 0.8600 | Test Loss: 0.3005, Test Acc: 0.9111\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6123, Train Acc: 0.7760 | Val Loss: 0.4883, Val Acc: 0.8700 | Test Loss: 0.3292, Test Acc: 0.9026\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 244.85it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 162.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5751, Train Acc: 0.7910 | Val Loss: 0.4306, Val Acc: 0.8800 | Test Loss: 0.2802, Test Acc: 0.9174\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4895, Train Acc: 0.8320 | Val Loss: 0.4494, Val Acc: 0.8700 | Test Loss: 0.2994, Test Acc: 0.9079\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 192.61it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 155.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5699, Train Acc: 0.7890 | Val Loss: 0.4452, Val Acc: 0.8600 | Test Loss: 0.2826, Test Acc: 0.9144\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4966, Train Acc: 0.8420 | Val Loss: 0.4835, Val Acc: 0.8500 | Test Loss: 0.3143, Test Acc: 0.9057\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.24it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4963, Train Acc: 0.8380 | Val Loss: 0.4352, Val Acc: 0.8800 | Test Loss: 0.2703, Test Acc: 0.9168\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4238, Train Acc: 0.8580 | Val Loss: 0.4431, Val Acc: 0.8600 | Test Loss: 0.2846, Test Acc: 0.9104\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.74it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 229.55it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4959, Train Acc: 0.8300 | Val Loss: 0.4380, Val Acc: 0.8600 | Test Loss: 0.2664, Test Acc: 0.9176\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4190, Train Acc: 0.8660 | Val Loss: 0.4772, Val Acc: 0.8700 | Test Loss: 0.2985, Test Acc: 0.9109\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.49it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 160.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4398, Train Acc: 0.8400 | Val Loss: 0.4299, Val Acc: 0.8800 | Test Loss: 0.2512, Test Acc: 0.9219\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3614, Train Acc: 0.8810 | Val Loss: 0.4213, Val Acc: 0.8800 | Test Loss: 0.2697, Test Acc: 0.9150\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.69it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 268.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4593, Train Acc: 0.8280 | Val Loss: 0.4325, Val Acc: 0.8600 | Test Loss: 0.2555, Test Acc: 0.9195\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3544, Train Acc: 0.8760 | Val Loss: 0.4992, Val Acc: 0.8600 | Test Loss: 0.3052, Test Acc: 0.9048\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.70it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4156, Train Acc: 0.8520 | Val Loss: 0.4447, Val Acc: 0.8800 | Test Loss: 0.2556, Test Acc: 0.9183\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3242, Train Acc: 0.8970 | Val Loss: 0.4373, Val Acc: 0.8600 | Test Loss: 0.2795, Test Acc: 0.9112\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 227.83it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 165.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4207, Train Acc: 0.8530 | Val Loss: 0.4372, Val Acc: 0.8700 | Test Loss: 0.2585, Test Acc: 0.9178\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3190, Train Acc: 0.9020 | Val Loss: 0.5075, Val Acc: 0.8600 | Test Loss: 0.2942, Test Acc: 0.9115\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 117.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.3935, Train Acc: 0.8590 | Val Loss: 0.4644, Val Acc: 0.8700 | Test Loss: 0.2474, Test Acc: 0.9226\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.9, epsilon=0.6: Test Loss: 0.3064, Test Accuracy: 0.9109\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.9, epsilon=0.6: Test Loss: 0.2474, Test Accuracy: 0.9226\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.9, epsilon=0.8 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 237.32it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 7.9484, Train Acc: 0.2450 | Val Loss: 1.2820, Val Acc: 0.6200 | Test Loss: 1.2073, Test Acc: 0.6157\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 5.8992, Train Acc: 0.2730 | Val Loss: 1.4113, Val Acc: 0.5300 | Test Loss: 1.2818, Test Acc: 0.5783\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 244.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 174.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.5718, Train Acc: 0.1860 | Val Loss: 1.1725, Val Acc: 0.6800 | Test Loss: 1.0561, Test Acc: 0.6888\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.1195, Train Acc: 0.2650 | Val Loss: 1.3548, Val Acc: 0.6600 | Test Loss: 1.2771, Test Acc: 0.6764\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.87it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 186.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.6222, Train Acc: 0.3160 | Val Loss: 1.0557, Val Acc: 0.6900 | Test Loss: 1.0195, Test Acc: 0.6886\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.9001, Train Acc: 0.3630 | Val Loss: 1.0842, Val Acc: 0.6400 | Test Loss: 1.0575, Test Acc: 0.6666\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 313.77it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 124.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.4902, Train Acc: 0.3450 | Val Loss: 1.0267, Val Acc: 0.7000 | Test Loss: 0.9432, Test Acc: 0.7440\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.1531, Train Acc: 0.4000 | Val Loss: 1.1154, Val Acc: 0.7100 | Test Loss: 1.0121, Test Acc: 0.7391\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 280.68it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.96it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.1962, Train Acc: 0.4350 | Val Loss: 0.8432, Val Acc: 0.7700 | Test Loss: 0.7825, Test Acc: 0.7727\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.8791, Train Acc: 0.4920 | Val Loss: 0.8763, Val Acc: 0.7200 | Test Loss: 0.8061, Test Acc: 0.7492\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 294.32it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.8344, Train Acc: 0.4290 | Val Loss: 0.7427, Val Acc: 0.7900 | Test Loss: 0.6508, Test Acc: 0.8192\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.6192, Train Acc: 0.5030 | Val Loss: 0.8056, Val Acc: 0.7600 | Test Loss: 0.6794, Test Acc: 0.8116\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.4689, Train Acc: 0.5580 | Val Loss: 0.6518, Val Acc: 0.8300 | Test Loss: 0.5556, Test Acc: 0.8544\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3042, Train Acc: 0.6140 | Val Loss: 0.6721, Val Acc: 0.8300 | Test Loss: 0.5639, Test Acc: 0.8506\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 206.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5278, Train Acc: 0.4730 | Val Loss: 0.5955, Val Acc: 0.8200 | Test Loss: 0.4841, Test Acc: 0.8654\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3541, Train Acc: 0.5430 | Val Loss: 0.6891, Val Acc: 0.8100 | Test Loss: 0.5567, Test Acc: 0.8365\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 196.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 171.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1855, Train Acc: 0.6030 | Val Loss: 0.5693, Val Acc: 0.8400 | Test Loss: 0.4623, Test Acc: 0.8893\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0379, Train Acc: 0.6710 | Val Loss: 0.5949, Val Acc: 0.8400 | Test Loss: 0.4845, Test Acc: 0.8826\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.34it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2980, Train Acc: 0.5400 | Val Loss: 0.5250, Val Acc: 0.8200 | Test Loss: 0.4188, Test Acc: 0.8910\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1498, Train Acc: 0.5880 | Val Loss: 0.6020, Val Acc: 0.8100 | Test Loss: 0.4969, Test Acc: 0.8508\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 217.55it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0100, Train Acc: 0.6810 | Val Loss: 0.5341, Val Acc: 0.8600 | Test Loss: 0.4272, Test Acc: 0.8934\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8939, Train Acc: 0.7120 | Val Loss: 0.5674, Val Acc: 0.8400 | Test Loss: 0.4511, Test Acc: 0.8749\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 207.58it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1140, Train Acc: 0.5910 | Val Loss: 0.5050, Val Acc: 0.8500 | Test Loss: 0.3951, Test Acc: 0.8963\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9637, Train Acc: 0.6430 | Val Loss: 0.5414, Val Acc: 0.8200 | Test Loss: 0.4435, Test Acc: 0.8677\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 190.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8846, Train Acc: 0.6990 | Val Loss: 0.4744, Val Acc: 0.8700 | Test Loss: 0.3729, Test Acc: 0.9104\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7792, Train Acc: 0.7340 | Val Loss: 0.4972, Val Acc: 0.8300 | Test Loss: 0.4028, Test Acc: 0.8877\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 148.64it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 319.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9675, Train Acc: 0.6420 | Val Loss: 0.4872, Val Acc: 0.8500 | Test Loss: 0.3721, Test Acc: 0.9002\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8455, Train Acc: 0.7020 | Val Loss: 0.5347, Val Acc: 0.8300 | Test Loss: 0.4198, Test Acc: 0.8751\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 286.53it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 226.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7641, Train Acc: 0.7380 | Val Loss: 0.4562, Val Acc: 0.8700 | Test Loss: 0.3544, Test Acc: 0.9112\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6471, Train Acc: 0.7910 | Val Loss: 0.4482, Val Acc: 0.8700 | Test Loss: 0.3651, Test Acc: 0.8991\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 334.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8340, Train Acc: 0.6840 | Val Loss: 0.4508, Val Acc: 0.8700 | Test Loss: 0.3402, Test Acc: 0.9061\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7337, Train Acc: 0.7370 | Val Loss: 0.5102, Val Acc: 0.8500 | Test Loss: 0.3820, Test Acc: 0.8842\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 239.82it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 206.90it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6604, Train Acc: 0.7740 | Val Loss: 0.4570, Val Acc: 0.8600 | Test Loss: 0.3271, Test Acc: 0.9144\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5684, Train Acc: 0.8120 | Val Loss: 0.4523, Val Acc: 0.8800 | Test Loss: 0.3398, Test Acc: 0.9042\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 231.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7882, Train Acc: 0.7170 | Val Loss: 0.4678, Val Acc: 0.8600 | Test Loss: 0.3361, Test Acc: 0.9051\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6653, Train Acc: 0.7720 | Val Loss: 0.5171, Val Acc: 0.8700 | Test Loss: 0.3855, Test Acc: 0.8826\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 253.09it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 157.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6591, Train Acc: 0.7630 | Val Loss: 0.4493, Val Acc: 0.8700 | Test Loss: 0.3114, Test Acc: 0.9183\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5425, Train Acc: 0.8030 | Val Loss: 0.4672, Val Acc: 0.8500 | Test Loss: 0.3352, Test Acc: 0.9072\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 270.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 181.89it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7664, Train Acc: 0.7250 | Val Loss: 0.4775, Val Acc: 0.8500 | Test Loss: 0.3362, Test Acc: 0.8991\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6181, Train Acc: 0.7820 | Val Loss: 0.5560, Val Acc: 0.8500 | Test Loss: 0.4202, Test Acc: 0.8699\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.38it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 194.03it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6099, Train Acc: 0.7790 | Val Loss: 0.4685, Val Acc: 0.8500 | Test Loss: 0.3134, Test Acc: 0.9141\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4785, Train Acc: 0.8240 | Val Loss: 0.4832, Val Acc: 0.8500 | Test Loss: 0.3229, Test Acc: 0.9086\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 237.92it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 207.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6686, Train Acc: 0.7480 | Val Loss: 0.4686, Val Acc: 0.8900 | Test Loss: 0.3158, Test Acc: 0.9050\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5321, Train Acc: 0.8080 | Val Loss: 0.5199, Val Acc: 0.8700 | Test Loss: 0.3891, Test Acc: 0.8786\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 222.44it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 201.94it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5071, Train Acc: 0.8110 | Val Loss: 0.4610, Val Acc: 0.8500 | Test Loss: 0.3025, Test Acc: 0.9123\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4012, Train Acc: 0.8750 | Val Loss: 0.4707, Val Acc: 0.8600 | Test Loss: 0.2943, Test Acc: 0.9146\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 308.39it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 232.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5766, Train Acc: 0.7790 | Val Loss: 0.4617, Val Acc: 0.8700 | Test Loss: 0.2930, Test Acc: 0.9119\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4693, Train Acc: 0.8390 | Val Loss: 0.5142, Val Acc: 0.8600 | Test Loss: 0.3670, Test Acc: 0.8808\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 274.05it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 197.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4960, Train Acc: 0.8180 | Val Loss: 0.4540, Val Acc: 0.8700 | Test Loss: 0.2898, Test Acc: 0.9118\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4054, Train Acc: 0.8660 | Val Loss: 0.4752, Val Acc: 0.8500 | Test Loss: 0.3064, Test Acc: 0.9024\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.20it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 178.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5778, Train Acc: 0.7750 | Val Loss: 0.4653, Val Acc: 0.8700 | Test Loss: 0.3003, Test Acc: 0.9035\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4462, Train Acc: 0.8420 | Val Loss: 0.5028, Val Acc: 0.8500 | Test Loss: 0.3616, Test Acc: 0.8847\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 322.66it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 251.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.4424, Train Acc: 0.8460 | Val Loss: 0.4405, Val Acc: 0.8700 | Test Loss: 0.2833, Test Acc: 0.9179\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3239, Train Acc: 0.9070 | Val Loss: 0.4575, Val Acc: 0.8500 | Test Loss: 0.2970, Test Acc: 0.9049\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 254.31it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5640, Train Acc: 0.7890 | Val Loss: 0.4459, Val Acc: 0.8700 | Test Loss: 0.2935, Test Acc: 0.9054\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3988, Train Acc: 0.8660 | Val Loss: 0.4910, Val Acc: 0.8500 | Test Loss: 0.3670, Test Acc: 0.8859\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 290.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 176.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5087, Train Acc: 0.8130 | Val Loss: 0.4275, Val Acc: 0.8700 | Test Loss: 0.2666, Test Acc: 0.9176\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3355, Train Acc: 0.8870 | Val Loss: 0.4604, Val Acc: 0.8500 | Test Loss: 0.2956, Test Acc: 0.9025\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 364.78it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 198.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6048, Train Acc: 0.7560 | Val Loss: 0.4526, Val Acc: 0.8600 | Test Loss: 0.2957, Test Acc: 0.9039\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3719, Train Acc: 0.8780 | Val Loss: 0.4888, Val Acc: 0.8700 | Test Loss: 0.3734, Test Acc: 0.8856\n",
      "\n",
      "--- Outer Iteration 31/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 184.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.14it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5164, Train Acc: 0.8000 | Val Loss: 0.4319, Val Acc: 0.8600 | Test Loss: 0.2716, Test Acc: 0.9149\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.3176, Train Acc: 0.8900 | Val Loss: 0.4552, Val Acc: 0.8400 | Test Loss: 0.2920, Test Acc: 0.9098\n",
      "\n",
      "--- Outer Iteration 32/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 309.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.5972, Train Acc: 0.7830 | Val Loss: 0.4611, Val Acc: 0.8700 | Test Loss: 0.2884, Test Acc: 0.9050\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.9, epsilon=0.8: Test Loss: 0.3158, Test Accuracy: 0.9050\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.9, epsilon=0.8: Test Loss: 0.2884, Test Accuracy: 0.9050\n",
      "\n",
      "------------------------ Starting model training with num_base_model=10, rho=0.9, epsilon=1 ------------------------\n",
      "Base model predictions generated with 10 base models and nominal weights: tensor([0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000, 0.1000,\n",
      "        0.1000], device='cuda:0')\n",
      "\n",
      "Using a CNN model with Batch Normalization as feature extractor\n",
      "Feature Extractor Output Feature Size: 1024\n",
      "Initial - Test Loss: 1.8787, Test Acc: 0.6250\n",
      "Initial - Val Loss: 1.7445, Val Acc: 0.7100\n",
      "\n",
      "--- Outer Iteration 1/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 311.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 8.2384, Train Acc: 0.2430 | Val Loss: 1.3897, Val Acc: 0.6000 | Test Loss: 1.3302, Test Acc: 0.5669\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 6.1971, Train Acc: 0.2630 | Val Loss: 1.5318, Val Acc: 0.4500 | Test Loss: 1.3969, Test Acc: 0.5262\n",
      "\n",
      "--- Outer Iteration 2/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 283.46it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 5.7038, Train Acc: 0.1790 | Val Loss: 1.1824, Val Acc: 0.6600 | Test Loss: 1.0991, Test Acc: 0.6746\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 4.2841, Train Acc: 0.2280 | Val Loss: 1.3883, Val Acc: 0.6500 | Test Loss: 1.3392, Test Acc: 0.6596\n",
      "\n",
      "--- Outer Iteration 3/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 229.50it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 155.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 3.8694, Train Acc: 0.2920 | Val Loss: 1.2184, Val Acc: 0.5700 | Test Loss: 1.2139, Test Acc: 0.6198\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 3.0637, Train Acc: 0.3450 | Val Loss: 1.3305, Val Acc: 0.5500 | Test Loss: 1.3198, Test Acc: 0.5668\n",
      "\n",
      "--- Outer Iteration 4/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 248.51it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 156.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.6804, Train Acc: 0.2940 | Val Loss: 1.1035, Val Acc: 0.7000 | Test Loss: 1.0433, Test Acc: 0.7072\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.3062, Train Acc: 0.3590 | Val Loss: 1.2755, Val Acc: 0.6900 | Test Loss: 1.1845, Test Acc: 0.6943\n",
      "\n",
      "--- Outer Iteration 5/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.33it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 261.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.6450, Train Acc: 0.3770 | Val Loss: 1.0974, Val Acc: 0.6300 | Test Loss: 1.0548, Test Acc: 0.6627\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 2.1797, Train Acc: 0.4460 | Val Loss: 1.2517, Val Acc: 0.5500 | Test Loss: 1.1877, Test Acc: 0.5789\n",
      "\n",
      "--- Outer Iteration 6/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 289.91it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 140.24it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 2.2258, Train Acc: 0.3170 | Val Loss: 0.8505, Val Acc: 0.7100 | Test Loss: 0.8172, Test Acc: 0.7702\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.9321, Train Acc: 0.3940 | Val Loss: 0.8947, Val Acc: 0.7500 | Test Loss: 0.8153, Test Acc: 0.7708\n",
      "\n",
      "--- Outer Iteration 7/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.59it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6585, Train Acc: 0.5170 | Val Loss: 0.7712, Val Acc: 0.8000 | Test Loss: 0.7145, Test Acc: 0.8045\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4588, Train Acc: 0.5680 | Val Loss: 0.8427, Val Acc: 0.7500 | Test Loss: 0.7677, Test Acc: 0.7641\n",
      "\n",
      "--- Outer Iteration 8/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 256.14it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 152.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.6971, Train Acc: 0.4510 | Val Loss: 0.6911, Val Acc: 0.8100 | Test Loss: 0.5878, Test Acc: 0.8407\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.4819, Train Acc: 0.5190 | Val Loss: 0.7736, Val Acc: 0.7500 | Test Loss: 0.6559, Test Acc: 0.8022\n",
      "\n",
      "--- Outer Iteration 9/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 199.16it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 236.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5366, Train Acc: 0.5130 | Val Loss: 0.6474, Val Acc: 0.8300 | Test Loss: 0.5889, Test Acc: 0.8615\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3555, Train Acc: 0.5600 | Val Loss: 0.7234, Val Acc: 0.7900 | Test Loss: 0.6640, Test Acc: 0.8279\n",
      "\n",
      "--- Outer Iteration 10/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 242.70it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 216.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.5508, Train Acc: 0.4510 | Val Loss: 0.5694, Val Acc: 0.8400 | Test Loss: 0.4849, Test Acc: 0.8793\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.3398, Train Acc: 0.5530 | Val Loss: 0.6886, Val Acc: 0.8100 | Test Loss: 0.5650, Test Acc: 0.8343\n",
      "\n",
      "--- Outer Iteration 11/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 305.19it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 173.59it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2976, Train Acc: 0.5830 | Val Loss: 0.6119, Val Acc: 0.8300 | Test Loss: 0.5398, Test Acc: 0.8773\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.1644, Train Acc: 0.6200 | Val Loss: 0.6694, Val Acc: 0.8000 | Test Loss: 0.6012, Test Acc: 0.8503\n",
      "\n",
      "--- Outer Iteration 12/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 250.30it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.2382, Train Acc: 0.5620 | Val Loss: 0.5696, Val Acc: 0.8300 | Test Loss: 0.4652, Test Acc: 0.8833\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0921, Train Acc: 0.6280 | Val Loss: 0.6476, Val Acc: 0.7900 | Test Loss: 0.5290, Test Acc: 0.8381\n",
      "\n",
      "--- Outer Iteration 13/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 255.67it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 270.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1182, Train Acc: 0.6340 | Val Loss: 0.5586, Val Acc: 0.8500 | Test Loss: 0.4919, Test Acc: 0.8838\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9725, Train Acc: 0.6910 | Val Loss: 0.6249, Val Acc: 0.8300 | Test Loss: 0.5735, Test Acc: 0.8470\n",
      "\n",
      "--- Outer Iteration 14/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 173.64it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.1658, Train Acc: 0.5690 | Val Loss: 0.5323, Val Acc: 0.8400 | Test Loss: 0.4363, Test Acc: 0.8931\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 1.0074, Train Acc: 0.6570 | Val Loss: 0.6185, Val Acc: 0.8200 | Test Loss: 0.5097, Test Acc: 0.8503\n",
      "\n",
      "--- Outer Iteration 15/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 294.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 200.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0421, Train Acc: 0.6580 | Val Loss: 0.5419, Val Acc: 0.8300 | Test Loss: 0.4570, Test Acc: 0.8845\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.9138, Train Acc: 0.7010 | Val Loss: 0.5980, Val Acc: 0.8200 | Test Loss: 0.5370, Test Acc: 0.8346\n",
      "\n",
      "--- Outer Iteration 16/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 264.47it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 208.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 1.0343, Train Acc: 0.6240 | Val Loss: 0.5231, Val Acc: 0.8400 | Test Loss: 0.4107, Test Acc: 0.8909\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8579, Train Acc: 0.6890 | Val Loss: 0.5794, Val Acc: 0.8400 | Test Loss: 0.4820, Test Acc: 0.8522\n",
      "\n",
      "--- Outer Iteration 17/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 356.75it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 205.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9928, Train Acc: 0.6540 | Val Loss: 0.5119, Val Acc: 0.8400 | Test Loss: 0.4346, Test Acc: 0.8907\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.8403, Train Acc: 0.7200 | Val Loss: 0.5792, Val Acc: 0.8100 | Test Loss: 0.5263, Test Acc: 0.8393\n",
      "\n",
      "--- Outer Iteration 18/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 301.17it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 247.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8707, Train Acc: 0.6880 | Val Loss: 0.4995, Val Acc: 0.8400 | Test Loss: 0.3884, Test Acc: 0.8971\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7205, Train Acc: 0.7510 | Val Loss: 0.5701, Val Acc: 0.8200 | Test Loss: 0.4470, Test Acc: 0.8656\n",
      "\n",
      "--- Outer Iteration 19/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 310.84it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 170.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9120, Train Acc: 0.6750 | Val Loss: 0.4928, Val Acc: 0.8300 | Test Loss: 0.3965, Test Acc: 0.8931\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7732, Train Acc: 0.7380 | Val Loss: 0.5316, Val Acc: 0.8100 | Test Loss: 0.4765, Test Acc: 0.8452\n",
      "\n",
      "--- Outer Iteration 20/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 239.97it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 158.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8799, Train Acc: 0.6860 | Val Loss: 0.4823, Val Acc: 0.8700 | Test Loss: 0.3700, Test Acc: 0.9001\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6703, Train Acc: 0.7720 | Val Loss: 0.5690, Val Acc: 0.8000 | Test Loss: 0.4535, Test Acc: 0.8668\n",
      "\n",
      "--- Outer Iteration 21/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 240.02it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.9074, Train Acc: 0.6670 | Val Loss: 0.4850, Val Acc: 0.8300 | Test Loss: 0.3892, Test Acc: 0.8922\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.7259, Train Acc: 0.7430 | Val Loss: 0.5234, Val Acc: 0.7900 | Test Loss: 0.4703, Test Acc: 0.8528\n",
      "\n",
      "--- Outer Iteration 22/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 213.25it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 161.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.8096, Train Acc: 0.7150 | Val Loss: 0.4896, Val Acc: 0.8300 | Test Loss: 0.3789, Test Acc: 0.8943\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6108, Train Acc: 0.7910 | Val Loss: 0.5605, Val Acc: 0.8200 | Test Loss: 0.4647, Test Acc: 0.8631\n",
      "\n",
      "--- Outer Iteration 23/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 182.41it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 175.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7689, Train Acc: 0.7220 | Val Loss: 0.4818, Val Acc: 0.8300 | Test Loss: 0.3755, Test Acc: 0.8963\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.6254, Train Acc: 0.8000 | Val Loss: 0.5074, Val Acc: 0.8300 | Test Loss: 0.4260, Test Acc: 0.8597\n",
      "\n",
      "--- Outer Iteration 24/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.48it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 177.10it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7337, Train Acc: 0.7360 | Val Loss: 0.4730, Val Acc: 0.8700 | Test Loss: 0.3530, Test Acc: 0.9007\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4845, Train Acc: 0.8360 | Val Loss: 0.5356, Val Acc: 0.8300 | Test Loss: 0.4256, Test Acc: 0.8774\n",
      "\n",
      "--- Outer Iteration 25/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 272.17it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 209.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7366, Train Acc: 0.7270 | Val Loss: 0.4456, Val Acc: 0.8500 | Test Loss: 0.3423, Test Acc: 0.9090\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5514, Train Acc: 0.7970 | Val Loss: 0.4757, Val Acc: 0.8200 | Test Loss: 0.3923, Test Acc: 0.8776\n",
      "\n",
      "--- Outer Iteration 26/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 209.93it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 195.63it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.7277, Train Acc: 0.7410 | Val Loss: 0.4782, Val Acc: 0.8700 | Test Loss: 0.3481, Test Acc: 0.8979\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.5402, Train Acc: 0.8070 | Val Loss: 0.5462, Val Acc: 0.8200 | Test Loss: 0.4181, Test Acc: 0.8718\n",
      "\n",
      "--- Outer Iteration 27/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 152.21it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 180.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6352, Train Acc: 0.7660 | Val Loss: 0.4619, Val Acc: 0.8500 | Test Loss: 0.3404, Test Acc: 0.9057\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4643, Train Acc: 0.8590 | Val Loss: 0.4906, Val Acc: 0.8400 | Test Loss: 0.4017, Test Acc: 0.8641\n",
      "\n",
      "--- Outer Iteration 28/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 279.94it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 189.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6403, Train Acc: 0.7620 | Val Loss: 0.4741, Val Acc: 0.8700 | Test Loss: 0.3394, Test Acc: 0.8957\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4496, Train Acc: 0.8460 | Val Loss: 0.5749, Val Acc: 0.8300 | Test Loss: 0.4645, Test Acc: 0.8596\n",
      "\n",
      "--- Outer Iteration 29/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 307.22it/s]\n",
      "100%|██████████| 10/10 [00:00<00:00, 156.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6412, Train Acc: 0.7620 | Val Loss: 0.4456, Val Acc: 0.8600 | Test Loss: 0.3263, Test Acc: 0.9072\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2/2 - Train Loss: 0.4342, Train Acc: 0.8400 | Val Loss: 0.4853, Val Acc: 0.8300 | Test Loss: 0.3888, Test Acc: 0.8737\n",
      "\n",
      "--- Outer Iteration 30/150 ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 331.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/2 - Train Loss: 0.6987, Train Acc: 0.7440 | Val Loss: 0.4958, Val Acc: 0.8600 | Test Loss: 0.3471, Test Acc: 0.8945\n",
      "Early stopping at Epoch 1\n",
      "Best Val-Test Results for num_base_model=10, rho=0.9, epsilon=1: Test Loss: 0.3700, Test Accuracy: 0.9001\n",
      "\n",
      "Last Test Results for num_base_model=10, rho=0.9, epsilon=1: Test Loss: 0.3471, Test Accuracy: 0.8945\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"------------------------------------ Starting Main Code ------------------------------------\\n\")\n",
    "max_outer_iteration = 150\n",
    "# ================== Prediction ==================\n",
    "train_data_loader = dataloaders[\"target_train\"]\n",
    "test_data_loader = dataloaders[\"target_test\"]\n",
    "\n",
    "timestamp = datetime.datetime.now().strftime('%Y%m%d_%H%M')\n",
    "\n",
    "base_predictions = get_classifier_predictions(\n",
    "    classifiers=classifiers, \n",
    "    feature_extractor=ERM_feature_map, \n",
    "    unlabeled_loader=train_data_loader, \n",
    "    device=device\n",
    ")\n",
    "nominal_weights = torch.full((num_base_model,), 1 / num_base_model).to(device)\n",
    "\n",
    "\n",
    "base_model_results = []\n",
    "for rho in rho_values:  # rho 값 반복\n",
    "    for epsilon in epsilon_values:  # epsilon 값 반복\n",
    "        print(f\"------------------------ Starting model training with num_base_model={num_base_model}, rho={rho}, epsilon={epsilon} ------------------------\")\n",
    "        print(f\"Base model predictions generated with {num_base_model} base models and nominal weights: {nominal_weights}\\n\")\n",
    "\n",
    "        # model 초기화\n",
    "        checkpoint = torch.load(default_path, map_location=device)\n",
    "        models, optimizers = get_erm_model(\n",
    "            device, n_class=n_class,\n",
    "            weight_decay=0, \n",
    "            n_channel=n_channel\n",
    "        )\n",
    "        models[\"G\"].load_state_dict(checkpoint[\"G\"])\n",
    "        models[\"C\"].load_state_dict(checkpoint[\"C\"])\n",
    "                \n",
    "        models_copy = copy.deepcopy(models)\n",
    "        models_copy[\"G\"] = models[\"G\"].to(device)\n",
    "        models_copy[\"C\"] = models[\"C\"].to(device)\n",
    "\n",
    "        optimizer_G = torch.optim.Adam(models_copy[\"G\"].parameters(), lr=base_model_lr, weight_decay=base_model_weight_decay)\n",
    "        optimizer_C = torch.optim.Adam(models_copy[\"C\"].parameters(), lr=base_model_lr, weight_decay=base_model_weight_decay)\n",
    "        optimizers_copy = [optimizer_G, optimizer_C]\n",
    "        \n",
    "        # 학습 및 평가\n",
    "        trained_model, val_best_test_acc, best_val_loss, best_test_loss, _ = train_model_batch(\n",
    "            models_copy, optimizers_copy, loss_fn, dataloaders, base_predictions, nominal_weights, device,\n",
    "            num_epochs=base_model_epochs, model_batch_size=batch_size, max_outer_iteration=max_outer_iteration,\n",
    "            threshold=1e-10, rho=rho, lr_weight=0.05, scheduler=None, epsilon=epsilon\n",
    "        )            \n",
    "        \n",
    "        # 마지막 테스트 결과\n",
    "        test_loss, test_accuracy = test_model(test_data_loader, trained_model, device)\n",
    "\n",
    "        print(f\"Best Val-Test Results for num_base_model={num_base_model}, rho={rho}, epsilon={epsilon}: Test Loss: {best_test_loss:.4f}, Test Accuracy: {val_best_test_acc:.4f}\\n\")\n",
    "        print(f\"Last Test Results for num_base_model={num_base_model}, rho={rho}, epsilon={epsilon}: Test Loss: {test_loss:.4f}, Test Accuracy: {test_accuracy:.4f}\\n\")\n",
    "\n",
    "        \n",
    "        # 결과 저장\n",
    "        base_model_results.append(\n",
    "            (num_base_model, rho, epsilon, best_test_loss, val_best_test_acc, test_loss, test_accuracy)\n",
    "        )\n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---- Final Results ----\n",
      "num_base_model=10, rho=0, epsilon=0 | Val-Best Test Loss=2.1299, Val-Best Test Acc=0.6373 | Last Test Loss=2.3344, Last Test Acc=0.6466\n",
      "num_base_model=10, rho=0, epsilon=0.2 | Val-Best Test Loss=0.3902, Val-Best Test Acc=0.8946 | Last Test Loss=0.4152, Last Test Acc=0.8959\n",
      "num_base_model=10, rho=0, epsilon=0.4 | Val-Best Test Loss=0.2916, Val-Best Test Acc=0.9130 | Last Test Loss=0.2716, Last Test Acc=0.9239\n",
      "num_base_model=10, rho=0, epsilon=0.6 | Val-Best Test Loss=0.4389, Val-Best Test Acc=0.8785 | Last Test Loss=0.2853, Last Test Acc=0.9122\n",
      "num_base_model=10, rho=0, epsilon=0.8 | Val-Best Test Loss=0.3124, Val-Best Test Acc=0.9074 | Last Test Loss=0.3172, Last Test Acc=0.8967\n",
      "num_base_model=10, rho=0, epsilon=1 | Val-Best Test Loss=0.3643, Val-Best Test Acc=0.8937 | Last Test Loss=0.4081, Last Test Acc=0.8712\n",
      "num_base_model=10, rho=0.2, epsilon=0 | Val-Best Test Loss=1.8423, Val-Best Test Acc=0.6561 | Last Test Loss=2.1443, Last Test Acc=0.6450\n",
      "num_base_model=10, rho=0.2, epsilon=0.2 | Val-Best Test Loss=0.4998, Val-Best Test Acc=0.8643 | Last Test Loss=0.4010, Last Test Acc=0.8944\n",
      "num_base_model=10, rho=0.2, epsilon=0.4 | Val-Best Test Loss=0.4133, Val-Best Test Acc=0.8849 | Last Test Loss=0.3284, Last Test Acc=0.9104\n",
      "num_base_model=10, rho=0.2, epsilon=0.6 | Val-Best Test Loss=0.2558, Val-Best Test Acc=0.9225 | Last Test Loss=0.2384, Last Test Acc=0.9273\n",
      "num_base_model=10, rho=0.2, epsilon=0.8 | Val-Best Test Loss=0.3503, Val-Best Test Acc=0.8940 | Last Test Loss=0.3507, Last Test Acc=0.8897\n",
      "num_base_model=10, rho=0.2, epsilon=1 | Val-Best Test Loss=0.4330, Val-Best Test Acc=0.8586 | Last Test Loss=0.3876, Last Test Acc=0.8687\n",
      "num_base_model=10, rho=0.4, epsilon=0 | Val-Best Test Loss=1.9171, Val-Best Test Acc=0.6472 | Last Test Loss=2.2220, Last Test Acc=0.6424\n",
      "num_base_model=10, rho=0.4, epsilon=0.2 | Val-Best Test Loss=0.4699, Val-Best Test Acc=0.8710 | Last Test Loss=0.4063, Last Test Acc=0.8935\n",
      "num_base_model=10, rho=0.4, epsilon=0.4 | Val-Best Test Loss=0.4115, Val-Best Test Acc=0.8831 | Last Test Loss=0.3147, Last Test Acc=0.9097\n",
      "num_base_model=10, rho=0.4, epsilon=0.6 | Val-Best Test Loss=0.2650, Val-Best Test Acc=0.9184 | Last Test Loss=0.2500, Last Test Acc=0.9226\n",
      "num_base_model=10, rho=0.4, epsilon=0.8 | Val-Best Test Loss=0.2961, Val-Best Test Acc=0.9118 | Last Test Loss=0.2895, Last Test Acc=0.9109\n",
      "num_base_model=10, rho=0.4, epsilon=1 | Val-Best Test Loss=0.3479, Val-Best Test Acc=0.9015 | Last Test Loss=0.3583, Last Test Acc=0.8856\n",
      "num_base_model=10, rho=0.6, epsilon=0 | Val-Best Test Loss=1.9256, Val-Best Test Acc=0.6512 | Last Test Loss=2.1043, Last Test Acc=0.6573\n",
      "num_base_model=10, rho=0.6, epsilon=0.2 | Val-Best Test Loss=0.4940, Val-Best Test Acc=0.8681 | Last Test Loss=0.4262, Last Test Acc=0.8872\n",
      "num_base_model=10, rho=0.6, epsilon=0.4 | Val-Best Test Loss=0.4357, Val-Best Test Acc=0.8829 | Last Test Loss=0.3277, Last Test Acc=0.9062\n",
      "num_base_model=10, rho=0.6, epsilon=0.6 | Val-Best Test Loss=0.3149, Val-Best Test Acc=0.9051 | Last Test Loss=0.3297, Last Test Acc=0.9043\n",
      "num_base_model=10, rho=0.6, epsilon=0.8 | Val-Best Test Loss=0.3284, Val-Best Test Acc=0.9049 | Last Test Loss=0.3017, Last Test Acc=0.9062\n",
      "num_base_model=10, rho=0.6, epsilon=1 | Val-Best Test Loss=0.4191, Val-Best Test Acc=0.8739 | Last Test Loss=0.3753, Last Test Acc=0.8832\n",
      "num_base_model=10, rho=0.9, epsilon=0 | Val-Best Test Loss=1.8295, Val-Best Test Acc=0.6552 | Last Test Loss=2.0821, Last Test Acc=0.6559\n",
      "num_base_model=10, rho=0.9, epsilon=0.2 | Val-Best Test Loss=0.3546, Val-Best Test Acc=0.9057 | Last Test Loss=0.3593, Last Test Acc=0.9093\n",
      "num_base_model=10, rho=0.9, epsilon=0.4 | Val-Best Test Loss=0.3122, Val-Best Test Acc=0.9059 | Last Test Loss=0.2563, Last Test Acc=0.9230\n",
      "num_base_model=10, rho=0.9, epsilon=0.6 | Val-Best Test Loss=0.3064, Val-Best Test Acc=0.9109 | Last Test Loss=0.2474, Last Test Acc=0.9226\n",
      "num_base_model=10, rho=0.9, epsilon=0.8 | Val-Best Test Loss=0.3158, Val-Best Test Acc=0.9050 | Last Test Loss=0.2884, Last Test Acc=0.9050\n",
      "num_base_model=10, rho=0.9, epsilon=1 | Val-Best Test Loss=0.3700, Val-Best Test Acc=0.9001 | Last Test Loss=0.3471, Last Test Acc=0.8945\n",
      "Results saved to ./Ours_results/s2m/20250923_2357_s2m_ERM_max_iter_150_latent_True_u100.csv\n"
     ]
    }
   ],
   "source": [
    "# 모든 결과 출력\n",
    "save_and_print_results(\n",
    "    base_model_results=base_model_results,\n",
    "    timestamp=timestamp,\n",
    "    dataset=dataset,\n",
    "    type_base_model=type_base_model,\n",
    "    max_outer_iteration=max_outer_iteration,\n",
    "    latent=latent,\n",
    "    seed = seed,\n",
    "    u=u\n",
    ")\n",
    "\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
