{
	"cells": [
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"# UCI Dataset: Connectionist Bench (Sonar, Mines vs. Rocks)"
			]
		},
		{
			"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",
				"\n",
				"set_random_seed(40)\n",
				"k = 2\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 = 151 # https://archive.ics.uci.edu/dataset/151/connectionist+bench+sonar+mines+vs+rocks\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",
				"# 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: 166\n",
						"Test size: 42\n",
						"New sample size: 32\n",
						"Number of classes: 2\n",
						"Number of features: 60\n"
					]
				}
			],
			"source": [
				"D = X_train.shape[1]\n",
				"S = (2, 2, 3, 5)\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}\")"
			]
		},
		{
			"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: 9\n"
					]
				}
			],
			"source": [
				"B_LD = ld.default_B(S, 1, 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: 30\n"
					]
				}
			],
			"source": [
				"# Construct the constrained coordinates\n",
				"B_BP = ld.default_B(S, 2, 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": [],
			"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 [00:11<00:00, 16.88it/s]\n"
					]
				},
				{
					"data": {
						"text/plain": [
							"[<matplotlib.lines.Line2D at 0x7f60745d9890>]"
						]
					},
					"execution_count": 11,
					"metadata": {},
					"output_type": "execute_result"
				},
				{
					"data": {
						"image/png": "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",
						"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([16, 60]), Labels shape: torch.Size([16])\n",
						"none loader:\n",
						"Images shape: torch.Size([16, 60]), Labels shape: torch.Size([16])\n",
						"PNL_augmented loader:\n",
						"Images shape: torch.Size([16, 60]), Labels shape: torch.Size([16])\n",
						"AE_augmented loader:\n",
						"Images shape: torch.Size([16, 60]), Labels shape: torch.Size([16])\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.min()/4)  # Add Gaussian noise with 1/4 of the standard deviation\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=16)\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\n",
				"\n",
				"One-layer (effectively a logistic regression) due to the simplicity of the dataset."
			]
		},
		{
			"cell_type": "code",
			"execution_count": 15,
			"metadata": {},
			"outputs": [],
			"source": [
				"class MLP(nn.Module):\n",
				"    def __init__(self, input_size, hidden_size=10, 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 mena accuracy and its standard deviation 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": [
						"  0%|          | 0/50 [00:00<?, ?it/s]"
					]
				},
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:09<00:00,  5.10it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 78.81%\n",
						"Standard deviation: 11.22\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_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": [
						"  0%|          | 0/50 [00:00<?, ?it/s]"
					]
				},
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:10<00:00,  4.65it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 75.00%\n",
						"Standard deviation: 9.97\n"
					]
				},
				{
					"data": {
						"image/png": "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b731Vvp22tpZ9fX1sixL69atSx+jze3z5JNPyrKsAZeqqqr07U62tSeCxWuvvaZ169bpb//2b7V7927dcsstWrlypY4dO+Z2aRNeV1eXFi1apOeee27I2//xH/9RP/7xj/Xcc89px44dqqqq0t13353eEwYj19jYqDVr1mj79u1qaGhQb2+vVqxYoa6urvR9aG/7TJs2TU899ZR27typnTt36o477tCXvvSl9A9X2to5O3bs0KZNm7Rw4cIBx2lze82bN0/Nzc3py759+9K3OdrWxgP+4i/+wqxevXrAsdmzZ5vHHnvMpYq8SZLZsmVL+noikTBVVVXmqaeeSh+7cOGCiUQi5qc//akLFXpLa2urkWQaGxuNMbR3LkyZMsX87Gc/o60d1NHRYa699lrT0NBgbrvtNvPoo48aY3h/2+2JJ54wixYtGvI2p9t6wvdYdHd3a9euXVqxYsWA4ytWrNB7773nUlX54ciRI2ppaRnQ9qFQSLfddhttb4P29nZJUmlpqSTa20nxeFybN29WV1eXli1bRls7aM2aNbrnnnt01113DThOm9vv0KFDqqmpUV1dnR588EEdPnxYkvNtnfNNyOzW1tameDyuysrKAccrKyvV0tLiUlX5IdW+Q7X90aNH3SjJM4wxWr9+vW6++WbNnz9fEu3thH379mnZsmW6cOGCiouLtWXLFs2dOzf9w5W2ttfmzZv1/vvva8eOHRfdxvvbXjfeeKNefvllzZo1SydOnND3v/993XTTTdq/f7/jbT3hg0XK4C3YjTG2bsuO4dH29lu7dq327t2rP/zhDxfdRnvb57rrrtOePXt09uxZ/frXv9aqVavU2NiYvp22tk9TU5MeffRRvfPOOyosLBz2frS5PVauXJn+84IFC7Rs2TLNnDlTv/zlL/X5z39eknNtPeGHQqZOnSq/339R70Rra+tFaQz2Ss0wpu3t9a1vfUtvvvmmfve732natGnp47S3/YLBoK655hotXbpU9fX1WrRokZ555hna2gG7du1Sa2urlixZokAgoEAgoMbGRj377LMKBALpdqXNnVFUVKQFCxbo0KFDjr+/J3ywCAaDWrJkiRoaGgYcb2ho0E033eRSVfmhrq5OVVVVA9q+u7tbjY2NtP0oGGO0du1avf7663r33XdVV1c34Hba23nGGMViMdraAXfeeaf27dunPXv2pC9Lly7VQw89pD179mjGjBm0uYNisZg++OADVVdXO//+HvP0z3Fg8+bNpqCgwPz85z83Bw4cMOvWrTNFRUXmk08+cbu0Ca+jo8Ps3r3b7N6920gyP/7xj83u3bvN0aNHjTHGPPXUUyYSiZjXX3/d7Nu3z3zta18z1dXVJhqNulz5xPPNb37TRCIRs3XrVtPc3Jy+nDt3Ln0f2ts+GzZsMNu2bTNHjhwxe/fuNY8//rjx+XzmnXfeMcbQ1rmQeVaIMbS5nf7mb/7GbN261Rw+fNhs377d3HvvvaakpCT9e9HJtvZEsDDGmJ/85Cdm+vTpJhgMmuuvvz59ih7G5ne/+52RdNFl1apVxpjkaUtPPPGEqaqqMqFQyNx6661m37597hY9QQ3VzpLMSy+9lL4P7W2fb3zjG+mfGeXl5ebOO+9MhwpjaOtcGBwsaHP7PPDAA6a6utoUFBSYmpoa8+Uvf9ns378/fbuTbc226QAAwDYTfo4FAAAYPwgWAADANgQLAABgG4IFAACwDcECAADYhmABAABsQ7AAAAC2IVgAAADbECwAAIBtCBYAAMA2BAsAAGAbggUAALDN/wdpXhyTMHOeKQAAAABJRU5ErkJggg==",
						"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": [
						"  0%|          | 0/50 [00:00<?, ?it/s]"
					]
				},
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:11<00:00,  4.32it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 80.00%\n",
						"Standard deviation: 6.49\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_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": [
						"  0%|          | 0/50 [00:00<?, ?it/s]"
					]
				},
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [00:11<00:00,  4.25it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 79.29%\n",
						"Standard deviation: 9.44\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
}