{
	"cells": [
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"# UCI Dataset: Wine Quality"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 1,
			"metadata": {},
			"outputs": [],
			"source": [
				"import os\n",
				"os.environ[\"PYTHONWARNINGS\"] = \"ignore\"\n",
				"\n",
				"import warnings\n",
				"warnings.filterwarnings('ignore')\n",
				"\n",
				"import sys\n",
				"sys.path.append(os.path.abspath(os.path.join(os.getcwd(), os.pardir)))\n",
				"\n",
				"import random\n",
				"\n",
				"import torch\n",
				"import torch.nn as nn\n",
				"from torch.utils.data import Dataset, DataLoader, Subset, ConcatDataset\n",
				"\n",
				"from sklearn.preprocessing import LabelEncoder\n",
				"from ucimlrepo import fetch_ucirepo\n",
				"\n",
				"from sklearn.neighbors import KernelDensity\n",
				"\n",
				"from tqdm import tqdm\n",
				"\n",
				"import numpy as np\n",
				"import cupy as cp\n",
				"import matplotlib.pyplot as plt\n",
				"\n",
				"from joblib import Parallel, delayed\n",
				"\n",
				"import ld\n",
				"from utils import vectorize_tensor, reconstruct_tensor\n",
				"\n",
				"device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"## Setup"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### General"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 2,
			"metadata": {},
			"outputs": [],
			"source": [
				"def set_random_seed(seed):\n",
				"    random.seed(seed)\n",
				"    np.random.seed(seed)\n",
				"\n",
				"    torch.manual_seed(seed)\n",
				"    if torch.cuda.is_available():\n",
				"        torch.cuda.manual_seed(seed)\n",
				"\n",
				"    cp.random.seed(seed)\n",
				"\n",
				"    torch.backends.cudnn.deterministic = True\n",
				"    torch.backends.cudnn.benchmark = False\n",
				"\n",
				"set_random_seed(42)\n",
				"k = 5\n",
				"bandwidth = 0.05\n",
				"bandwidth_AE = 0.05\n",
				"eps = np.asarray(1.0e-5)"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### Dataset"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 3,
			"metadata": {},
			"outputs": [],
			"source": [
				"class NumpyDataset(Dataset):\n",
				"    def __init__(self, features, labels, transform=None):\n",
				"        \"\"\"\n",
				"        Args:\n",
				"            features (np.ndarray): Feature matrix.\n",
				"            labels (np.ndarray): Label array.\n",
				"            transform (callable, optional): Optional transform to be applied\n",
				"                on a sample.\n",
				"        \"\"\"\n",
				"        self.features = torch.tensor(features, dtype=torch.float32)\n",
				"        self.labels = torch.tensor(labels, dtype=torch.long)\n",
				"        self.transform = transform\n",
				"\n",
				"    def __len__(self):\n",
				"        return len(self.labels)\n",
				"\n",
				"    def __getitem__(self, idx):\n",
				"        sample = self.features[idx]\n",
				"        label = self.labels[idx]\n",
				"\n",
				"        if self.transform:\n",
				"            sample = self.transform(sample)\n",
				"\n",
				"        return sample, label\n",
				"\n",
				"# Normalize transform for UCI dataset\n",
				"class Normalize:\n",
				"    def __init__(self, mean, std):\n",
				"        self.mean = torch.tensor(mean, dtype=torch.float32)\n",
				"        self.std = torch.tensor(std, dtype=torch.float32)\n",
				"\n",
				"    def __call__(self, sample):\n",
				"        # std is 0 for constant features, so we add a small epsilon to avoid division by zero\n",
				"        return (sample - self.mean) / (self.std + eps)\n",
				"\n",
				"# Custom transformation for adding Gaussian noise\n",
				"class AddGaussianNoise:\n",
				"    def __init__(self, mean=0.0, std=0.1):\n",
				"        self.mean = mean\n",
				"        self.std = std\n",
				"\n",
				"    def __call__(self, sample):\n",
				"        noise = torch.randn_like(sample) * self.std + self.mean\n",
				"        return sample + noise\n",
				"\n",
				"# Composite transformation to combine Normalize and AddGaussianNoise\n",
				"class CompositeTransform:\n",
				"    def __init__(self, transforms):\n",
				"        \"\"\"\n",
				"        Args:\n",
				"            transforms (list): List of transformations to apply in sequence.\n",
				"        \"\"\"\n",
				"        self.transforms = transforms\n",
				"\n",
				"    def __call__(self, sample):\n",
				"        for transform in self.transforms:\n",
				"            sample = transform(sample)\n",
				"        return sample"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 4,
			"metadata": {},
			"outputs": [],
			"source": [
				"UCI_id = 186 # https://archive.ics.uci.edu/dataset/186/wine-quality\n",
				"test_size = 0.2\n",
				"\n",
				"UCI_dataset = fetch_ucirepo(id=UCI_id)\n",
				"\n",
				"X = np.array(UCI_dataset.data.features)\n",
				"Y = np.array(LabelEncoder().fit_transform(UCI_dataset.data.targets))\n",
				"\n",
				"# normalize to [0, 1]\n",
				"X = (X - X.min()) / (X.max() - X.min())\n",
				"\n",
				"# extend features to 12 dimensions\n",
				"X = np.pad(X, ((0, 0), (0, 12 - X.shape[1])), mode=\"constant\")\n",
				"\n",
				"# Find unique labels\n",
				"unique_labels = np.unique(Y)\n",
				"\n",
				"# Create an array of indices\n",
				"indices = np.arange(len(Y))\n",
				"np.random.shuffle(indices)\n",
				"\n",
				"# Use the shuffled indices to randomly select data for training and testing\n",
				"n_train = int(len(Y) * (1 - test_size))\n",
				"X_train, Y_train = X[indices[:n_train]], Y[indices[:n_train]]\n",
				"X_test, Y_test = X[indices[n_train:]], Y[indices[n_train:]]\n",
				"\n",
				"X_train_class = []\n",
				"Y_train_class = []\n",
				"for i in unique_labels:\n",
				"    X_train_class.append(X_train[np.isin(Y_train, i).flatten()])\n",
				"    Y_train_class.append(Y_train[np.isin(Y_train, i).flatten()])\n",
				"\n",
				"mean = X_train.mean(axis=0)\n",
				"std = X_train.std(axis=0)\n",
				"\n",
				"train_dataset = NumpyDataset(X_train, Y_train, transform=Normalize(mean, std))\n",
				"test_dataset = NumpyDataset(X_test, Y_test, transform=Normalize(mean, std))"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 5,
			"metadata": {},
			"outputs": [
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Train size: 5197\n",
						"Test size: 1300\n",
						"New sample size: 1036\n",
						"Number of classes: 7\n",
						"Number of features: 11\n"
					]
				}
			],
			"source": [
				"D = X_train.shape[1]\n",
				"S = (2, 2, 3)\n",
				"\n",
				"if np.prod(S) != D:\n",
				"    raise ValueError(\"The product of the tensor structure is not equal to the feature dimension\")\n",
				"\n",
				"new_sample_size_per_class = int(n_train * 0.2 // len(unique_labels))\n",
				"\n",
				"# Print dataset statistics\n",
				"print(f\"Train size: {len(train_dataset)}\")\n",
				"print(f\"Test size: {len(test_dataset)}\")\n",
				"print(f\"New sample size: {new_sample_size_per_class * len(unique_labels)}\")\n",
				"print(f\"Number of classes: {len(unique_labels)}\")\n",
				"print(f\"Number of features: {D-1}\")"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"## Pseudo-Non-Linear Data Augmentation"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### Legendre Decomposition (Many-Body Approximation)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 6,
			"metadata": {},
			"outputs": [
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Dimension of Base Sub-Manifold: 10\n"
					]
				}
			],
			"source": [
				"B_LD = ld.default_B(S, 2, cp.get_array_module(X_train[0]))\n",
				"print(f\"Dimension of Base Sub-Manifold: {B_LD.shape[0]}\")\n",
				"\n",
				"scaleX_class = []\n",
				"theta_class = []\n",
				"\n",
				"def LD_helper(i, class_):\n",
				"    _, _, scaleX, _, theta = ld.LD(X_train_class[class_][i].reshape(*S), B=B_LD, verbose=False, n_iter=1000, lr=1e-1)\n",
				"    return (scaleX, theta)\n",
				"\n",
				"results = Parallel(n_jobs=30)(delayed(LD_helper)(i, class_) for class_ in unique_labels for i in range(len(X_train_class[class_])))\n",
				"\n",
				"len_class = 0\n",
				"for class_ in unique_labels:\n",
				"    scaleX_list = []\n",
				"    theta_list = []\n",
				"\n",
				"    for i in range(len(X_train_class[class_])):\n",
				"        result = results[i + len_class]\n",
				"\n",
				"        scaleX_list.append(result[0])\n",
				"        theta_list.append(result[1])\n",
				"\n",
				"    len_class += len(X_train_class[class_])\n",
				"\n",
				"    scaleX_class.append(scaleX_list)\n",
				"    theta_class.append(theta_list)"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"#### Fitting on Projected Points"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 7,
			"metadata": {},
			"outputs": [],
			"source": [
				"sampled_theta_class = []\n",
				"\n",
				"for class_ in unique_labels:\n",
				"    reduced_theta = vectorize_tensor(np.array(theta_class[class_]), B_LD)\n",
				"\n",
				"    # Fit a KDE to the theta values\n",
				"    kde = KernelDensity(kernel='gaussian', bandwidth=bandwidth).fit(reduced_theta)\n",
				"    # Sample new data from the KDE\n",
				"    sampled_reduced_theta = kde.sample(n_samples=new_sample_size_per_class)\n",
				"\n",
				"    sampled_theta = reconstruct_tensor(sampled_reduced_theta, (new_sample_size_per_class, *S), B_LD)\n",
				"\n",
				"    sampled_theta_class.append(sampled_theta)"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"#### Construct Local Data Sub-Manifold"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 8,
			"metadata": {},
			"outputs": [
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Dimension of Local Data Sub-Manifold: 7\n"
					]
				}
			],
			"source": [
				"# Construct the constrained coordinates\n",
				"B_BP = ld.default_B(S, 1, cp.get_array_module(X_train[0]))\n",
				"print(f\"Dimension of Local Data Sub-Manifold: {D - B_BP.shape[0]}\")\n",
				"\n",
				"# Compute every datapoint's eta_hat (served as the linear constraints)\n",
				"eta_hat_class = []\n",
				"\n",
				"for class_ in unique_labels:\n",
				"    eta_hat_list = []\n",
				"    for i in range(X_train_class[class_].shape[0]):\n",
				"        xp = cp.get_array_module(X_train_class[class_][i])\n",
				"        P = (X_train_class[class_][i].reshape(*S) + eps) / scaleX_class[class_][i]\n",
				"        eta_hat = ld.get_eta(P, len(S), xp)\n",
				"        eta_hat_list.append(eta_hat)\n",
				"    eta_hat_list = cp.asarray(eta_hat_list)\n",
				"\n",
				"    eta_hat_class.append(eta_hat_list)"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"#### Backward Projection"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 9,
			"metadata": {},
			"outputs": [
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n",
						"Warning: Not Converged. Consider increasing the number of iterations.\n"
					]
				}
			],
			"source": [
				"def BP_helper(i, class_):\n",
				"    N = ld.kNN(sampled_theta_class[class_][i], np.array(theta_class[class_]), k=k)\n",
				"    avg_scale = np.mean(np.array(scaleX_class[class_])[N])\n",
				"    avg_eta_hat = np.mean(eta_hat_class[class_][N], axis=0)\n",
				"\n",
				"    _, _, P, theta = ld.BP(sampled_theta_class[class_][i], [(X_train_class[class_][j].reshape(*S) + eps) / scaleX_class[class_][j] for j in N], avg_eta_hat, avg_scale, B=B_BP, verbose=False, n_iter=1000, lr=5e-2, exit_abs=True)\n",
				"    X_recons_ = P.reshape(-1)\n",
				"    return (theta, X_recons_)\n",
				"\n",
				"results = Parallel(n_jobs=30)(delayed(BP_helper)(i, class_) for i in range(new_sample_size_per_class) for class_ in unique_labels)\n",
				"\n",
				"sampled_theta_BP_class = []\n",
				"sampled_X_BP_class = []\n",
				"\n",
				"for class_ in unique_labels:\n",
				"    sampled_theta_BP = []\n",
				"    sampled_X_BP = []\n",
				"    for i in range(new_sample_size_per_class):\n",
				"        result = results[i + new_sample_size_per_class * class_]\n",
				"\n",
				"        sampled_theta_BP.append(result[0])\n",
				"        sampled_X_BP.append(result[1])\n",
				"\n",
				"    sampled_theta_BP_class.append(np.array(sampled_theta_BP))\n",
				"    sampled_X_BP_class.append(np.array(sampled_X_BP))"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"## Data Augmentation with Autoencoder"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 10,
			"metadata": {},
			"outputs": [],
			"source": [
				"class Encoder(nn.Module):\n",
				"    def __init__(self, input_size=D, hidden_size=B_LD.shape[0], z_dim=3):\n",
				"        super().__init__()\n",
				"        self.fc1 = nn.Linear(input_size, hidden_size)\n",
				"        self.fc2 = nn.Linear(hidden_size, z_dim)\n",
				"        self.relu = nn.ReLU()\n",
				"    def forward(self , x):\n",
				"        x = self.relu(self.fc1(x))\n",
				"        x = self.fc2(x)\n",
				"        return x\n",
				"\n",
				"class Decoder(nn.Module):\n",
				"    def __init__(self, output_size=D, hidden_size=B_LD.shape[0], z_dim=3):\n",
				"        super().__init__()\n",
				"        self.fc1 = nn.Linear(z_dim , hidden_size)\n",
				"        self.fc2 = nn.Linear(hidden_size, output_size)\n",
				"        self.relu = nn.ReLU()\n",
				"    def forward(self , x):\n",
				"        x = self.relu(self.fc1(x))\n",
				"        x = torch.sigmoid(self.fc2(x))\n",
				"        return x"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 11,
			"metadata": {},
			"outputs": [
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 200/200 [02:01<00:00,  1.65it/s]\n"
					]
				},
				{
					"data": {
						"text/plain": [
							"[<matplotlib.lines.Line2D at 0x7f6b82068f90>]"
						]
					},
					"execution_count": 11,
					"metadata": {},
					"output_type": "execute_result"
				},
				{
					"data": {
						"image/png": "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FJ9++im2b9+O2NjYK55rMpkQHx+PnJwcH1XnPUFBQRgwYABycnJcs166yv3My8vD1q1b8eCDD17xvM58/wBc030zGo2w2WwoKyu77DmdQV1dHe677z7k5uZiy5YtV31U+eDBg6FWqzvlvb3057Kr3EMA+Pbbb3H06NGr/m4CHfMeXu7zoaP8Lnb58KHRaJCSktKsOWzLli0YNmyYTFW1jRACjzzyCDZu3Iht27YhISHhqq8pLS1FQUEBTCaTDyr0LqvVisOHD8NkMrmaOpveT5vNhvT09E55P1euXImoqChMnDjxiud15vsH4JruW0pKCtRqtds5hYWFOHToUKe5t43BIycnB1u3bkV4ePhVX5OdnY26urpOeW8v/bnsCvew0fvvv4+UlBQMHDjwqud2pHt4tc+HDvO76JVhqx3c+vXrhVqtFu+//7746aefxIIFC0RQUJA4deqU3KW1ym9/+1thMBjEjh07RGFhoWurrq4WQghRUVEhnnrqKbFr1y6Rm5srtm/fLm655RbRvXt3YbFYZK7+6p566imxY8cOcfLkSbFnzx4xadIkodfrXffrlVdeEQaDQWzcuFFkZWWJBx54QJhMpk5xbU05HA7Ro0cP8cwzz7jt76z3r6KiQuzfv1/s379fABDLli0T+/fvd830uJb79vDDD4vY2FixdetWsW/fPjFmzBgxcOBAYbfb5bosN1e6xrq6OnHXXXeJ2NhYceDAAbffTavVKoQQ4vjx4+LFF18UGRkZIjc3V3z++efi+uuvF4MGDeoQ13il67vWn8vOfA8bmc1mERgYKN56661mr+/o9/Bqnw9CdIzfRb8IH0II8be//U3Ex8cLjUYjBg8e7DYttbMB0OK2cuVKIYQQ1dXVYty4cSIyMlKo1WrRo0cPMWvWLJGfny9v4dfo/vvvFyaTSajVahETEyOmTp0qsrOzXcedTqd44YUXhNFoFFqtVtx2220iKytLxopbZ9OmTQKAOHr0qNv+znr/tm/f3uLP5axZs4QQ13bfampqxCOPPCK6desmdDqdmDRpUoe67itdY25u7mV/N7dv3y6EECI/P1/cdtttolu3bkKj0YjevXuLxx57TJSWlsp7YQ2udH3X+nPZme9ho3feeUfodDpRXl7e7PUd/R5e7fNBiI7xuyg1FEtERETkE11+zAcRERF1LAwfRERE5FMMH0RERORTDB9ERETkUwwfRERE5FMMH0RERORTDB9ERETkUwwfRERE5FMMH0RERORTDB9ERETkUwwfRERE5FMMH0RERORT/x+XPhP6BJ9JzAAAAABJRU5ErkJggg==",
						"text/plain": [
							"<Figure size 640x480 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				}
			],
			"source": [
				"train_loader_original = DataLoader(dataset=train_dataset, batch_size=64, shuffle=True)\n",
				"\n",
				"enc = Encoder().to(device)\n",
				"dec = Decoder().to(device)\n",
				"loss_fn = nn.MSELoss()\n",
				"optimizer_enc = torch.optim.Adam(enc.parameters())\n",
				"optimizer_dec = torch.optim.Adam(dec.parameters())\n",
				"\n",
				"train_loss = []\n",
				"num_epochs = 200\n",
				"\n",
				"for epoch in tqdm(range(num_epochs)):\n",
				"    train_epoch_loss = 0\n",
				"    for (x , _) in train_loader_original:\n",
				"        x = x.to(device)\n",
				"        x = x.flatten(1)\n",
				"        latents = enc(x)\n",
				"        output = dec(latents)\n",
				"        loss = loss_fn(output , x)\n",
				"        train_epoch_loss += loss.cpu().detach().numpy()\n",
				"        optimizer_enc.zero_grad()\n",
				"        optimizer_dec.zero_grad()\n",
				"        loss.backward()\n",
				"        optimizer_enc.step()\n",
				"        optimizer_dec.step()\n",
				"    train_loss.append(train_epoch_loss)\n",
				"plt.plot(train_loss)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 12,
			"metadata": {},
			"outputs": [],
			"source": [
				"representation = None\n",
				"all_labels = []\n",
				"\n",
				"with torch.no_grad():\n",
				"    for (xs , labels) in train_loader_original:\n",
				"        xs = xs.to(device)\n",
				"        xs = xs.flatten(1)\n",
				"        all_labels.extend(list(labels.numpy()))\n",
				"        latents = enc(xs)\n",
				"        if representation is None:\n",
				"            representation = latents.cpu()\n",
				"        else:\n",
				"            representation = torch.vstack([representation , latents.cpu()])\n",
				"\n",
				"all_labels = np.array(all_labels)\n",
				"representation = representation.numpy()"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 13,
			"metadata": {},
			"outputs": [],
			"source": [
				"sampled_X_AE_class = []\n",
				"\n",
				"for class_ in unique_labels:\n",
				"    sampled_X_AE_list = []\n",
				"\n",
				"    rep = representation[np.argwhere(all_labels == class_)].squeeze()\n",
				"    # Fit a KDE to the theta values\n",
				"    kde = KernelDensity(kernel='gaussian', bandwidth=bandwidth_AE).fit(rep)\n",
				"\n",
				"    # Sample new data from the KDE\n",
				"    sampled_rep = kde.sample(n_samples=new_sample_size_per_class)\n",
				"    for i in range(new_sample_size_per_class):\n",
				"        pred = dec(torch.Tensor(sampled_rep[i])[None , ...].to(device)).cpu().detach().numpy()\n",
				"        sampled_X_AE_list.append(pred.flatten())\n",
				"\n",
				"    sampled_X_AE_class.append(sampled_X_AE_list)"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"## Classification Performance"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### Dataset Preparation"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 14,
			"metadata": {},
			"outputs": [
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"standard loader:\n",
						"Images shape: torch.Size([64, 12]), Labels shape: torch.Size([64])\n",
						"none loader:\n",
						"Images shape: torch.Size([64, 12]), Labels shape: torch.Size([64])\n",
						"PNL_augmented loader:\n",
						"Images shape: torch.Size([64, 12]), Labels shape: torch.Size([64])\n",
						"AE_augmented loader:\n",
						"Images shape: torch.Size([64, 12]), Labels shape: torch.Size([64])\n"
					]
				}
			],
			"source": [
				"# Helper function to create a DataLoader for augmented datasets\n",
				"def prepare_augmented_dataset(original_dataset, augmented_data, augmented_labels, transform, batch_size):\n",
				"    # Create dataset from augmented data\n",
				"    augmented_dataset = NumpyDataset(features=augmented_data, labels=augmented_labels, transform=transform)\n",
				"\n",
				"    # Combine with the original dataset\n",
				"    combined_dataset = ConcatDataset([original_dataset, augmented_dataset])\n",
				"\n",
				"    # Create a DataLoader for the combined dataset\n",
				"    return DataLoader(dataset=combined_dataset, batch_size=batch_size, shuffle=True)\n",
				"\n",
				"# Main function to prepare datasets and loaders\n",
				"def create_datasets_and_loaders(batch_size=64):\n",
				"    # Define transformations\n",
				"    transform_standard = CompositeTransform([\n",
				"        Normalize(mean, std),\n",
				"        AddGaussianNoise(mean=0.0, std=std[:-1].min()/4)  # Add Gaussian noise with 1/4 of the standard deviation (omit the last dummy feature)\n",
				"    ])\n",
				"    transform_none = Normalize(mean, std)\n",
				"\n",
				"    train_standard = NumpyDataset(X_train, Y_train, transform=transform_standard)\n",
				"    train_none = NumpyDataset(X_train, Y_train, transform=transform_none)\n",
				"\n",
				"    augmented_data_PNL = []\n",
				"    labels_PNL = []\n",
				"    augmented_data_AE = []\n",
				"    labels_AE = []\n",
				"\n",
				"    for class_ in range(len(unique_labels)):\n",
				"        for data_PNL in sampled_X_BP_class[class_]:\n",
				"            augmented_data_PNL.append(data_PNL)\n",
				"            labels_PNL.append(class_)\n",
				"\n",
				"        for data_AE in sampled_X_AE_class[class_]:\n",
				"            augmented_data_AE.append(data_AE)\n",
				"            labels_AE.append(class_)\n",
				"\n",
				"    augmented_data_PNL = np.array(augmented_data_PNL)\n",
				"    labels_PNL = np.array(labels_PNL)\n",
				"    augmented_data_AE = np.array(augmented_data_AE)\n",
				"    labels_AE = np.array(labels_AE)\n",
				"\n",
				"    mean_LD = augmented_data_PNL.mean(axis=0)\n",
				"    std_LD = augmented_data_PNL.std(axis=0)\n",
				"    transform_none_LD = Normalize(mean_LD, std_LD)\n",
				"\n",
				"    mean_AE = augmented_data_AE.mean(axis=0)\n",
				"    std_AE = augmented_data_AE.std(axis=0)\n",
				"    transform_none_AE = Normalize(mean_AE, std_AE)\n",
				"\n",
				"    # Combine original with augmented data\n",
				"    train_loader_PNL = prepare_augmented_dataset(train_none, augmented_data_PNL, labels_PNL, transform_none_LD, batch_size)\n",
				"    train_loader_AE = prepare_augmented_dataset(train_none, augmented_data_AE, labels_AE, transform_none_AE, batch_size)\n",
				"\n",
				"    # DataLoader for the original dataset only\n",
				"    train_loader_standard = DataLoader(train_standard, batch_size=batch_size, shuffle=True)\n",
				"    train_loader_none = DataLoader(train_none, batch_size=batch_size, shuffle=True)\n",
				"\n",
				"    return {\n",
				"        \"standard\": train_loader_standard,\n",
				"        \"none\": train_loader_none,\n",
				"        \"PNL_augmented\": train_loader_PNL,\n",
				"        \"AE_augmented\": train_loader_AE,\n",
				"    }\n",
				"\n",
				"loaders = create_datasets_and_loaders(batch_size=64)\n",
				"\n",
				"# Check each DataLoader\n",
				"for name, loader in loaders.items():\n",
				"    print(f\"{name} loader:\")\n",
				"    for images, labels in loader:\n",
				"        print(f\"Images shape: {images.shape}, Labels shape: {labels.shape}\")\n",
				"        break\n",
				"\n",
				"train_loader_standard = loaders[\"standard\"]\n",
				"train_loader_none = loaders[\"none\"]\n",
				"train_loader_PNL = loaders[\"PNL_augmented\"]\n",
				"train_loader_AE = loaders[\"AE_augmented\"]"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### MLP Model"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 15,
			"metadata": {},
			"outputs": [],
			"source": [
				"class MLP(nn.Module):\n",
				"    def __init__(self, input_size, hidden_size=8, num_classes=len(unique_labels)):\n",
				"        super(MLP, self).__init__()\n",
				"        self.input_size = input_size\n",
				"        self.hidden_layer = nn.Linear(input_size, hidden_size)\n",
				"        self.output_layer = nn.Linear(hidden_size, num_classes)\n",
				"        self.activation = nn.ReLU()\n",
				"\n",
				"    def forward(self, x):\n",
				"        x = x.view(-1, self.input_size)  # Flatten the input\n",
				"        x = self.activation(self.hidden_layer(x))  # Apply hidden layer + ReLU\n",
				"        x = self.output_layer(x)  # Apply output layer\n",
				"        return x\n",
				"\n",
				"# Training Function\n",
				"def train_model(model, train_loader, criterion, optimizer, scheduler, num_epochs, device='cuda'):\n",
				"    train_loss = []\n",
				"    model.to(device)\n",
				"    for epoch in tqdm(range(num_epochs)):\n",
				"        model.train()\n",
				"        train_epoch_loss = 0.0\n",
				"\n",
				"        for images, labels in train_loader:\n",
				"            images, labels = images.to(device), labels.to(device)\n",
				"            optimizer.zero_grad()\n",
				"            outputs = model(images)\n",
				"            loss = criterion(outputs, labels)\n",
				"            loss.backward()\n",
				"            optimizer.step()\n",
				"\n",
				"            train_epoch_loss += loss.item()\n",
				"\n",
				"        scheduler.step()\n",
				"        train_loss.append(train_epoch_loss)\n",
				"\n",
				"    plt.plot(train_loss)\n",
				"\n",
				"def test_model(model, test_loader, device='cuda'):\n",
				"    model.eval()\n",
				"    correct = 0\n",
				"    total = 0\n",
				"\n",
				"    with torch.no_grad():\n",
				"        for features, labels in test_loader:\n",
				"            features, labels = features.to(device), labels.to(device)\n",
				"            outputs = model(features)\n",
				"            _, predicted = torch.max(outputs.data, 1)\n",
				"            total += labels.size(0)\n",
				"            correct += (predicted == labels).sum().item()\n",
				"\n",
				"    accuracy = 100 * correct / total\n",
				"    return accuracy\n",
				"\n",
				"def bootstrapping(train_loader, test_dataset, num_epochs=10, learning_rate=1e-1, n_bootstrap=20, device='cuda'):\n",
				"    \"\"\"\n",
				"    Train the Logistic Regression model on the training dataset, and evaluate it using bootstrapping on the test dataset.\n",
				"\n",
				"    Args:\n",
				"        train_loader: DataLoader for training data.\n",
				"        test_dataset: Dataset object for the test data.\n",
				"        num_epochs: Number of epochs for training.\n",
				"        learning_rate: Learning rate for the optimizer.\n",
				"        device: Device to run the training on ('cuda' or 'cpu').\n",
				"\n",
				"    Returns:\n",
				"        Prints the mean accuracy and 95% confidence interval after bootstrapping.\n",
				"    \"\"\"\n",
				"    # Initialize the model, loss, and optimizer\n",
				"    model = MLP(input_size=D ,num_classes=len(unique_labels)).to(device)\n",
				"    criterion = nn.CrossEntropyLoss()\n",
				"    # optimizer = torch.optim.SGD(model.parameters(), lr=learning_rate)\n",
				"    optimizer = torch.optim.SGD(model.parameters(), lr=learning_rate, momentum=0.9, weight_decay=5e-4)\n",
				"    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=30, gamma=0.1)  # Decay LR every 30 epochs\n",
				"\n",
				"    # Train the model\n",
				"    train_model(model, train_loader, criterion, optimizer, scheduler, num_epochs=num_epochs, device=device)\n",
				"\n",
				"    # Perform bootstrapping\n",
				"    accuracies = []\n",
				"\n",
				"    num_test_samples = len(test_dataset) // 2\n",
				"    for i in range(n_bootstrap):\n",
				"        indices = torch.randint(len(test_dataset), size=(num_test_samples,))\n",
				"        bootstrap_subset = Subset(test_dataset, indices)\n",
				"        bootstrap_loader = DataLoader(dataset=bootstrap_subset, batch_size=num_test_samples, shuffle=False)\n",
				"\n",
				"        accuracy = test_model(model, bootstrap_loader, device=device)\n",
				"        accuracies.append(accuracy)\n",
				"\n",
				"    # Compute statistics\n",
				"    mean_accuracy = np.mean(accuracies)\n",
				"    std_accuracy = np.std(accuracies)\n",
				"\n",
				"    print(f\"Mean accuracy: {mean_accuracy:.2f}%\")\n",
				"    print(f\"Standard deviation: {std_accuracy:.2f}\")"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### Dataset Performance"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 16,
			"metadata": {},
			"outputs": [
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:26<00:00,  1.91it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 56.90%\n",
						"Standard deviation: 1.55\n"
					]
				},
				{
					"data": {
						"image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABMuklEQVR4nO3deVxU5eIG8GdmgAEGGEVkR0RFyQ0VN3BPM02NynIrNbXttvzk1jW122KLkXbzllp5uy2allrX9VamWIpy3UBAcccVZBEXmGEdZjm/P5CxSUCWc+YAPt/P53yUmXPeec+rNY/veReFIAgCiIiIiJo4pdwVICIiIhIDQw0RERE1Cww1RERE1Cww1BAREVGzwFBDREREzQJDDRERETULDDVERETULDDUEBERUbPgIHcF7MlisSA7Oxvu7u5QKBRyV4eIiIhqQRAEFBYWwt/fH0pl9f0xd1Woyc7ORlBQkNzVICIionrIzMxEYGBgte/fVaHG3d0dQEWjeHh4yFwbIiIiqg29Xo+goCDr93h17qpQU/nIycPDg6GGiIioibnT0BEOFCYiIqJmgaGGiIiImgWGGiIiImoWGGqIiIioWWCoISIiomaBoYaIiIiaBYYaIiIiahYYaoiIiKhZYKghIiKiZoGhhoiIiJoFhhoiIiJqFhhqiIiIqFm4qza0lMqSuDPILy7HS8M7wNvdWe7qEBER3ZXYUyOCtYcysPrAJVwtNMhdFSIiorsWQ40INE4qAEBJuVnmmhAREd29GGpE4OpU8RSPoYaIiEg+DDUi0Khv9tQYTDLXhIiI6O7FUCOCyp6aYvbUEBERyYahRgTWnppy9tQQERHJhaFGBC6ON3tqDOypISIikgtDjQjYU0NERCS/OoeaPXv2YNy4cfD394dCocDmzZtt3hcEAQsWLIC/vz9cXFwwdOhQHD9+3OYcg8GAl156CV5eXtBoNHjwwQdx+fLlO372Z599hpCQEDg7OyMiIgJ79+6ta/UlwdlPRERE8qtzqCkuLkZ4eDiWL19e5fuLFy/GkiVLsHz5ciQmJsLX1xf33XcfCgsLrefExMRg06ZNWLduHRISElBUVISxY8fCbK4+FKxfvx4xMTH4+9//jpSUFAwaNAijR49GRkZGXW9BdLfWqWFPDRERkWyEBgAgbNq0yfqzxWIRfH19hQ8++MD6WllZmaDVaoUVK1YIgiAIBQUFgqOjo7Bu3TrrOVlZWYJSqRR+/fXXaj+rb9++wnPPPWfzWlhYmDBv3rxa11en0wkABJ1OV+trauPLveeF4Lk/CS99nyxquURERFT7729Rx9RcuHABubm5GDlypPU1tVqNIUOGYN++fQCAw4cPw2g02pzj7++Prl27Ws/5s/Lychw+fNjmGgAYOXJktdfYE3tqiIiI5Cfqhpa5ubkAAB8fH5vXfXx8cOnSJes5Tk5OaNmy5W3nVF7/Z9euXYPZbK6y3OquASrG7hgMt/Zj0uv1tb+ZOnC5GWo4+4mIiEg+ksx+UigUNj8LgnDba39Wm3PqWm5sbCy0Wq31CAoKukPN60dTOVDYyFBDREQkF1FDja+vLwDc1nuSl5dn7WXx9fVFeXk58vPzqz3nz7y8vKBSqWostyrz58+HTqezHpmZmXW+p9pw5TYJREREshM11ISEhMDX1xdxcXHW18rLyxEfH4+oqCgAQEREBBwdHW3OycnJwbFjx6zn/JmTkxMiIiJsrgGAuLi4aq8BKsbzeHh42BxS0HBKNxERkezqPKamqKgIZ8+etf584cIFpKamwtPTE23atEFMTAzef/99hIaGIjQ0FO+//z5cXV0xZcoUAIBWq8WsWbPwyiuvoFWrVvD09MTf/vY3dOvWDSNGjLCWO3z4cDz88MN48cUXAQAvv/wypk6dit69eyMyMhJffPEFMjIy8NxzzzW0DRqscvG9Yg4UJiIikk2dQ01SUhKGDRtm/fnll18GAEyfPh0rV67Eq6++itLSUjz//PPIz89Hv379sGPHDri7u1uv+ec//wkHBwdMmDABpaWlGD58OFauXAmVSmU959y5c7h27Zr154kTJ+L69et45513kJOTg65du+KXX35BcHBwvW5cTNbF9zhQmIiISDYKQRAEuSthL3q9HlqtFjqdTtRHUQUl5ejxTsWjsfSFo+Go4u4TREREYqnt9ze/fUVQ2VMDcFwNERGRXBhqRODkoISjqmJqORfgIyIikgdDjUgqe2u4AB8REZE8GGpEwq0SiIiI5MVQIxJXNXtqiIiI5MRQIxJX9tQQERHJiqFGJLdCDXtqiIiI5MBQI5JbWyWwp4aIiEgODDUi4ZgaIiIieTHUiISzn4iIiOTFUCMSF6fKTS3ZU0NERCQHhhqRWMfUGNhTQ0REJAeGGpG4qjn7iYiISE4MNSK5NfuJoYaIiEgODDUicbWOqeHjJyIiIjkw1IhEo64cU8OeGiIiIjkw1IjEhT01REREsmKoEQnH1BAREcmLoUYk3NCSiIhIXgw1IuGYGiIiInkx1IhE84cxNYIgyFwbIiKiuw9DjUgqN7S0CIDBZJG5NkRERHcfhhqRuDiqrL8v5lYJREREdsdQIxKVUgFnx4rm5AwoIiIi+2OoERGndRMREcmHoUZElZtacgE+IiIi+2OoEZG1p4bTuomIiOyOoUZE3NSSiIhIPgw1InK1jqlhqCEiIrI3hhoRWXtq+PiJiIjI7hhqRFS5VUIpZz8RERHZHUONiDimhoiISD4MNSKybmrJnhoiIiK7Y6gR0a0xNeypISIisjeGGhFVhhr21BAREdkfQ42IOKWbiIhIPgw1ItKo2VNDREQkF0lCTWFhIWJiYhAcHAwXFxdERUUhMTHR+r5Coajy+PDDD6stc+XKlVVeU1ZWJsUt1EtlTw3H1BAREdmfgxSFPvXUUzh27BhWr14Nf39/rFmzBiNGjMCJEycQEBCAnJwcm/O3bduGWbNmYfz48TWW6+HhgdOnT9u85uzsLHr964u7dBMREclH9FBTWlqKDRs2YMuWLRg8eDAAYMGCBdi8eTM+//xzvPfee/D19bW5ZsuWLRg2bBjatWtXY9kKheK2axsT7tJNREQkH9EfP5lMJpjN5tt6UFxcXJCQkHDb+VeuXMHPP/+MWbNm3bHsoqIiBAcHIzAwEGPHjkVKSkqN5xsMBuj1eptDStbZT9wmgYiIyO5EDzXu7u6IjIzEu+++i+zsbJjNZqxZswYHDx687bETAKxatQru7u545JFHaiw3LCwMK1euxNatW7F27Vo4OztjwIABSE9Pr/aa2NhYaLVa6xEUFNTg+6sJHz8RERHJRyEIgiB2oefOncPMmTOxZ88eqFQq9OrVCx07dkRycjJOnDhhc25YWBjuu+8+LFu2rE6fYbFY0KtXLwwePBhLly6t8hyDwQCDwWD9Wa/XIygoCDqdDh4eHnW/sTu4XmRAxHs7AQDn3n8AKqVC9M8gIiK62+j1emi12jt+f0syULh9+/aIj49HcXEx9Ho9/Pz8MHHiRISEhNict3fvXpw+fRrr16+v82colUr06dOnxp4atVoNtVpd57Lrq3KbBAAoNZrhppakeYmIiKgKkq5To9Fo4Ofnh/z8fGzfvh3R0dE273/11VeIiIhAeHh4ncsWBAGpqanw8/MTq7oNpnZQorJzpoTTuomIiOxKkq6E7du3QxAEdOrUCWfPnsWcOXPQqVMnzJgxw3qOXq/Hjz/+iI8++qjKMqZNm4aAgADExsYCAN5++230798foaGh0Ov1WLp0KVJTU/Hpp59KcQv1olAooHFyQKHBhGKOqyEiIrIrSUKNTqfD/PnzcfnyZXh6emL8+PFYuHAhHB0dreesW7cOgiBg8uTJVZaRkZEBpfJWR1JBQQGeeeYZ5ObmQqvVomfPntizZw/69u0rxS3Um4uTqiLUsKeGiIjIriQZKNxY1XagUUMM+8duXLhWjB+fi0Sftp6SfAYREdHdpLbf39z7SWSVa9Wwp4aIiMi+GGpExrVqiIiI5MFQIzLrVgnsqSEiIrIrhhqRWbdKYE8NERGRXTHUiMz15uMnbmpJRERkXww1ItPc7KkpZU8NERGRXTHUiMz15tYIxdypm4iIyK4YakSmsY6p4eMnIiIie2KoEdmtMTXsqSEiIrInhhqRWWc/cUo3ERGRXTHUiMw6poaPn4iIiOyKoUZknP1EREQkD4YakXFMDRERkTwYakSmUXNMDRERkRwYakTGnhoiIiJ5MNSIzJXr1BAREcmCoUZkmps9NUazgHKTRebaEBER3T0YakTmcrOnBuAMKCIiIntiqBGZk4MSTqqKZuVaNURERPbDUCMBVzXH1RAREdkbQ40EKsfVcKduIiIi+2GokUDluBo+fiIiIrIfhhoJcKsEIiIi+2OokQAX4CMiIrI/hhoJcKsEIiIi+2OokQB7aoiIiOyPoUYC7KkhIiKyP4YaCbg4sqeGiIjI3hhqJFDZU1PKKd1ERER2w1AjAY6pISIisj+GGglouE0CERGR3THUSMCV2yQQERHZHUONBCpXFGZPDRERkf0w1EjAuvcTe2qIiIjshqFGAhp1xeOnUiNDDRERkb0w1EjA1dpTw8dPRERE9sJQIwHNzYHCJZzSTUREZDeShJrCwkLExMQgODgYLi4uiIqKQmJiovX9J598EgqFwubo37//HcvdsGEDOnfuDLVajc6dO2PTpk1SVL/BXG9O6S4uN0EQBJlrQ0REdHeQJNQ89dRTiIuLw+rVq5GWloaRI0dixIgRyMrKsp4zatQo5OTkWI9ffvmlxjL379+PiRMnYurUqThy5AimTp2KCRMm4ODBg1LcQoNU9tQIAlBmtMhcGyIioruDQhC5K6G0tBTu7u7YsmULxowZY329R48eGDt2LN577z08+eSTKCgowObNm2td7sSJE6HX67Ft2zbra6NGjULLli2xdu3aWpWh1+uh1Wqh0+ng4eFR68+uK4tFQLvXKkJa0usj4OWmluyziIiImrvafn+L3lNjMplgNpvh7Oxs87qLiwsSEhKsP+/evRve3t7o2LEjnn76aeTl5dVY7v79+zFy5Eib1+6//37s27ev2msMBgP0er3NYQ9KpQIujpX7P3FcDRERkT2IHmrc3d0RGRmJd999F9nZ2TCbzVizZg0OHjyInJwcAMDo0aPx3Xff4ffff8dHH32ExMRE3HvvvTAYDNWWm5ubCx8fH5vXfHx8kJubW+01sbGx0Gq11iMoKEicm6wFzR/G1RAREZH0JBlTs3r1agiCgICAAKjVaixduhRTpkyBSlXxRT9x4kSMGTMGXbt2xbhx47Bt2zacOXMGP//8c43lKhQKm58FQbjttT+aP38+dDqd9cjMzGz4zdUSt0ogIiKyLwcpCm3fvj3i4+NRXFwMvV4PPz8/TJw4ESEhIVWe7+fnh+DgYKSnp1dbpq+v7229Mnl5ebf13vyRWq2GWi3PeBZXbpVARERkV5KuU6PRaODn54f8/Hxs374d0dHRVZ53/fp1ZGZmws/Pr9qyIiMjERcXZ/Pajh07EBUVJWqdxeLKrRKIiIjsSpKemu3bt0MQBHTq1Alnz57FnDlz0KlTJ8yYMQNFRUVYsGABxo8fDz8/P1y8eBGvvfYavLy88PDDD1vLmDZtGgICAhAbGwsAmD17NgYPHoxFixYhOjoaW7Zswc6dO20GHzcmlVslsKeGiIjIPiTpqdHpdHjhhRcQFhaGadOmYeDAgdixYwccHR2hUqmQlpaG6OhodOzYEdOnT0fHjh2xf/9+uLu7W8vIyMiwDiwGgKioKKxbtw7ffPMNunfvjpUrV2L9+vXo16+fFLfQYLceP7GnhoiIyB5EX6emMbPXOjUA8PL6VGxMycJrD4ThmcHtJf0sIiKi5ky2dWqognWrBI6pISIisguGGonc2tSSY2qIiIjsgaFGIi6Vs584poaIiMguGGokYu2pMbCnhoiIyB4YaiRSOaaGs5+IiIjsg6FGIrfG1DDUEBER2QNDjUSsKwpzoDAREZFdMNRIxLqiMKd0ExER2QVDjURc2FNDRERkVww1EuGYGiIiIvtiqJHIrb2f2FNDRERkDww1EqkcU1NmtMBsuWu21yIiIpINQ41EKntqAPbWEBER2QNDjUTUDkqolAoAHFdDRERkDww1ElEoFHB1rNypmz01REREUmOokRC3SiAiIrIfhhoJcVo3ERGR/TDUSKiyp4YL8BEREUmPoUZCrk7cKoGIiMheGGokpOFWCURERHbDUCOhWz01DDVERERSY6iRkHWrBCMfPxEREUmNoUZClVslcEwNERGR9BhqJOTKMTVERER2w1AjIfbUEBER2Q9DjYTYU0NERGQ/DDUSsg4U5orCREREkmOokZB1Sjd7aoiIiCTHUCMhDTe0JCIishuGGglV9tQUc/E9IiIiyTHUSIi7dBMREdkPQ42ErLt0s6eGiIhIcgw1EuLsJyIiIvthqJFQ5Zgak0VAuckic22IiIiaN4YaCVX21ACc1k1ERCQ1hhoJOaqUcHKoaOJiPoIiIiKSlCShprCwEDExMQgODoaLiwuioqKQmJgIADAajZg7dy66desGjUYDf39/TJs2DdnZ2TWWuXLlSigUituOsrIyKW5BNJrKcTUcLExERCQpSULNU089hbi4OKxevRppaWkYOXIkRowYgaysLJSUlCA5ORlvvPEGkpOTsXHjRpw5cwYPPvjgHcv18PBATk6OzeHs7CzFLYjGulYNe2qIiIgk5SB2gaWlpdiwYQO2bNmCwYMHAwAWLFiAzZs34/PPP8d7772HuLg4m2uWLVuGvn37IiMjA23atKm2bIVCAV9fX7GrLClX9tQQERHZheg9NSaTCWaz+bYeFBcXFyQkJFR5jU6ng0KhQIsWLWosu6ioCMHBwQgMDMTYsWORkpIiVrUl46rmAnxERET2IHqocXd3R2RkJN59911kZ2fDbDZjzZo1OHjwIHJycm47v6ysDPPmzcOUKVPg4eFRbblhYWFYuXIltm7dirVr18LZ2RkDBgxAenp6tdcYDAbo9Xqbw94qx9QUc/YTERGRpCQZU7N69WoIgoCAgACo1WosXboUU6ZMgUqlsjnPaDRi0qRJsFgs+Oyzz2oss3///njiiScQHh6OQYMG4YcffkDHjh2xbNmyaq+JjY2FVqu1HkFBQaLcX124cqsEIiIiu5Ak1LRv3x7x8fEoKipCZmYmDh06BKPRiJCQEOs5RqMREyZMwIULFxAXF1djL01VlEol+vTpU2NPzfz586HT6axHZmZmve+pvjTcKoGIiMguRB8o/EcajQYajQb5+fnYvn07Fi9eDOBWoElPT8euXbvQqlWrOpctCAJSU1PRrVu3as9Rq9VQq9X1rr8YuFUCERGRfUgSarZv3w5BENCpUyecPXsWc+bMQadOnTBjxgyYTCY8+uijSE5Oxk8//QSz2Yzc3FwAgKenJ5ycnAAA06ZNQ0BAAGJjYwEAb7/9Nvr374/Q0FDo9XosXboUqamp+PTTT6W4BdHcmtLNnhoiIiIpSRJqdDod5s+fj8uXL8PT0xPjx4/HwoUL4ejoiIsXL2Lr1q0AgB49ethct2vXLgwdOhQAkJGRAaXy1tOxgoICPPPMM8jNzYVWq0XPnj2xZ88e9O3bV4pbEE3lQOFS9tQQERFJSiEIgiB3JexFr9dDq9VCp9PVeQxPfa2IP4cPtp3C+F6B+GhCuF0+k4iIqDmp7fc3936SmHWbBD5+IiIikhRDjcS4TQIREZF9MNRIjNskEBER2QdDjcQqt0lgTw0REZG0GGokdmv2E3tqiIiIpMRQIzGOqSEiIrIPhhqJVW6TwDE1RERE0mKokZh1Q0ujGRbLXbMkEBERkd0x1EiscvaTIABlJj6CIiIikgpDjcRcHFXW33NTSyIiIukw1EhMqVT8Ya0ahhoiIiKpMNTYAXfqJiIikh5DjR1YZ0Ax1BAREUmGocYOrD01fPxEREQkGYYaO3DlTt1ERESSY6ixg1uhhj01REREUmGosQMNt0ogIiKSHEONHbhyqwQiIiLJMdTYAXtqiIiIpMdQYwfsqSEiIpIeQ40duDqyp4aIiEhqDDV2ULn4XimndBMREUmGocYOXDmmhoiISHIMNXbAbRKIiIikx1BjB9wmgYiISHoMNXag4TYJREREkmOosQOXm6GGPTVERETSYaixA4264vFTqZGhhoiISCoMNXbgau2p4eMnIiIiqTDU2EHlNgkGkwUms0Xm2hARETVPDDV2ULlNAgCU8BEUERGRJBhq7MBJpYRKqQAAlHCwMBERkSQYauxAoVDcGlfDad1ERESSYKixk8pxNaXcKoGIiEgSDDV2UjmuhjOgiIiIpMFQYyeVPTUl7KkhIiKSBEONnXBMDRERkbQkCTWFhYWIiYlBcHAwXFxcEBUVhcTEROv7giBgwYIF8Pf3h4uLC4YOHYrjx4/fsdwNGzagc+fOUKvV6Ny5MzZt2iRF9SXh7lzRU5OrK5O5JkRERM2TJKHmqaeeQlxcHFavXo20tDSMHDkSI0aMQFZWFgBg8eLFWLJkCZYvX47ExET4+vrivvvuQ2FhYbVl7t+/HxMnTsTUqVNx5MgRTJ06FRMmTMDBgweluAXR9W/XCgDw36M5MteEiIioeVIIgiCIWWBpaSnc3d2xZcsWjBkzxvp6jx49MHbsWLz77rvw9/dHTEwM5s6dCwAwGAzw8fHBokWL8Oyzz1ZZ7sSJE6HX67Ft2zbra6NGjULLli2xdu3aWtVNr9dDq9VCp9PBw8OjAXdZd1cLDegf+xvMFgE7Xx6CDt5udv18IiKipqq239+i99SYTCaYzWY4OzvbvO7i4oKEhARcuHABubm5GDlypPU9tVqNIUOGYN++fdWWu3//fptrAOD++++v8RqDwQC9Xm9zyKW1uxpDO7YGAGxIvixbPYiIiJor0UONu7s7IiMj8e677yI7Oxtmsxlr1qzBwYMHkZOTg9zcXACAj4+PzXU+Pj7W96qSm5tb52tiY2Oh1WqtR1BQUAPurOHGRwQCADYlZ8FsEbWDjIiI6K4nyZia1atXQxAEBAQEQK1WY+nSpZgyZQpUqlt7ICkUCptrBEG47bU/q+s18+fPh06nsx6ZmZn1uBvxDL/HG1oXR+Tqy7Dv3DVZ60JERNTcSBJq2rdvj/j4eBQVFSEzMxOHDh2C0WhESEgIfH19AeC2Hpa8vLzbemL+yNfXt87XqNVqeHh42BxyUjuoMC7cDwCw4TAfQREREYlJ0nVqNBoN/Pz8kJ+fj+3btyM6OtoabOLi4qznlZeXIz4+HlFRUdWWFRkZaXMNAOzYsaPGaxqjR3pVPIL69XguCsuMMteGiIio+XCQotDt27dDEAR06tQJZ8+exZw5c9CpUyfMmDEDCoUCMTExeP/99xEaGorQ0FC8//77cHV1xZQpU6xlTJs2DQEBAYiNjQUAzJ49G4MHD8aiRYsQHR2NLVu2YOfOnUhISJDiFiTTM6gF2nlpcP5aMbal5WJCH3nH+RARETUXkvTU6HQ6vPDCCwgLC8O0adMwcOBA7NixA46OjgCAV199FTExMXj++efRu3dvZGVlYceOHXB3d7eWkZGRgZycW2u6REVFYd26dfjmm2/QvXt3rFy5EuvXr0e/fv2kuAXJKBQK64Dh/3AWFBERkWhEX6emMZNznZo/yi4oxYBFv0MQgL2vDkOQp6tsdSEiImrsZFunhu7Mv4ULotpXrDDMNWuIiIjEwVAjk/E3BwxvTM7CXdRZRkREJBmGGpmM6uoLjZMKGTdKkHQpX+7qEBERNXkMNTJxdXLA6G5cs4aIiEgsDDUyqnwE9fPRHJQZzTLXhoiIqGljqJFRvxBPBLRwQaHBhO3Hq9/DioiIiO6MoUZGSqUC43sFAAA2JGfJXBsiIqKmjaFGZpXbJiSkX8UVfZnMtSEiImq6GGpk1tZLg97BLWERgE0p7K0hIiKqL4aaRqBy24QNhy9zzRoiIqJ6YqhpBMZ094PaQYn0vCKkZenkrg4REVGTxFDTCHg4O2JkF18AXLOGiIiovhhqGonKWVBbj2Sj3GSRuTZERERND0NNIzEotDW83dXILzHi91N5cleHiIioyWGoaSRUSgUe7lnRW7P2UIbMtSEiImp6GGoakcl920ChAOLPXMX5q0VyV4eIiKhJYahpRNp6aTCskzcA4Nv9l2SuDRERUdPCUNPITI9qCwD4z+HLKDKY5K0MERFRE8JQ08gM6uCFdq01KDKYOL2biIioDhhqGhmlUoHpkW0BAKv2X4TFwhWGiYiIaoOhphEaHxEIN7UDzl8tRsLZa3JXh4iIqElgqGmE3NQOePTmflAr912UtzJERERNBENNIzUtMhgAsOt0Hi5dL5a5NkRERI0fQ00j1a61G4Z2ag1B4PRuIiKi2mCoacQqp3f/kJiJYk7vJiIiqhFDTSM2JLQ1Qrw0KDSYsDElS+7qEBERNWoMNY2YUqmwjq35dt9FCAKndxMREVWHoaaRezQiEBonFdLzirDv3HW5q0NERNRoMdQ0cu7Ojhh/c3r3N/+7KG9liIiIGjGGmiZg2s0Vhn87dQWZN0rueH6OrhR/+/EI5m04imNZOolrR0RE1Dg4yF0BurMO3m4YFOqFvenXsPrAJbz2wD1VnmcyW7Bq/yUs2XEaxeVmAMC6xEz0DfHEzAEhuK+zD1RKhT2rTkREZDfsqWkinrw5vXvdoQyUlN8+vTs1swDRn/4P7/50AsXlZkQEt8SD4f5wUCpw6MINPLfmMIZ8uAtf7j0PXanRzrUnIiKSnkK4i6bU6PV6aLVa6HQ6eHh4yF2dOrFYBAz7aDcuXS/B+w93w5R+bQAA+jIj/rH9NFYfuARBALQujpg3OgwTewdBqVQgV1eG1Qcu4vuDGcgvqQgzrk4qPBYRiCcHhCDESyPnbREREd1Rbb+/GWqakC/3nsd7P59EJx93/BozCP89moN3fzqBq4UGAMAjPQPw2ph74OWmvu3aMqMZW1Kz8HXCRZy+Umh9vVuAFg4qBcwWwXpYhMpfAbNFgINKgbatNOjg7YYOrd3Q3tsNHbzdoHVxtNu9ExHR3YuhpgpNPdToSo3o//5vKDWa0S1Ai7Sbg4DbeWnw3kNdEdXB645lCIKA/eeu4+v/XcBvp/LQkD99Lzc1OnhXhJ1Qb3cM6OCFDt5u9S+wlpbsOI2jWTr8c0IPtNQ4Sf55dGeCIOB6cXmVgZqIqKEYaqrQ1EMNALy+OQ1rDmQAAJwclHhhaAc8N7Qd1A6qOpeVcb0EJ3L0UCoAlVIBpVIBlUJR8XuFAg6qil8NRjPOXSvGubwinLtahLN5RcjRlVVZZvvWGtzfxRf3d/FF90AtFApxBybvOpWHGSsTAQAjO/vgX1MjRP8Mqrv5G49i7aFMfDE1AiO7+MpdHSJqZhhqqtAcQk3G9RI88dVBtGutwVvjusg2JqbIYMK5vIqAc/ZqEY5l6XDg/HUYzbf+OvlpnTGysw/u7+KLviGecFA1bFx6YZkR9/9zD7L/EKjeje6CqTenvJM8NqdkIWZ9KgCgT9uW+PG5KHkrRETNjmyhxmQyYcGCBfjuu++Qm5sLPz8/PPnkk3j99dehVFZ8qVX3L+vFixdjzpw5Vb63cuVKzJgx47bXS0tL4ezsXKu6NYdQ05jpy4zYdSoPO45fwa7TeSi5Oa0cAFq4OmJ4mA+eHhyCMN/6tf0bm49h9YFLaOPpiol9gvDh9tNwclBiywsDcI8f/zzlkHG9BA8s3YuiP2y4GvfXwQj1cZexVkTU3NT2+1v0dWoWLVqEFStWYNWqVejSpQuSkpIwY8YMaLVazJ49GwCQk5Njc822bdswa9YsjB8/vsayPTw8cPr0aZvXahtoSHoezo6I7hGA6B4BKDOa8b+z17D9eC52nszDjeJybEi+jLgTudj0wgC0b123sTeHLtzA6gOXAAAfPNINke1b4fClfPx+Kg8vrU3Bf18cCBenuj+Co/ozmi14aV0Kigwm9GnbEh7OjvjtVB7WHsrEm+M6y109IroLib5Ozf79+xEdHY0xY8agbdu2ePTRRzFy5EgkJSVZz/H19bU5tmzZgmHDhqFdu3Y1lq1QKG67lhonZ0cVht/jg8WPhuPQa8Ox7pn+CA9qAX2ZCTNXJuJGcXmtyyozmjF3w1EAwKQ+QYjq4AWFQoEPH+0Ob3c1zuYV4Z2fjkt1K1SNJXFncCSzAB7ODvh4Uk88cXPz1Q3Jl1FmNN/haiIi8YkeagYOHIjffvsNZ86cAQAcOXIECQkJeOCBB6o8/8qVK/j5558xa9asO5ZdVFSE4OBgBAYGYuzYsUhJSanxfIPBAL1eb3OQ/TmolOjfrhW+mt4bgS1dcOl6CZ5bfRgGU+2++D75LR0XrhXD212N+X9YTbmVmxofT+wBhQJYeygTPx/NqaEUEtO+s9ewIv4cAOCD8d0R0MIFg0NbI6CFC3SlRmw7xj8LIrI/0UPN3LlzMXnyZISFhcHR0RE9e/ZETEwMJk+eXOX5q1atgru7Ox555JEayw0LC8PKlSuxdetWrF27Fs7OzhgwYADS09OrvSY2NhZardZ6BAUFNejeqGG83NT45sk+cFc74NDFG5i/IQ13GtJ1LEuHL/acBwC891DX29bGiergheeHtgcAzNt4tFZ7Y1HD3CguR8z6VAgCMLlvEB7o5gegYgbdpD4V/42tPZgpZxWJ6C4leqhZv3491qxZg++//x7JyclYtWoV/vGPf2DVqlVVnv/111/j8ccfv+PYmP79++OJJ55AeHg4Bg0ahB9++AEdO3bEsmXLqr1m/vz50Ol01iMzk/+jlVuojzs+e6IXVEoFNqZkYfnvZ6s912i24NX/HIXZImBMd79qpwrHjOiInm1aoLDMhNnrUmA0W6Sq/l1PEAS8+p8jyCs0oIO3G94c28Xm/cd6B0GlVODQxRs4m1dYTSlERNIQPdTMmTMH8+bNw6RJk9CtWzdMnToVf/3rXxEbG3vbuXv37sXp06fx1FNP1flzlEol+vTpU2NPjVqthoeHh81B8hsU2hrvRFd8GX4Udwb/PZJd5Xlf7DmPEzl6tHB1xIJxXao8BwAcVUosndQT7s4OSM4owMc7z0hSbwK+3X8JO0/mwelmm/95cLav1hn3hnkDAL5nbw0R2ZnooaakpMQ6dbuSSqWCxXL7v56/+uorREREIDw8vM6fIwgCUlNT4efnV++6knwe7xeMWQNDAACv/HgEhy/l27x/Nq8In/xWEVjfHNsZrd1rXqk2yNMVHzzSHQDw2e5z2Hf2Wo3nmy0Cjmfr8ENSJrakZmHPmatIu6xD5o0SFJYZ7/hYrD7KjGbkVrNooVxKyk0oNty+QWpVTubosfCXkwCA+Q+EobN/1f9IqNyXjAOGicjeRJ/SPW7cOCxcuBBt2rRBly5dkJKSgiVLlmDmzJk25+n1evz444/46KOPqixn2rRpCAgIsPbwvP322+jfvz9CQ0Oh1+uxdOlSpKam4tNPPxX7FshOXnvgHly6XoydJ/PwzLdJ2PzCAAR5usJiETBvw1GUmywY0rE1Hu4ZUKvyxnT3w970IKxLzETM+lRsmz0IrW4u219mNCM1swBJF2/g0MV8JF/Kt1lb5c8clAq0cHVEC1cneLo64dHegZjQu/5jsjJvlGDSFwdwtdCAlTP7IKr9nbe0kNrl/BI88tk+3CguR0RwS9wb5o17w7zRwdvttrWkSsvNeGltCspNFtwb5m3dNb4qlQOGswpK8euxXDxUyz8/IqKGEj3ULFu2DG+88Qaef/555OXlwd/fH88++yzefPNNm/PWrVsHQRCqHUCckZFh0+NTUFCAZ555Brm5udBqtejZsyf27NmDvn37in0LZCcqpQKfTOqJx1bsx4kcPWauTMSG56OwOSULSZfyoXFSYeHDXeu0DcJb47og6VI+zuYV4aW1KegWoEXixRtIy9LZrHYMAG5qB3QP1MIiCCgoMaKgxIj8knIYTBaYLAKuFZXjWlHF1PNDF2/gaqEBLwzrUOf7zC4oxZQvDyCroBQA8MoPR/Dr7MHQusq3IWixwYSnViUh7+ZmqAcv3MDBCzcQu+0UAlu6YFinioAT2b4VnB1VeOenEzibVwRvdzU+fLR7jX8mKqUCE/sEYUncGXx/MIOhhojshtskkOxydKV46NP/4YregL4hnjiepUNxuRnvRHfBtHpsgXAyR4/oT/+HcpPtI09vdzX6hHiiT3BL9AnxRJivB1TK27+cy4xm5JeUI7/YiIKScsSfuYp/3ZyB9X/DQ/HXEaG1DlpX9GWY+K/9uHi9BMGtXKEAcPF6CcZ298OyyT1l2bfKYhHwwvfJ2HYsF15uTljxRASOZ+vx+6k87D9/3abd1A5K9AhqgYMXbkChANbM6ocBtdg4NVdXhgGLfofZImDny4PRwZsrDBNR/XHvpyow1DReaZd1mPCv/Si9OQajd3BL/PBsJJRVhI7a2JKaha8TLuAePw/0aeuJPm09EeTpUu8QsSL+HD7YdgoA8OyQdpg3KuyOZV0tNGDiF/tx/moxAlu6YP2zkbhaaMD4z/fBbBGwZEI4HukVWK/6NMTHO8/g453pcFQpsO6Z/ogI9rS+V1Juwv5z1/H7qTzsOpVns8/Wc0PaY97osFp/ztPfJiHuxBXMGhiCN8ZyhWEiqj+Gmiow1DRu24/n4rk1h+GoUuKX/xuEDt5120pBat/87wLe/u8JAMCTUW3x1rjO1Qab60UGTP73AZy5UgR/rTPWPxuJIE9XAMCy39LxUdwZuKkdsG32IOvr9rAtLQd/+S4ZALB4fHdM6FP9OCFBEHDmShF2nc6D0WTBc0Pbw7EOm5JW7qjewtURB+YPh7Nj893GwmAy45Od6dCXGeGpUaOVxgmeGqeKX90qfu/p6tTgTV2J7lYMNVVgqGn8jmXp4OyobLSPK747eAl/33QMQMUsn/eiu97Wm5RfXI7J/z6AU7mF8PFQY/0zkWj7h93UzRYBE/+1H0mX8tE7uCXWPxtZ5WMwsZ3I1mP85/tQajRjxoC2eKuGafJiMFsEDF68C1kFpfh4Yo9mO7ZGEAT87cej2JB8+Y7ntnB1xNCOrfHPiT1kefRI1FTV9vub/2ygRqVrgLbRBhqgYir6Px4Lh1IBfH8wA3NuLg5YSVdqxNSvD+JUbiG83NT4/un+NoEGqBhI+8+JPeCmdkDSpXx8vrv6BQjFcr3IgKe/TUKp0YyBHbzw9z9sNyGVygHDAPD9oQzJP08uXyVcwIbky1ApFZg1MASP92uD0V190TfEEx283eCpcUJlfikoMWJzajYyb5TKW2miZkr02U9Ezd2jEYFwVCnw8g9HsCH5MsrNFiyZEI4yoxnTvj6EY1l6tNI4Ye3T/ardjTzI0xVvP9gFr/x4BB/vTMeg0NYID2ohSX3LTRb85btkZBWUom0rVyyf0tNuj0Em9A7CxzvP4NCFGzibV9ToHik21K7TeXj/5to9r4+5BzMGhFR5ntkiIL+kHE98WRF4T+To0KaV/R47Et0t2FNDVA/RPQLw6ZSecFQp8N8j2Xjhu2Q8+U0ijmQWoIWrI9Y81Q+hPjX3OD3SKwBjuvvBZBEQsz611ovg1YUgCHhr63EcunADbmoHfDm9N1q4Oon+OdWpWGHYBwCwVsTeGn1Zxcw0OZ3NK8L/fZ8Ci1Cxe3xNa/eolAp4uakRHtgCAHA8m5vrEkmBoYaonkZ19cO/pkbAyUGJHSeu4PClfHg4O2DNrH64x+/OY7YUCgXef6gb/LTOuHCtGO/9fFL0Oq45cAlrD2VAoQA+mdRDlkd7U/pVPIISa4XhxIs3MGjRLkS8txPTvj6EDYcvo7DM2OBy60JXYsTT3yah0GBCn7Yt8U507dZTqlyFmaGGSBoMNUQNcG+YD76a3hvOjkq4qx3w7ax+6BqgrfX1WldHfDQhHApFRU/GjuO5otVt37lr1tlar94fhuH3+IhWdl0M6egNf60zCkqM2N7A+9t+PBdPfHkQulIjzBYBe85cxSs/HkHv93bi+e8O49djOZJvzWAyW/Di2mRcuFaMgBYu+PyJimBbG12soUYnZRWJ7locU0PUQINCWyNh7r1QKRRoqan7o52o9l54elA7fLHnPOZtTEOPNi3g7W67a31puRnnrxXh3NVinMsrwqXrxSgpN6PcbEG5qeIw3Py18rWrRQaYLAKie/jjuSHtxLrdOqsYMNwG/9x5Bt8dzEB0j/rNglpz4BLe3HIMFgEYcY8P/nZ/R+w4fgWbU7Nw/moxfknLxS9puXBXO2BUV1882MMfke1aodRoRkGJEbrSiqOgxIiC0vKKn0uMsAgCxoX7o/vNR0N38v4vp7A3/RpcHFX497Te8HKreV+yPwrz84BCAVzRG3CtyFCna4nozjilm6gRMJjMePjTfTiRo8fADl4Y1dUX567eCjGVWyzUVURwS3z3VD/Z14jJ0ZViwAe/wyIAO18eUqcBw4Ig4J8707H05gank/sG4d3ortbBzoIg4Hi2Hv89ko2tR7KRU89NQ/uGeOKZQe1wb5h3tYs+/pCYiVc3HAUArHiiF0Z1rfuGusP+sRsXrhXj25l9Mbhj63rVlehuw3VqqsBQQ41Z+pVCjF2WAIPp9h3tAcBT44T2rTVo39oNbb00cHd2gJNKCScHJdQOFb86qVRQOyrhpFLC2VGFUG+3eq/KLLanViVh58kraN9ag+eHdsC4cP87PrYxmS14ffMxrEvMBADMHh6KmBq2qbBYBCRevIGtR7Lxc1oOCkoqxto4OSjRwsWxYpNSFyd4WH/viLxCA35Jy4Hp5tT8dq01mDUwBON7BdqEwaSLNzD53wdgNAv464iOmD0itF7t8ML3yfj5aA7mjgrDX4a2r1cZRHcbhpoqMNRQY7c5JQsr4s8hoIUL2nu7WUNMu9YV6500ZUcvF+Dxfx9E4c1ZXn5aZ8wcEIJJfYPg7nz75p4VO4MnY+fJPCgVwLsPdcXj/YJr/XlGswX5xeXwcHG8Y09Vjq4UK/ddxPcHM1BYVlE/T40TpvYPxtTIYBhMFkQvT8C1onI80M0Xyyf3qndY/Gz3WSz+9TTGhftj2eSe9SqD6G7DUFMFhhoieelKjfju4CV887+LuHpzh3B3Zwc83i8YMwa0hY9HxVii/OJyzFqViOSMAqgdlFg6uSfu7+Iref2KDCasT8zE1wkXrI/8nByUaKVxQo6uDJ39PPCfv0TC1an+wxHjz1zF9K8PoV1rDX5/ZahINSdq3hhqqsBQQ9Q4GExmbE7Jwhd7zuPc1WIAgKNKgYd7BiC6RwDe3HIM564Ww8PZAV892Qd92nreoURxmcwW/Ho8F//ecx5HLlfMVPJyc8KWFwcioIVLg8q+WmhAn4U7oVAAxxbcD42a8zWI7oShpgoMNUSNi8Ui4LdTefhizzkkXsy3ec9P64xVM/ui4x0WMZSSIAhIvJiPX4/l4tGIQOs6Mw3Vd+FO5BUasOEvkTa7pBNR1Wr7/c1/IhCRbJRKBe7r7IP7Ovvg8KV8fLHnHHacuIKO3u5YObMP/LQN6xVpKIVCgb4hnugbIm7w6OLvgbzTV3EiW89QQyQihhoiahQiglviX1N743qRAR4ujnC00/5Ucujir8Wu01e5sjCRyBhqiKhRaXUXLEjH7RKIpNF8/ylERNRIVW6XcDq3EEZz1esSEVHdMdQQEdlZUEtXuKsdUG624NzVIrmrQ9RsMNQQEdmZUqnAPZWPoLL4CIpILAw1REQy6OzHcTVEYmOoISKSQeW4mhM5OplrQtR8MNQQEcmgi78WAHAiW4+7aA1UIkkx1BARyaCDtxscVQroy0y4nF8qd3WImgWGGiIiGTg5KK1bQBzP5iMoIjEw1BARycQ6roaDhYlEwVBDRCSTynE1nAFFJA6GGiIimXC7BCJxMdQQEcnkHj8PKBRArr4M14sMcleHqMljqCEikomb2gFtW2kAACdy2FtD1FAMNUREMuIjKCLxMNQQEcmI2yUQiYehhohIRremdXOtGqKGYqghIpJR5bTu89eKUVJukrk2RE0bQw0RkYxau6vh7a6GIAAncwrlrg5RkyZ6qDGZTHj99dcREhICFxcXtGvXDu+88w4sFov1nCeffBIKhcLm6N+//x3L3rBhAzp37gy1Wo3OnTtj06ZNYlefiMjuOlt37Oa4GqKGED3ULFq0CCtWrMDy5ctx8uRJLF68GB9++CGWLVtmc96oUaOQk5NjPX755Zcay92/fz8mTpyIqVOn4siRI5g6dSomTJiAgwcPin0LRER2xXE1ROJwELvA/fv3Izo6GmPGjAEAtG3bFmvXrkVSUpLNeWq1Gr6+vrUu9+OPP8Z9992H+fPnAwDmz5+P+Ph4fPzxx1i7dq14N0BEZGfcLoFIHKL31AwcOBC//fYbzpw5AwA4cuQIEhIS8MADD9ict3v3bnh7e6Njx454+umnkZeXV2O5+/fvx8iRI21eu//++7Fv3z5xb4CIyM4qp3Wfyi2E0Wy5w9lEVB3Re2rmzp0LnU6HsLAwqFQqmM1mLFy4EJMnT7aeM3r0aDz22GMIDg7GhQsX8MYbb+Dee+/F4cOHoVarqyw3NzcXPj4+Nq/5+PggNze32roYDAYYDLeWHtfr+a8gImp82ni6wk3tgCKDCeevFqOTr7vcVSJqkkQPNevXr8eaNWvw/fffo0uXLkhNTUVMTAz8/f0xffp0AMDEiROt53ft2hW9e/dGcHAwfv75ZzzyyCPVlq1QKGx+FgThttf+KDY2Fm+//XYD74iISFpKpQKd/Txw6OINHM/WMdQQ1ZPoj5/mzJmDefPmYdKkSejWrRumTp2Kv/71r4iNja32Gj8/PwQHByM9Pb3ac3x9fW/rlcnLy7ut9+aP5s+fD51OZz0yMzPrfkNERHbA7RKIGk70UFNSUgKl0rZYlUplM6X7z65fv47MzEz4+flVe05kZCTi4uJsXtuxYweioqKqvUatVsPDw8PmICJqjKzTuhlqiOpN9MdP48aNw8KFC9GmTRt06dIFKSkpWLJkCWbOnAkAKCoqwoIFCzB+/Hj4+fnh4sWLeO211+Dl5YWHH37YWs60adMQEBBg7eGZPXs2Bg8ejEWLFiE6OhpbtmzBzp07kZCQIPYtEBHZXRdrT43ujo/WiahqooeaZcuW4Y033sDzzz+PvLw8+Pv749lnn8Wbb74JoKLXJi0tDd9++y0KCgrg5+eHYcOGYf369XB3v/UcOSMjw6bHJyoqCuvWrcPrr7+ON954A+3bt8f69evRr18/sW+BiMjuQr3d4ahSQF9mwuX8UgR5uspdJaImRyEIgiB3JexFr9dDq9VCp9PxURQRNTpjlu7F8Ww9VjwRgVFda7+OF1FzV9vvb+79RETUSFSuV8PtEojqh6GGiKiR4HYJRA3DUENE1Eh0CeB2CUQNwVBDRNRI3HPz8VOOrgw3istlrg1R08NQQ0TUSLipHdDOSwMAiDtR/RYwRFQ1hhoiokZkct82AIClv52FwWSWuTZETQtDDRFRIzI1Mhg+HmpkFZRi7cEMuatD1KQw1BARNSLOjir83/BQAMDyXWdRUm6SuUZETQdDDRFRIzOhdxCCW7niWlE5vvnfRbmrQ9RkMNQQETUyjiolXr6vIwBgRfw56EqMMteIqGlgqCEiaoTGdfdHmK87CstM+Neec3JXh6hJYKghImqElEoFXhnZCQDwzf8uIq+wTOYaETV+DDVERI3UiHu80SOoBUqNZnz6+1m5q0PU6DHUEBE1UgqFAq/eX9Fb8/2hDGTeKJG5RkSNG0MNEVEjFtXBCwM7eMFoFvDJb+l1urawzAhBEBpch+PZOhzL4iab1Pgx1BARNXJ/u9lbszH5MtKvFN7x/MIyI+ZvTEO3BTvw5DeJuF5kqNfnWiwCPtmZjrHLEvDg8gRsP86tG6hxY6ghImrkegS1wMjOPrAIwJK4MzWeuzf9KkZ9vBdrD1WsRhx/5irGLE1A4sUbdfpMXYkRT32bhH/uPANBACwC8NLaFOw/d73e90EkNYYaIqIm4JWRnaBQANuO5eLo5YLb3i8ymDB/YxqmfnUIWQWlCPJ0wT8eC0e71hrk6ssw6YsD+Hz3OVgsd34cdSJbj3HLE/D7qTw4OSixaHw3jOzsg3KTBU9/myTpo6iTOXp8uP0UUjMLJPsMar4UghgPXJsIvV4PrVYLnU4HDw8PuatDRFQnL69PxcaULAzu2BrfzuxrfT0h/RrmbjiKrIJSAMC0yGDMHRUGjdoBxQYT/r4pDZtTswEAwzq1xpIJPdBS41TlZ2xKuYz5G9NQZrQgsKULVjwRga4BWpQZzZj+9SEcvHADXm5O+PG5KITc3FG8oQRBwP5z1/GvPecRf+YqAECpAF4c1gEvDQ+Fo0q6f39XfgUqFArJPoMarrbf3ww1RERNRMb1Etz70W6YLALWPdMfXQO0iP3lJL67ufFlkKcLFo3vjqj2XjbXCYKAdYmZeGvrcZSbLPDXOmPZlF6ICG5pPafcZMF7P5/At/svAQAGd2yNTybahh99mRGT/nUAJ3L0CGzpgg1/iYKPh3O978dktmDbsVx8sec80m72/igVQBd/rfXnbgFa/HNiD3Twdqv35/yZ2SLg8KV8/JKWg1+P5SK/pBwTegfh2SHtENjSVbTPIfEw1FSBoYaImrrXN6dhzYEMdPJxR5HBVGXvTHVOZOvxwvfJuHCtGA5KBeaOCsNTg0JwRW/A898dRnJGAQDg/+7tgNkjOkKlvL334mqhAY+t2IeL10vQyccdPzwbCa2rY53uoaTchB+TLuPLhPPIvFFRf2dHJSb0DsJTA9uhTStX/HQ0G3/fdAy6UiPUDkq89sA9mNo/GMoq6lQbZouAQxduYNuxHGw7lourhbcPnnZQKvBwzwD8ZWh7tGstXoiihmOoqQJDDRE1dVf0ZRjy4S6UGS0AgMCWLlj86O29M9WpnBn109EcAMCgUC+czNHjWlE53J0d8PHEHhh+j0+NZWTeKMH4z/chr9CAiOCWWDOrH1ycVHf87Mv5Jfgh6TJW77+I/Jv7WbV0dcT0qLaYFtkWnn96JJarK8Oc/xzB3vRr1rp++Gg4fLW16x0ymS04eOEGfknLwfbjubhWVG59z93ZAfd19sEDXf3g4qTCZ7vP4n9nKwZBKxXAmO7+eGFYe4T58ruiMWCoqQJDDRE1Byviz+HD7acxpW8bzBtdc+9MVQRBwJqDGXj3vydQbq4IR2G+7vjX1AgEt6rdOJnTuYV4bMU+6MtMGNqpNf49rXeVY18uXCvGtmMVj3mOXr41wLiNpyueHhSCRyOCagxEgiBg9YFLWPjzSRhMFmhdHPHeQ10xLtzf5jyLRcD5a8VIyypA2mU90rIKcCxLj1Kj2XqO1sURIzv74IHufhjQ3gtODrb1Tc7Ix6e/n8Vvp/Ksr93X2QcvDuuA8KAWtWoXkgZDTRUYaoiouTCaLQ0eQHssS4cFW4+jo6873hjTuVa9LX90+NINPP7lQZQZLXiohz+WTOgBhQI4c6XIGmRO5d5aV0epAPq09cS0yLYY1dW3ysdb1TmbV4SXf0i1BqPoHv64N8wbx7J0OHpZh+PZehQZTLdd56lxwv1dfDC6qx8i27eqVZsdz9bhs13n8MuxHFR+Qw4K9cLkvm1wb5g3nB3r1k7UcAw1VWCoISIS165TeXj62ySYLAIGd2yNyzdKcP5asfV9B6UCke1bYXRXP4zs4gMvN3W9P8totmDZ72fx6a6zMFcxNd3ZUYmu/lp0DdCie2DFEeLlVqfw9Edn84rw2e6z2JKabf08d7UD7u/qi4d6BCCyfat6l011w1BTBYYaIiLxbU7JQsz6VOvPTg5KDA71wqiufhhxjzdauFY9fby+kjPy8cG2UzCYLAgP1KJbgBbdA1ugfWsNHCSY/p1xvQTfHbqE/6ZmI1t3a7f01u5qjO3uh4d6BKB7oNZu08KPZenwzk8ncDJHj2GdvPFoRCAGdPCSLGAVlJQjJbMAXho1ugZ4yDL9naGmCgw1RETS2JRyGXvTr2FIx9a4N8wb7s51mxHVFFgsApIu5WNzahZ+SctBwc3BzgDQtpUrHgz3R1svDdQOKjg5KKGuPBxVNr/3cVfXK3wVlJTjHztO47uDGfjzN7ef1hmP9ArAoxFBDV4/SFdqxKELN3Dg/HXsP3cdJ3P11s8LbOmCMd388EA3P7sGOYaaKjDUEBGRGMpNFuxNv4rNqdmIO5FrnY1WG15uTnikVyAm9A6q1fo7FouA9UmZWPzrKeussQfD/TGhdxC2H8/FltQs6MtujSfqHdwSj0YEYkx3vzuGS0EQoC81IenSzRBz/jqOZ+tvC00hXhrk6spsBl4HtnTBAzcDTrjEAYehpgoMNUREJLZigwlxJ65g58kr0JUaUW6ywGA9zDAYb/2+zGiG0XzrazciuCUm9A7EmO7+cKtiFltqZgHe2nIMR24OkO7o44a3H+yKyPatrOeUGc3YefIK/nP4MvacuYrK4UbOjkoM6+QNtYMSRQYzig0mFJebUGQwodhgQonBjOJyE6raOaOdlwb927dC/3at0L+dJ7zdnVFabsbu03n4OS0Hv5/KQ0n5rYAT0MIFD3TzxZju/pIEHIaaKjDUEBGRnIxmC3adysMPSZex63SedQCyq5MKY7r5YUKfIPQObokbxeX4cPtprE/KhCBUDFCOua8jpkUG1ziD64q+DBuTs/Cfw5k4d7W42vP+rG0rV0RaQ0yrO64UXVpuRvyZPPx09PaAs/H5KPRq07KGq+uOoaYKDDVERNRY5OnLsDElCz8kZtrMGGvnpcG1IoP1kdL4XoGYO7oTvN1rvyWFIAhIzSzAvnPXoXZQQqN2qDicVNCoHeBW+bNaBTe1A1yd6rbW0R+VGSt7cHJxIluHuL8OqffKz9VhqKkCQw0RETU2glCxF9UPSZn46WiOtdejs58H3onugt5tPWWuYe1ZLILogQZgqKkSQw0RETVmRQYT4k7kwkmlqvMChc1Zbb+/69/fRERERKJyUzvg4Z6BclejyRJ/lSIiIiIiGTDUEBERUbPAUENERETNguihxmQy4fXXX0dISAhcXFzQrl07vPPOO7BYKlZbNBqNmDt3Lrp16waNRgN/f39MmzYN2dnZNZa7cuVKKBSK246ysrIaryMiIqK7g+gDhRctWoQVK1Zg1apV6NKlC5KSkjBjxgxotVrMnj0bJSUlSE5OxhtvvIHw8HDk5+cjJiYGDz74IJKSkmos28PDA6dPn7Z5zdm59vP2iYiIqPkSPdTs378f0dHRGDNmDACgbdu2WLt2rTWwaLVaxMXF2VyzbNky9O3bFxkZGWjTpk21ZSsUCvj6+opdZSIiImoGRH/8NHDgQPz22284c+YMAODIkSNISEjAAw88UO01Op0OCoUCLVq0qLHsoqIiBAcHIzAwEGPHjkVKSkqN5xsMBuj1epuDiIiImifRe2rmzp0LnU6HsLAwqFQqmM1mLFy4EJMnT67y/LKyMsybNw9TpkypcUGdsLAwrFy5Et26dYNer8cnn3yCAQMG4MiRIwgNDa3ymtjYWLz99tui3BcRERE1bqKvKLxu3TrMmTMHH374Ibp06YLU1FTExMRgyZIlmD59us25RqMRjz32GDIyMrB79+46rfJrsVjQq1cvDB48GEuXLq3yHIPBAIPBYP1Zr9cjKCiIKwoTERE1IbKtKDxnzhzMmzcPkyZNAgB069YNly5dQmxsrE2oMRqNmDBhAi5cuIDff/+9ziFDqVSiT58+SE9Pr/YctVoNtVpdvxshIiKiJkX0MTUlJSVQKm2LValU1indwK1Ak56ejp07d6JVq1Z1/hxBEJCamgo/P78G15mIiIiaPtF7asaNG4eFCxeiTZs26NKlC1JSUrBkyRLMnDkTQMU6No8++iiSk5Px008/wWw2Izc3FwDg6ekJJycnAMC0adMQEBCA2NhYAMDbb7+N/v37IzQ0FHq9HkuXLkVqaio+/fRTsW+BiIiImiDRQ82yZcvwxhtv4Pnnn0deXh78/f3x7LPP4s033wQAXL58GVu3bgUA9OjRw+baXbt2YejQoQCAjIwMmx6fgoICPPPMM8jNzYVWq0XPnj2xZ88e9O3bV+xbICIioiZI9IHCjZlOp0OLFi2QmZnJgcJERERNROVEn4KCAmi12mrPE72npjErLCwEAAQFBclcEyIiIqqrwsLCGkPNXdVTY7FYkJ2dDXd3dygUCtHKrUyQ7AGyD7a3fbG97YvtbV9sb/uqb3sLgoDCwkL4+/vfNhnpj+6qnhqlUonAwEDJyvfw8OB/FHbE9rYvtrd9sb3ti+1tX/Vp75p6aCqJPqWbiIiISA4MNURERNQsMNSIQK1W46233uLqxXbC9rYvtrd9sb3ti+1tX1K39101UJiIiIiaL/bUEBERUbPAUENERETNAkMNERERNQsMNURERNQsMNSI4LPPPkNISAicnZ0RERGBvXv3yl2lZmHPnj0YN24c/P39oVAosHnzZpv3BUHAggUL4O/vDxcXFwwdOhTHjx+Xp7JNXGxsLPr06QN3d3d4e3vjoYcewunTp23OYXuL5/PPP0f37t2tC5BFRkZi27Zt1vfZ1tKKjY2FQqFATEyM9TW2uXgWLFgAhUJhc/j6+lrfl7KtGWoaaP369YiJicHf//53pKSkYNCgQRg9ejQyMjLkrlqTV1xcjPDwcCxfvrzK9xcvXowlS5Zg+fLlSExMhK+vL+677z7rHl9Ue/Hx8XjhhRdw4MABxMXFwWQyYeTIkSguLraew/YWT2BgID744AMkJSUhKSkJ9957L6Kjo63/Y2dbSycxMRFffPEFunfvbvM621xcXbp0QU5OjvVIS0uzvidpWwvUIH379hWee+45m9fCwsKEefPmyVSj5gmAsGnTJuvPFotF8PX1FT744APra2VlZYJWqxVWrFghQw2bl7y8PAGAEB8fLwgC29seWrZsKXz55ZdsawkVFhYKoaGhQlxcnDBkyBBh9uzZgiDw77fY3nrrLSE8PLzK96Rua/bUNEB5eTkOHz6MkSNH2rw+cuRI7Nu3T6Za3R0uXLiA3Nxcm7ZXq9UYMmQI214EOp0OAODp6QmA7S0ls9mMdevWobi4GJGRkWxrCb3wwgsYM2YMRowYYfM621x86enp8Pf3R0hICCZNmoTz588DkL6t76oNLcV27do1mM1m+Pj42Lzu4+OD3NxcmWp1d6hs36ra/tKlS3JUqdkQBAEvv/wyBg4ciK5duwJge0shLS0NkZGRKCsrg5ubGzZt2oTOnTtb/8fOthbXunXrkJycjMTExNve499vcfXr1w/ffvstOnbsiCtXruC9995DVFQUjh8/LnlbM9SIQKFQ2PwsCMJtr5E02Pbie/HFF3H06FEkJCTc9h7bWzydOnVCamoqCgoKsGHDBkyfPh3x8fHW99nW4snMzMTs2bOxY8cOODs7V3se21wco0ePtv6+W7duiIyMRPv27bFq1Sr0798fgHRtzcdPDeDl5QWVSnVbr0xeXt5tKZTEVTmSnm0vrpdeeglbt27Frl27EBgYaH2d7S0+JycndOjQAb1790ZsbCzCw8PxySefsK0lcPjwYeTl5SEiIgIODg5wcHBAfHw8li5dCgcHB2u7ss2lodFo0K1bN6Snp0v+95uhpgGcnJwQERGBuLg4m9fj4uIQFRUlU63uDiEhIfD19bVp+/LycsTHx7Pt60EQBLz44ovYuHEjfv/9d4SEhNi8z/aWniAIMBgMbGsJDB8+HGlpaUhNTbUevXv3xuOPP47U1FS0a9eObS4hg8GAkydPws/PT/q/3w0eanyXW7duneDo6Ch89dVXwokTJ4SYmBhBo9EIFy9elLtqTV5hYaGQkpIipKSkCACEJUuWCCkpKcKlS5cEQRCEDz74QNBqtcLGjRuFtLQ0YfLkyYKfn5+g1+tlrnnT85e//EXQarXC7t27hZycHOtRUlJiPYftLZ758+cLe/bsES5cuCAcPXpUeO211wSlUins2LFDEAS2tT38cfaTILDNxfTKK68Iu3fvFs6fPy8cOHBAGDt2rODu7m79XpSyrRlqRPDpp58KwcHBgpOTk9CrVy/rNFhqmF27dgkAbjumT58uCELF1MC33npL8PX1FdRqtTB48GAhLS1N3ko3UVW1MwDhm2++sZ7D9hbPzJkzrf/PaN26tTB8+HBroBEEtrU9/DnUsM3FM3HiRMHPz09wdHQU/P39hUceeUQ4fvy49X0p21ohCILQ8P4eIiIiInlxTA0RERE1Cww1RERE1Cww1BAREVGzwFBDREREzQJDDRERETULDDVERETULDDUEBERUbPAUENERETNAkMNERERNQsMNURERNQsMNQQERFRs8BQQ0RERM3C/wP+XSrPzRqUJQAAAABJRU5ErkJggg==",
						"text/plain": [
							"<Figure size 640x480 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				}
			],
			"source": [
				"bootstrapping(train_loader_none, test_dataset, num_epochs=50, learning_rate=0.1, device=device)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 17,
			"metadata": {},
			"outputs": [
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:40<00:00,  1.24it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 57.07%\n",
						"Standard deviation: 2.10\n"
					]
				},
				{
					"data": {
						"image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABKqElEQVR4nO3deVhU9eI/8PeZYRj2QUQZNhFMQBRwX3Atlyw1WzUtNdP2unIrM251s8zIuvntavuvRdNS65rLzUyxFPVKiguIG6KgoIAIwgzrADPn9wcyOgkIcs4My/v1POcJZj7nzOecx5y3n1UQRVEEERERUSunsHUFiIiIiKTAUENERERtAkMNERERtQkMNURERNQmMNQQERFRm8BQQ0RERG0CQw0RERG1CQw1RERE1CbY2boC1mQymZCdnQ1XV1cIgmDr6hAREVEjiKKI4uJi+Pj4QKGovz2mXYWa7Oxs+Pv727oaREREdAuysrLg5+dX7/vtKtS4uroCqHkobm5uNq4NERERNYZer4e/v7/5e7w+7SrU1HY5ubm5MdQQERG1MjcbOsKBwkRERNQmMNQQERFRm8BQQ0RERG0CQw0RERG1CQw1RERE1CYw1BAREVGbwFBDREREbQJDDREREbUJDDVERETUJjDUEBERUZvAUENERERtAkMNERERtQkMNRJYGncar29MweVig62rQkRE1G4x1EhgzYFMrP4zk6GGiIjIhhhqJOBsrwQAlFVW27gmRERE7RdDjQSc7O0AACUGhhoiIiJbYaiRgLO6tqXGaOOaEBERtV8MNRJwVte01JSypYaIiMhmGGok4Hy1+4ktNURERLbDUCMBp6sDhUs5UJiIiMhmGGokwO4nIiIi22OokYC5pcbA7iciIiJbYaiRQG1LDdepISIish2GGgk4m8fUsKWGiIjIVhhqJODEMTVEREQ2x1AjAfOUbo6pISIishmGGgk4qTmlm4iIyNYYaiTgoubie0RERLbGUCOBa1O62VJDRERkK00ONbt378akSZPg4+MDQRCwceNGi/dFUcTChQvh4+MDR0dHjBo1CsePH7coYzAY8MILL8DT0xPOzs645557cOHChZt+9qefforAwEA4ODigX79+2LNnT1OrL4vaMTUMNURERLbT5FBTWlqKyMhIfPzxx3W+//7772Pp0qX4+OOPkZiYCK1Wi7Fjx6K4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",
						"text/plain": [
							"<Figure size 640x480 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				}
			],
			"source": [
				"bootstrapping(train_loader_standard, test_dataset, num_epochs=50, learning_rate=0.1, device=device)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 18,
			"metadata": {},
			"outputs": [
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:32<00:00,  1.55it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 58.12%\n",
						"Standard deviation: 2.05\n"
					]
				},
				{
					"data": {
						"image/png": "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zz33nCiK/PttbStXrhRjY2M7XGfre82Wmh7Q6/XIzc1FSkqK2fcpKSk4cOCAg6q6NRQVFaGystLs3ru6uuKuu+7ivbcCjUYDAPDz8wPA+21LBoMBmzZtQkNDAyZOnMh7bUNPP/00pk6diuTkZLPvec+tr6CgACqVCpGRkZg/fz7OnTsHwPb3+paa0NLaqqurYTAYEBQUZPZ9UFAQKisrHVTVraH9/nZ074uLix1RktMQRRFLly7FHXfcgejoaAC837aQn5+PiRMnorm5GV5eXti6dStGjhxp+hc777V1bdq0CXl5eTh8+PB16/j327ri4+OxYcMGDB06FBcvXsQrr7yChIQEnDhxwub3mqHGCgRBMPssiuJ135Ft8N5b3+LFi3Hs2DHs37//unW839YzbNgwqNVq1NbW4vPPP0daWhr27NljWs97bT2lpaV47rnn8O2338LNza3T7XjPrSM1NdX0zzExMZg4cSIGDRqE9evXY8KECQBsd6/5+KkHAgICIJVKr2uVqaqqui6FknW196TnvbeuZ555Bl9++SV27dqF0NBQ0/e839bn4uKCwYMHY9y4cUhPT0dsbCzefPNN3msbyM3NRVVVFeLi4iCTySCTybBnzx689dZbkMlkpvvKe24bnp6eiImJQUFBgc3/fjPU9ICLiwvi4uKQlZVl9n1WVhYSEhIcVNWtITIyEsHBwWb3Xq/XY8+ePbz33SCKIhYvXowvvvgC33//PSIjI83W837bniiK0Ol0vNc2kJSUhPz8fKjVatMybtw4PPLII1Cr1Rg4cCDvuQ3pdDqcOnUKISEhtv/73eOuxre4TZs2iXK5XMzMzBRPnjwpLlmyRPT09BTPnz/v6NL6vLq6OvHIkSPikSNHRADi66+/Lh45ckQsLi4WRVEUX331VVGpVIpffPGFmJ+fLz700ENiSEiIqNVqHVx53/Ob3/xGVCqV4u7du8WKigrT0tjYaNqG99t6VqxYIe7du1csKioSjx07Jr7wwguiRCIRv/32W1EUea/t4drRT6LIe25Ny5YtE3fv3i2eO3dOPHTokHj//feL3t7ept9FW95rhhor+Mc//iFGRESILi4u4tixY03DYKlndu3aJQK4bklLSxNFsW1o4MqVK8Xg4GDR1dVVvPPOO8X8/HzHFt1HdXSfAYgffvihaRveb+v51a9+Zfp3RmBgoJiUlGQKNKLIe20P/x1qeM+tZ968eWJISIgol8tFlUolPvjgg+KJEydM6215rwVRFMWet/cQERERORb71BAREZFTYKghIiIip8BQQ0RERE6BoYaIiIicAkMNEREROQWGGiIiInIKDDVERETkFBhqiIiIyCkw1BAREZFTYKghIiIip8BQQ0RERE6BoYaIiIicwv8HRl4yAYz6N3UAAAAASUVORK5CYII=",
						"text/plain": [
							"<Figure size 640x480 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				}
			],
			"source": [
				"bootstrapping(train_loader_PNL, test_dataset, num_epochs=50, learning_rate=0.1, device=device)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 19,
			"metadata": {},
			"outputs": [
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:32<00:00,  1.54it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 56.61%\n",
						"Standard deviation: 1.84\n"
					]
				},
				{
					"data": {
						"image/png": "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",
						"text/plain": [
							"<Figure size 640x480 with 1 Axes>"
						]
					},
					"metadata": {},
					"output_type": "display_data"
				}
			],
			"source": [
				"bootstrapping(train_loader_AE, test_dataset, num_epochs=50, learning_rate=0.1, device=device)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": []
		}
	],
	"metadata": {
		"kernelspec": {
			"display_name": "ig",
			"language": "python",
			"name": "python3"
		},
		"language_info": {
			"codemirror_mode": {
				"name": "ipython",
				"version": 3
			},
			"file_extension": ".py",
			"mimetype": "text/x-python",
			"name": "python",
			"nbconvert_exporter": "python",
			"pygments_lexer": "ipython3",
			"version": "3.11.9"
		}
	},
	"nbformat": 4,
	"nbformat_minor": 2
}