{
	"cells": [
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"# UCI Dataset: Taiwanese Bankruptcy Prediction"
			]
		},
		{
			"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(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 = 572 # https://archive.ics.uci.edu/dataset/572/taiwanese+bankruptcy+prediction\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: 5455\n",
						"Test size: 1364\n",
						"New sample size: 1090\n",
						"Number of classes: 2\n",
						"Number of features: 95\n"
					]
				}
			],
			"source": [
				"# Feature dimension\n",
				"D = X_train.shape[1]\n",
				"S = (5, 19)\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: 23\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 and Sampling"
			]
		},
		{
			"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 Submanifold"
			]
		},
		{
			"cell_type": "code",
			"execution_count": 8,
			"metadata": {},
			"outputs": [
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Dimension of Local Data Sub-Manifold: 72\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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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",
						"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": [
						"  5%|▌         | 10/200 [00:23<07:26,  2.35s/it]"
					]
				},
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 200/200 [07:38<00:00,  2.29s/it]\n"
					]
				},
				{
					"data": {
						"text/plain": [
							"[<matplotlib.lines.Line2D at 0x7fe92c081110>]"
						]
					},
					"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",
				"        #100 , 1 , 28 , 28 ---> (100 , 28*28)\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, 95]), Labels shape: torch.Size([64])\n",
						"none loader:\n",
						"Images shape: torch.Size([64, 95]), Labels shape: torch.Size([64])\n",
						"PNL_augmented loader:\n",
						"Images shape: torch.Size([64, 95]), Labels shape: torch.Size([64])\n",
						"AE_augmented loader:\n",
						"Images shape: torch.Size([64, 95]), 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.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=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": [
						"  0%|          | 0/50 [00:00<?, ?it/s]"
					]
				},
				{
					"name": "stderr",
					"output_type": "stream",
					"text": [
						"100%|██████████| 50/50 [01:58<00:00,  2.36s/it]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 96.59%\n",
						"Standard deviation: 0.65\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": [
						"100%|██████████| 50/50 [00:40<00:00,  1.23it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 96.36%\n",
						"Standard deviation: 0.65\n"
					]
				},
				{
					"data": {
						"image/png": "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mjRJO3fulOT9vq53B8t52qFDh+RwONS8efNTnm/evLkOHDjgp1YFjqo+rq7/d+/e7Y8mNRqmaeree+/VkCFD1L17d0n0tzdkZGRo8ODBKikpUWRkpObOnauuXbu6/gGmrz3rww8/1Jo1a7Rq1arTXuPvt2cNHDhQ7777rjp16qScnBw98cQTOv/887Vx40av93WjDx9VDMM45WfTNE97Dt5D/3ve7bffrvXr12vZsmWnvUZ/e07nzp2Vnp6uY8eO6ZNPPtGUKVO0ePFi1+v0tedkZ2frrrvu0jfffKPQ0NAzXkefe8aYMWNcf+7Ro4cGDx6s9u3b65133tGgQYMkea+vG/20S9OmTWW1Wk8b5cjNzT0t0cHzqlZO0/+edccdd+izzz7TwoUL1apVK9fz9LfnBQcHq0OHDurXr5+mTZum1NRUvfDCC/S1F6xevVq5ubnq27evbDabbDabFi9erBdffFE2m83Vr/S5d0RERKhHjx7avn271/9+N/rwERwcrL59+2rBggWnPL9gwQKdf/75fmpV4Gjbtq0SExNP6f/S0lItXryY/q8F0zR1++23a86cOfr+++/Vtm3bU16nv73PNE3Z7Xb62gtGjBihjIwMpaenux79+vXT9ddfr/T0dLVr144+9yK73a7NmzerRYsW3v/7Xeclqw3Ahx9+aAYFBZkzZ840N23aZN59991mRESEuWvXLn83rVEoKCgw165da65du9aUZE6fPt1cu3atuXv3btM0TfPJJ580Y2JizDlz5pgZGRnmtddea7Zo0cLMz8/3c8sbnj/84Q9mTEyMuWjRInP//v2uR3Fxsesa+ttzpk6dai5ZssTMzMw0169fb/7lL38xLRaL+c0335imSV/7wsm7XUyTPvek++67z1y0aJG5c+dOc/ny5eZll11mRkVFub4bvdnXARE+TNM0X375ZbN169ZmcHCw2adPH9fWRNTdwoULTUmnPaZMmWKaZsWWrUcffdRMTEw0Q0JCzIsuusjMyMjwb6MbqOr6WZL51ltvua6hvz3nd7/7nevfjWbNmpkjRoxwBQ/TpK994Zfhgz73nGuuucZs0aKFGRQUZCYlJZkTJkwwN27c6Hrdm31tmKZp1n38BAAAoGYa/ZoPAABQvxA+AACATxE+AACATxE+AACATxE+AACATxE+AACATxE+AACATxE+AACATxE+AACATxE+AACATxE+AACATxE+AACAT/0/M+dG3MNzWEEAAAAASUVORK5CYII=",
						"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:33<00:00,  1.48it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 96.61%\n",
						"Standard deviation: 0.67\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": [
						"100%|██████████| 50/50 [00:33<00:00,  1.48it/s]\n"
					]
				},
				{
					"name": "stdout",
					"output_type": "stream",
					"text": [
						"Mean accuracy: 95.85%\n",
						"Standard deviation: 0.62\n"
					]
				},
				{
					"data": {
						"image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAAGdCAYAAACyzRGfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABFfUlEQVR4nO3de1yUZd4/8M8MA8NpZhQQARkRTygiWB5xUdE8Vh46bFqt2WHddMUyW0tre6r9bWG1udrJai07eqg8ZLWSugpmhgmKECoeOJ9FZQYGGJiZ+/cHzCgpwsDM3Mh83q/XvJ6YueeeL/fjOh/v67q+l0QQBAFEREREDiIVuwAiIiJyLgwfRERE5FAMH0RERORQDB9ERETkUAwfRERE5FAMH0RERORQDB9ERETkUAwfRERE5FAysQv4PZPJhOLiYigUCkgkErHLISIiojYQBAFVVVUICgqCVHrjexudLnwUFxdDrVaLXQYRERG1Q0FBAYKDg294TKcLHwqFAkBj8UqlUuRqiIiIqC20Wi3UarXle/xGOl34MA+1KJVKhg8iIqKbTFumTHDCKRERETkUwwcRERE5FMMHERERORTDBxERETkUwwcRERE5FMMHERERORTDBxERETkUwwcRERE5lFXhY/369YiMjLQ0AIuOjsbu3bubHXPq1CnMmjULKpUKCoUCY8aMQX5+vk2LJiIiopuXVeEjODgYq1evRkpKClJSUjBp0iTMnj0bmZmZAIDz588jJiYGgwYNQmJiIk6cOIEXXngB7u7udimeiIiIbj4SQRCEjpzAx8cHb7zxBh577DHMmzcPrq6u+Pzzz9t9Pq1WC5VKBY1Gw/bqRERENwlrvr/bPefDaDRiy5Yt0Ol0iI6Ohslkwg8//ICBAwdi2rRp8Pf3x+jRo7Fz584bnkev10Or1TZ7EBERUddldfjIyMiAt7c35HI5Fi1ahB07diA8PBzl5eWorq7G6tWrMX36dOzZswd33XUX7r77biQlJbV4vvj4eKhUKstDrVZ36BdqSbXegH/9mIWV29LRwZs9RERE1AFWD7vU19cjPz8flZWV2LZtGzZs2ICkpCR069YNvXr1wv33349NmzZZjp81axa8vLywefPm655Pr9dDr9dbfjZvyWvrYZe6BiMGvZAAADjxf1Oh8nS12bmJiIicnTXDLjJrT+7m5ob+/fsDAEaMGIGjR49i3bp1ePvttyGTyRAeHt7s+MGDB+PQoUMtnk8ul0Mul1tbhtXcXV3g6+WGi7p6FFXWMnwQERGJpMN9PgRBgF6vh5ubG0aOHImsrKxmr585cwYhISEd/RibCOrmAQAo0dSKXAkREZHzsurOx3PPPYcZM2ZArVajqqoKW7ZsQWJiIhISGoczVqxYgblz52L8+PGYOHEiEhIS8N133yExMdEetVstqJs7Moo0KK5k+CAiIhKLVeGjrKwM8+fPR0lJCVQqFSIjI5GQkIApU6YAAO666y68//77iI+PxxNPPIGwsDBs27YNMTExdineWuY7H0WVdSJXQkRE5LysCh8fffRRq8c8+uijePTRR9tdkD31agofvPNBREQkHqfa2yWI4YOIiEh0ThU+AlWNbd4ZPoiIiMTjVOHDPOxSqq2DwWgSuRoiIiLn5FThw89bDlcXCUwCUFalb/0NREREZHNOFT6kUgkCVU29Pjj0QkREJAqnCh9AY68PAChi+CAiIhKFE4YP84oX9vogIiISg9OFD/b6ICIiEpfThQ/2+iAiIhKX04UPc68PzvkgIiISh9OFDw67EBERicvpwkdgU/jQ1hlQrTeIXA0REZHzcbrw4S2XQeXhCoC9PoiIiMTgdOEDuDLplPM+iIiIHM8pw0evbuYN5tjrg4iIyNGcMnxwuS0REZF4nDJ8mPd3YfggIiJyPKcMH9zfhYiISDxOGT4svT40DB9ERESO5pThwzzno1RTB5NJELkaIiIi5+KU4cNfIYeLVIIGo4CKar3Y5RARETkVpwwfMhcpApSc90FERCQGpwwfwJVJp+z1QURE5FhOGz643JaIiEgcThs+2GKdiIhIHE4bPq60WGf4ICIiciSnDR9B7PVBREQkCoYPTjglIiJyKKcPH5d09ahrMIpcDRERkfNw2vChdJfBWy4DwHkfREREjuS04UMikbDXBxERkQicNnwA7PVBREQkBqcOH+z1QURE5HhWhY/169cjMjISSqUSSqUS0dHR2L1793WPffzxxyGRSLB27Vpb1GkX7PVBRETkeFaFj+DgYKxevRopKSlISUnBpEmTMHv2bGRmZjY7bufOnThy5AiCgoJsWqytsdcHERGR41kVPmbOnInbb78dAwcOxMCBA/HKK6/A29sbycnJlmOKiooQFxeHL7/8Eq6urjYv2JbY64OIiMjxZO19o9FoxNdffw2dTofo6GgAgMlkwvz587FixQoMGTKkTefR6/XQ6/WWn7VabXtLslqvblcmnAqCAIlE4rDPJiIiclZWTzjNyMiAt7c35HI5Fi1ahB07diA8PBwA8Nprr0Emk+GJJ55o8/ni4+OhUqksD7VabW1J7dZT6Q6JBNAbTLikq3fY5xIRETkzq+98hIWFIS0tDZWVldi2bRsWLFiApKQk1NbWYt26dTh27JhVdxBWrVqF5cuXW37WarUOCyBuMil6eMtRXqVHcWUdfL3lDvlcIiIiZyYRBEHoyAkmT56Mfv36YfDgwVi+fDmk0is3U4xGI6RSKdRqNXJzc9t0Pq1WC5VKBY1GA6VS2ZHS2mTOuz8jraAS7/9pOKZHBNj984iIiLoia76/2z3nw0wQBOj1esyfPx+TJ09u9tq0adMwf/58PPLIIx39GLvp1c0DaQWVXG5LRETkIFaFj+eeew4zZsyAWq1GVVUVtmzZgsTERCQkJMDX1xe+vr7Njnd1dUVAQADCwsJsWrQtBbHXBxERkUNZFT7Kysowf/58lJSUQKVSITIyEgkJCZgyZYq96rM79vogIiJyLKvCx0cffWTVyds6z0NMV1qss9cHERGRIzj13i7AlV4fJRx2ISIicginDx+BqsY5H+VVeugNRpGrISIi6vqcPnz4eLlBLmu8DGUafStHExERUUc5ffiQSCSWoZciDr0QERHZndOHD+DqDeYYPoiIiOyN4QPs9UFERORIDB9grw8iIiJHYvgAe30QERE5EsMH2OuDiIjIkRg+cKXXR3FlLTq4yS8RERG1guEDV4ZddPVGaGsNIldDRETUtTF8AHB3dYGvlxsA9vogIiKyN4aPJuz1QURE5BgMH00svT643JaIiMiuGD6aBLHFOhERkUMwfDTpZRl2Ya8PIiIie2L4aBKoYq8PIiIiR2D4aML9XYiIiByD4aOJedilVFsHg9EkcjVERERdF8NHEz9vOVxdJDAJQFmVXuxyiIiIuiyGjyZSqcQy74NDL0RERPbD8HEVzvsgIiKyP4aPq7DXBxERkf0xfFwliMMuREREdsfwcRXznY8SNhojIiKyG4aPq5jnfHDYhYiIyH4YPq7SizvbEhER2R3Dx1UCm8KHts6AqroGkashIiLqmhg+ruItl0Hl4QoAKNFw3gcREZE9MHz8jnnSacGlGpErISIi6poYPn6nj68nACDvIsMHERGRPTB8/E4fPy8AQO5FnciVEBERdU0MH79jvvORU8HwQUREZA8MH7/Tx7fxzgeHXYiIiOzDqvCxfv16REZGQqlUQqlUIjo6Grt37wYANDQ04Nlnn8XQoUPh5eWFoKAgPPTQQyguLrZL4fZiHnYpvFyDeoNJ5GqIiIi6HqvCR3BwMFavXo2UlBSkpKRg0qRJmD17NjIzM1FTU4Njx47hhRdewLFjx7B9+3acOXMGs2bNslftduGvkMPD1QUmoTGAEBERkW1JBEEQOnICHx8fvPHGG3jssceuee3o0aMYNWoU8vLy0Lt37zadT6vVQqVSQaPRQKlUdqS0dpu+9iBOl1bh44dHYNKgnqLUQEREdDOx5vtb1t4PMRqN+Prrr6HT6RAdHX3dYzQaDSQSCbp169biefR6PfR6veVnrVbb3pJsJtTPC6dLq5BbwTsfREREtmb1hNOMjAx4e3tDLpdj0aJF2LFjB8LDw685rq6uDitXrsQDDzxwwwQUHx8PlUpleajVamtLsrkQXy63JSIisherw0dYWBjS0tKQnJyMxYsXY8GCBTh58mSzYxoaGjBv3jyYTCa89957NzzfqlWroNFoLI+CggJrS7K5UL/G5ba5XPFCRERkc1YPu7i5uaF///4AgBEjRuDo0aNYt24dPvjgAwCNweO+++5DTk4O9u/f3+q4j1wuh1wub0fp9mNebpvLXh9EREQ21+E+H4IgWOZsmIPH2bNnsW/fPvj6+na4QDFwuS0REZH9WHXn47nnnsOMGTOgVqtRVVWFLVu2IDExEQkJCTAYDLj33ntx7NgxfP/99zAajSgtLQXQuCLGzc3NLr+APZiX29Y2GFF4uQZ9e3iLXRIREVGXYVX4KCsrw/z581FSUgKVSoXIyEgkJCRgypQpyM3Nxa5duwAAw4YNa/a+AwcOIDY21lY1251EIkGIrydOl1Yh7yLDBxERkS1ZFT4++uijFl/r06cPOtgypFMxL7fNqdBhotjFEBERdSHc26UFIZY9XjjplIiIyJYYPlpgXm6bw+W2RERENsXw0YIQLrclIiKyC4aPFoRyuS0REZFdMHy0gLvbEhER2QfDRwvMy20BII/zPoiIiGyG4eMGzG3Wczjvg4iIyGYYPm7A3Gady22JiIhsh+HjBrjcloiIyPYYPm6AjcaIiIhsj+HjBq4st61Fg5HLbYmIiGyB4eMGzMttjSYBhZdrxS6HiIioS2D4uIGrl9uy0ykREZFtMHy0wrzcNpfzPoiIiGyC4aMV5uW2vPNBRERkGwwfrehjHnbhclsiIiKbYPhoheXOB4ddiIiIbILhoxXmOR9cbktERGQbDB+t6KnkclsiIiJbYvhoBZfbEhER2RbDRxtwuS0REZHtMHy0AZfbEhER2Q7DRxtwuS0REZHtMHy0AZfbEhER2Q7DRxtwuS0REZHtMHy0QU+lHO6uUi63JSIisgGGjzaQSCRc8UJERGQjDB9tZAkfXPFCRETUIQwfbRTi17jiJY8rXoiIiDqE4aONQpvufOTwzgcREVGHMHy0kXm5bR7nfBAREXUIw0cbmed8FHC5LRERUYcwfLQRl9sSERHZhlXhY/369YiMjIRSqYRSqUR0dDR2795teV0QBLz00ksICgqCh4cHYmNjkZmZafOixcDltkRERLZhVfgIDg7G6tWrkZKSgpSUFEyaNAmzZ8+2BIzXX38da9aswTvvvIOjR48iICAAU6ZMQVVVlV2KdzQutyUiIuo4q8LHzJkzcfvtt2PgwIEYOHAgXnnlFXh7eyM5ORmCIGDt2rV4/vnncffddyMiIgKffvopampqsGnTJnvV71BcbktERNRx7Z7zYTQasWXLFuh0OkRHRyMnJwelpaWYOnWq5Ri5XI4JEybg8OHDNilWbFxuS0RE1HEya9+QkZGB6Oho1NXVwdvbGzt27EB4eLglYPTs2bPZ8T179kReXl6L59Pr9dDr9ZaftVqttSU5TIgvl9sSERF1lNV3PsLCwpCWlobk5GQsXrwYCxYswMmTJy2vSySSZscLgnDNc1eLj4+HSqWyPNRqtbUlOUyoH5fbEhERdZTV4cPNzQ39+/fHiBEjEB8fj6ioKKxbtw4BAQEAgNLS0mbHl5eXX3M35GqrVq2CRqOxPAoKCqwtyWH8FVeW2xZxuS0REVG7dLjPhyAI0Ov1CA0NRUBAAPbu3Wt5rb6+HklJSRg7dmyL75fL5Zalu+ZHZyWVXllum8OhFyIionaxas7Hc889hxkzZkCtVqOqqgpbtmxBYmIiEhISIJFIsGzZMrz66qsYMGAABgwYgFdffRWenp544IEH7FW/w/Xx9cLp0irkVeiAMLGrISIiuvlYFT7Kysowf/58lJSUQKVSITIyEgkJCZgyZQoA4JlnnkFtbS3++te/4vLlyxg9ejT27NkDhUJhl+LFYF5um8vltkRERO0iEQRBELuIq2m1WqhUKmg0mk45BLPl13ys3J6B2LAe+OSRUWKXQ0RE1ClY8/3NvV2sFMIup0RERB3C8GEl83LbQi63JSIiaheGDyuZl9sauNyWiIioXRg+rMTltkRERB3D8NEOIb5NK14474OIiMhqDB/tMMC/cenwmbIqkSshIiK6+TB8tMOgwMbwcaqE4YOIiMhaDB/tMDiwcf1yVmkVjKZO1SaFiIio02P4aIc+vl5wd5WitsGI/EvsdEpERGQNho92cJFKENbTPPSiFbkaIiKimwvDRzsNCmgcejnN8EFERGQVho92Gtw06fQkJ50SERFZheGjnQY1TTo9Xco7H0RERNZg+GinwU3DLoWXa6GtaxC5GiIiopsHw0c7qTxdEaRyB9C45JaIiIjahuGjAyxDL5x0SkRE1GYMHx3ASadERETWY/joAMtyW046JSIiajOGjw64us26iW3WiYiI2oThowP6+HpCLpOipp5t1omIiNqK4aMDZC5SDGxqs86hFyIiorZh+OggTjolIiKyDsNHB3GPFyIiIuswfHSQedLpKQ67EBERtQnDRweZh10KLtWiim3WiYiIWsXw0UHdPN0QyDbrREREbcbwYQODAhrvfpxi+CAiImoVw4cNmPd4OcVJp0RERK1i+LCBwdxgjoiIqM0YPmxgcNOwC9usExERtY7hwwZC/bzgJpNCV29EwWW2WSciIroRhg8baGyz7g0AOMVOp0RERDfE8GEjgwM46ZSIiKgtGD5sxLzihRvMERER3ZhV4SM+Ph4jR46EQqGAv78/5syZg6ysrGbHVFdXIy4uDsHBwfDw8MDgwYOxfv16mxbdGZknnXLYhYiI6MasCh9JSUlYsmQJkpOTsXfvXhgMBkydOhU6nc5yzFNPPYWEhAR88cUXOHXqFJ566iksXboU3377rc2L70zMdz7yL9WgWm8QuRoiIqLOy6rwkZCQgIcffhhDhgxBVFQUNm7ciPz8fKSmplqO+eWXX7BgwQLExsaiT58++Mtf/oKoqCikpKTYvPjOxMfLDT2VcgBAFodeiIiIWtShOR8ajQYA4OPjY3kuJiYGu3btQlFREQRBwIEDB3DmzBlMmzbtuufQ6/XQarXNHjcryw63HHohIiJqUbvDhyAIWL58OWJiYhAREWF5/q233kJ4eDiCg4Ph5uaG6dOn47333kNMTMx1zxMfHw+VSmV5qNXq9pYkukEBnHRKRETUmnaHj7i4OKSnp2Pz5s3Nnn/rrbeQnJyMXbt2ITU1FW+++Sb++te/Yt++fdc9z6pVq6DRaCyPgoKC9pYkusGBnHRKRETUGll73rR06VLs2rULBw8eRHBwsOX52tpaPPfcc9ixYwfuuOMOAEBkZCTS0tLwr3/9C5MnT77mXHK5HHK5vJ3ldy7mYRdzm3WpVCJyRURERJ2PVXc+BEFAXFwctm/fjv379yM0NLTZ6w0NDWhoaIBU2vy0Li4uMJlMHa+2kwv184KbixTVegMKL9eKXQ4REVGnZNWdjyVLlmDTpk349ttvoVAoUFpaCgBQqVTw8PCAUqnEhAkTsGLFCnh4eCAkJARJSUn47LPPsGbNGrv8Ap2Jq4sUA3p6I7NYi1OlWvT29RS7JCIiok7Hqjsf69evh0ajQWxsLAIDAy2PrVu3Wo7ZsmULRo4ciQcffBDh4eFYvXo1XnnlFSxatMjmxXdGg9hmnYiI6IasuvMhCK1vFx8QEICNGze2u6CbnXnS6WlOOiUiIrou7u1iY4O5xwsREdENMXzY2KCmPV7yLtVAxzbrRERE12D4sDFfbzn8FXIIApBVxqEXIiKi32P4sINBgZx0SkRE1BKGDzvgpFMiIqKWMXzYwWAutyUiImoRw4cdXFnxUtWm5clERETOhOHDDvr2YJt1IiKiljB82IGrixT9/b0BcOiFiIjo9xg+7GSQedJpKSedEhERXY3hw07Mk05PFvPOBxER0dUYPuxkSK/G8PFbsUbkSoiIiDoXhg87GRKkAgAUXq5FZU29yNUQERF1HgwfdqLycEWIrycA4LciDr0QERGZMXzYUUTT3Q8OvRAREV3B8GFHEb0aw0dGEcMHERGRGcOHHUU0TTrNZPggIiKyYPiwI/OwS+7FGmjrGkSuhoiIqHNg+LCj7l5u6NXNAwCQyUmnREREABg+7G5o07yP3zj0QkREBIDhw+4i2GyMiIioGYYPOxvCOx9ERETNMHzYmXnSaXaFDtV6g8jVEBERiY/hw856KOQIULpDEIBTJZx0SkRExPDhAJZmY4UceiEiImL4cABOOiUiIrqC4cMBuNyWiIjoCoYPBzAPu5wrr0ZtvVHkaoiIiMTF8OEAPZXu6KGQwyQAJznplIiInBzDh4NEBDVtMsd5H0RE5OQYPhyE8z6IiIgaMXw4iLnTaQY3mCMiIifH8OEg5kmnZ8uqUNfASadEROS8GD4cJEjlDh8vNxhMArJKq8Quh4iISDRWhY/4+HiMHDkSCoUC/v7+mDNnDrKysq457tSpU5g1axZUKhUUCgXGjBmD/Px8mxV9M5JIJBgSxGZjREREVoWPpKQkLFmyBMnJydi7dy8MBgOmTp0KnU5nOeb8+fOIiYnBoEGDkJiYiBMnTuCFF16Au7u7zYu/2XDSKRERESCz5uCEhIRmP2/cuBH+/v5ITU3F+PHjAQDPP/88br/9drz++uuW4/r27WuDUm9+EZbwwUmnRETkvDo050OjafwXvI+PDwDAZDLhhx9+wMCBAzFt2jT4+/tj9OjR2LlzZ4vn0Ov10Gq1zR5dlfnOR1ZpFeoNJpGrISIiEke7w4cgCFi+fDliYmIQEREBACgvL0d1dTVWr16N6dOnY8+ePbjrrrtw9913Iykp6brniY+Ph0qlsjzUanV7S+r0grt7QOXhinqjCWfKOOmUiIicU7vDR1xcHNLT07F582bLcyZT47/mZ8+ejaeeegrDhg3DypUrceedd+L999+/7nlWrVoFjUZjeRQUFLS3pE5PIpFc2eGW8z6IiMhJtSt8LF26FLt27cKBAwcQHBxsed7Pzw8ymQzh4eHNjh88eHCLq13kcjmUSmWzR1cWEdQ074MrXoiIyElZNeFUEAQsXboUO3bsQGJiIkJDQ5u97ubmhpEjR16z/PbMmTMICQnpeLVdACedEhGRs7MqfCxZsgSbNm3Ct99+C4VCgdLSUgCASqWCh4cHAGDFihWYO3cuxo8fj4kTJyIhIQHfffcdEhMTbV78zcgcPk6VaGEwmiBzYZ83IiJyLlZ9861fvx4ajQaxsbEIDAy0PLZu3Wo55q677sL777+P119/HUOHDsWGDRuwbds2xMTE2Lz4m1GIjye85TLoDSacu1AtdjlEREQOZ/WwS1s8+uijePTRR9tVUFcnlTZ2Oj2ScwkZhRoMCujac1yIiIh+j/f8RWAeesks5rwPIiJyPgwfIjA3G8vgclsiInJCDB8iMPf6OFmshdHUtqEsIiKiroLhQwShft7wdHNBbYMR2Zx0SkRETobhQwQuUgnCA5s6nbLZGBERORmGD5GYJ51mFHLSKREROReGD5FYOp3yzgcRETkZhg+RmFe8nCzWwsRJp0RE5EQYPkTSr4cX5DIpqvUG5F7UiV0OERGRwzB8iETmIsVgy6RTzvsgIiLnwfAhoqGWHW4574OIiJwHw4eIzM3GMgoZPoiIyHkwfIjo1t7dAQCpeZdxsVovcjVERESOwfAhogE9FYgKVqHeaMJXKYVil0NEROQQDB8ie3BMCABg0695XHJLREROgeFDZDMjg6B0l6HgUi0Onr0gdjlERER2x/AhMg83F9wzPBgA8OWRfJGrISIisj+Gj07gwdGNQy//O1WG4spakashIiKyL4aPTqC/vzfG9PWBSQC2/Mq7H0RE1LUxfHQSf2qaeLrlaAEajCaRqyEiIrIfho9OYmp4APy85Siv0mPfyTKxyyEiIrIbho9Owk0mxdyRjRNPvziSJ3I1RERE9sPw0YncP6o3JBLg53MXkX2hWuxyiIiI7ILhoxMJ7u6JiWH+AIBNXHZLRERdFMNHJ/OnMb0BAF+nFqKuwShyNURERLbH8NHJTBjoj17dPKCpbcAP6SVil0NERGRzDB+djItUggdGN9794MRTIiLqihg+OqH7Rqghk0pwPL8SmcUascshIiKyKYaPTqiHQo5pEQEAuN8LERF1PQwfndSfmvZ72Xm8CFV1DSJXQ0REZDsMH53UmL4+6NfDCzX1RuxMKxa7HCIiIpth+OikJBKJZbfbL5PzIAiCyBURERHZBsNHJ3bP8GC4u0pxurQKqXmXO3w+QRDYO4SIiERnVfiIj4/HyJEjoVAo4O/vjzlz5iArK6vF4x9//HFIJBKsXbu2o3U6JZWHK2ZFBQEAPk9u/7Jbk0nA3pNluHv9YYT/XwI2/JRtqxKJiIisZlX4SEpKwpIlS5CcnIy9e/fCYDBg6tSp0Ol01xy7c+dOHDlyBEFBQTYr1hmZh16+TSvG7HcO4fPkPGhq2zYBtcFowvZjhZi+7iAWfpaC4/mVMAnAP384ha9SCuxZtk1drNZjw0/ZqKk3iF0KERHZgMyagxMSEpr9vHHjRvj7+yM1NRXjx4+3PF9UVIS4uDj8+OOPuOOOO2xTqZOKUnfDwnGh2PhzLk4UanCiUIN/fn8S0yMCcN8INaL7+kIqlTR7T12DEV+lFOCDpGwUVdYCALzlMvxpTAjqGoz45HAuVm5Lh9LdFdOblvR2Zs9uS8e+U+WoqK7HyhmDxC6HiIg6yKrw8XsaTWMDLB8fH8tzJpMJ8+fPx4oVKzBkyJBWz6HX66HX6y0/a7XajpTUJT1/Rzgen9APO48X4auUApwpq8a3acX4Nq0Yvbp54I8jgnHPrcFQerjii+Q8fHwoBxd19QAAXy83PBoTij+NCYHKwxWCIKCm3oCvUgrxxObj+OSRkRjb30/k37Bl58qrsO9UOQDguxPFeHZ6GCQSSSvvIiKizqzd4UMQBCxfvhwxMTGIiIiwPP/aa69BJpPhiSeeaNN54uPj8fLLL7e3DKfh5y3Hn8f1xWMxoUgv1OCrlALsOlGMosparN13Fmv3nYWHqwtqmyaU9urmgccn9MV9I9Rwd3WxnEcikeDVu4ZCU9uAHzPLsPCzFGxaOAZR6m4i/WY3tuGnHMt/F1XW4nhBJW7t3V3EiqitLuvqseiLVIQFKPCP2RGtv4GInEa7V7vExcUhPT0dmzdvtjyXmpqKdevW4ZNPPmnzv05XrVoFjUZjeRQU3DxzEcQgkUgQpe6GV+4aiqPPT8a6ecPwh/6+AIDaBiMG9vTGv+dGIXFFLB6K7tMseJjJXKRYN+8WjO3nC129EQ9v/BXnyqsc/au0qryqDtuPFQEABvb0BgB8f4Kb7d0MBEHAczsycCTnEj77JQ8HTpeLXRIRdSISoR0NJJYuXYqdO3fi4MGDCA0NtTy/du1aLF++HFLplUxjNBohlUqhVquRm5vb6rm1Wi1UKhU0Gg2USqW1pTmtwss1uFhdj6G9VNfMAWlJtd6AB/+TjBOFGgSq3PHN4rHo1c3DzpW23Zt7svD2/nO4pXc3/DW2PxZ+loIApTsOr5zU5t+RxPFVSgGe+Sbd8nPfHl74cdl4uLpwdT9RV2XN97dVfxMIgoC4uDhs374d+/fvbxY8AGD+/PlIT09HWlqa5REUFIQVK1bgxx9/tP43oTYL7u6JKHU3q76UveUybHxkFPr7e6NEU4f5G46golrf+hsdoKbeYFle/JdxfTF+oB8U7jKUauuQYoOeJ2Q/eRd1eHlXJgDgr7H94OfthuwLOnz2C3dpJqJGVoWPJUuW4IsvvsCmTZugUChQWlqK0tJS1NY2rqjw9fVFREREs4erqysCAgIQFhZml1+AOsbHyw2fPzYKvbp5ILtChwUf/wptJ9hL5pvUQlTWNKC3jyemDgmAXOaCqeGNK3O+T2e7+c7KYDRh2dY06OqNGBXqg6enhuFvUxv/t7923xlc7CThlojEZVX4WL9+PTQaDWJjYxEYGGh5bN261V71kQMEqjzw+WOj4OvlhsxiLf78aYqonVCNJsEy0fTP40Lh0nQ3586oQADAfzNKYTSx3Xxn9Pb+czieXwmFuwz/njsMLlIJ/jhCjfBAJarqDFiz94zYJRJRJ2D1sMv1Hg8//HCL78nNzcWyZcs6WCbZW98e3vj00VFQyGX4NecS7ll/GOmFlaLUsiezFPmXatDN0xX3Dg+2PB/T3w/dPF1RUa3HkeyLotRGLUvNu4y3958FAPxzToRl/pCLVIIXZ4YDADb/mo9TJVxOT+TsOPuLLCJ6qfDRwyOh8nBFZrEWc979GS/tykS13nGdRQVBwAcHG9u/zx8TAk+3K6vBXV2kmD6kcejlu3SueulMqvUGPLU1DSYBmDMsCLOH9Wr2+ui+vrgjMhAmAfjHdye5USKRk2P4oGZGhfpg3/IJmDMsCCYB+ORwLia/mYQfM0utOk9uhQ7vHjiHTw/nWvVFk5p3GWkFlXCTSfFQdJ9rXr8zsrFdf8JvJWgwmqyqieznpV2ZyL9Ug17dPPCPOdfv6bFqxiDIZVL8kn3R6j9PRNS1MHzQNXoo5Fg77xZ8/tgohPh6olRbh8c/T8XCz1JQ3NSu/XrKtHXY8FM2Zr9zCLH/SsQbP2bhxV2Z+Mf3bf+X7odNdz3uubUXeijk17w+pq8PfL3ccLmmAYfPc+ilM/hvRgm+SS2EVAL8e+4wKN1dr3tccHdPPD6+L4DG/YW4wzKR82L4oBaNG9ADPy4bj7iJ/SGTSrD3ZBmmrEnCx4dyLBM+L+vqselIPuZ9+AvGxP8P//zhFE4UauAilWBESGMn0o0/5+LV/55qNYBkX6jG3lNlAIDHYvpe9xiZixQzhjatejnBVS9iK9HUYtX2DADA4th+GBXqc8PjF8X2Q4DSHYWXa/HRoZwbHktEXVe7mozZE5uMdU5nyqrw3PYMS4+Nob1U6KGQ4+CZCzBctfJkREh3zBoWhNuHBsLPW45NR/Lx3I7GL6dFE/rdcG+W53dk4Msj+Zg82B8bFoxssZbk7IuY92EylO4ypPx9CtxkzNBiMJkEzP/4CH4+dxGRwSpsWzy2TU3Edh4vwrKtafB0c8GBv8Wip9LdAdUSkb3ZrckYOa+BPRX46vFoxN89FEp3GTKKNNh/uhwGk4AhQUqsmjEIP6+chG8Wj8VD0X3g5904ZPLA6N74f7MbNxh8P+l8i0stK6r1+Ca1EACwcNz173qYjezjA3+FHNo6A346e8GGv2XbCIKAl7/LRMxr+3H4fIXDP7+z+OhQDn4+dxEeri5YO3dYm7uXzh4WhFt6d0NNvRGvJ2TZuUoi6owYPqjNpFIJ7h/VG/97OhZxE/tj2eQB2Ld8An54Yhwen9Cvxdbs86P7WJZavr3/HNbtO3vNMZ//kge9wYSoYFWrt+5dpBLcPrSx58f3Iqx62XK0ABt/zkXh5Vo8vPEo9p0sc3gNYjtdqsUbPzYGhxfuDEffHt5tfq9EIsGLMxsD6bZjhUgrqLRHiUTUiTF8kNV6KOT427QwLJs8EP392/al88gfQvH87YMBAP/edwbvHjhnea223mhppb5wfN82bUo4s6nh2N6TZQ6duHiqRIuXmlqH9/H1RL3BhMe/SMW3aUUOq0FsRpOAZ79JR73RhMmDe+L+UWqrzzFM3Q1339q4HPfl7zK59JbIyTB8kMMsHN8Xz04fBAB448csvJ90HkDjv34v6eoR3N3D0sejNbeouyNI5Y5qvQGJWY4ZeqnWG7Dky2PQG0yIDeuBPU9NwF239ILRJGDZ1jR8kewce5d8cjgXJwo1ULjL8MpdEW3ewfr3np0+CJ5uLjieX4lv0zh5mMiZMHyQQy2O7YenpwwEAKzefRofHjxvWfXwWEwoZG2cNyCVSnBHpHnoxf5fXIIg4O87MpBdoUOA0h1r7hsGN5kUb/4xCg9Fh0AQgL/v/A3rE89bfd4zZVU3Tc+Swss1eHNP43DLqhmDOzRZtKfSHUsm9gfQ+GdB58BmdkQkLoYPcriltw3Ak7cNAAC8+t/TyKnQQekuw30jrLt9b2449r9T5aipt+8X11cpBdiZVgwXqQRvP3ALfLzcADSGoJdnDUFc05foawmn8VrC6VaHEarqGvDJzzm4bU0Spv77IOZ9mNzpv3wFQcDfd/6GmnojRvXxwbyR1g+3/N5jMaFQ+3igVFuHd64aiiOiro3hg0SxbPIALJnYz/Lzn8aEwEsuu8E7rhUZrILaxwO1DUbsP11u6xItTpdq8X/fNs7zeHrqQIzs03xCrEQiwd+mhWHVjMYhpfWJ5/H3nb/BdJ3N786WVeGFnb9hzKv/w0vfnUT2BR2Axs6uj316FLX1nbfx1q4TxUjMugA3FylevXsopNL2Dbdczd3VBf93Z+Pk0w0/ZSP7QnW7zyUIArIvVHP+CNFNgOGDRCGRSPC3qWFYMS0MMf398OdWlte2dI47hjbe/fj+hH1WveiumucxYWAPLBrfr8VjH5/QD/F3D4VEAnx5JB9PfZWGBqMJBqMJCb+V4oH/JGPKvw/i8+Q86OqN6O/vjf83ewg2LRwNhVyG5OxL+Mvn7d9R2GQSrht4bOGyrh7/+O4kACBuUv82TzRui8mD/REb1gMNRgEvdWDfl+d3/oZJbybhmW/SGUCIOjk2GaOb2m9FGtz59iHIZVKkvjAF3q3cPamo1sPd1aXV44DGf0k//dUJbD9ehJ5KOf77xDj4el/b8v33dp0oxvKtaTCYBAwP6Y6SyloUa+oAAFIJMCW8JxZE90F0P1/LZM2U3Et46ONfUVNvxOTB/njvweFWNU87nn8ZK75Jx4UqPWZGBeLe4WpEBavaPRn09/729Ql8k1qIgT298f3ScTZv7JZbocPUfx9EvdGE9/80HNMj2jbx2OyH9BIs2XTM8vPSSf3x9NQwm9ZIRDdmzfc3wwfd1ARBwKQ3k5BTocPaucMw55Ze1xzTYDRh38kyfHkkH4fOVUAuk2JGRAD+OEKN6L6+LQ4ffJVSgGe+SYdUAmxeOAaj+/q2ua79p8uw+IvGOyYA4Ovlhnmj1HhgdEiL/VAOn6/AIxuPQm8w4fahAXhr3i2tTsCtN5jw9v6zePfAOfz+pke/Hl64d7gad93SCwGq9k8M/flcBR7ccAQSCfDNorEY3tQ239b+9WMW3jlwDr26eWDf8gnwcHNp0/sKL9dgxrqfUFVnwKhQH/yacwkA8MpdEXhwdIhdaiWiazF8kFN5c08W3t5/7pq27MWVtdjyaz62HC1AeZX+uu/t1c0D9wwPxh+HB0Pt42l5/kxZFWa9cwh1DSasmBZmWZVhjZTcS/jslzxMHNQDtw8NhFzW+pdp0pkLWPhpCuqNJswZFoQ37xsGlxbC0ZmyKjy1NQ2ZxVoAjZ1DZw8Lwq60YiRklqKuoTH4SCVAzIAeuHd4MKaG94S7a9u+1AGgrsGIaWsPIu9iDRZEh+Dl2dffsdYWauoNmPxmEoo1dXhiUn8sb8OdC4PRhHkfJiMl7zKGqbvh60XReHv/Obz1v7OQSoAP54/A5PCedquZiK5g+CCnklVahWlrD8LVRYKjz0/G8YJKfJmch/2nyy13A/y83TB3pBrzRvbGRV09vk4pwK4Txaiqu7LCZExfH/xxuBoTwnpg3ofJOFdejXED/PDpI6NsMrmyrfaeLMPiL1JhMAmYO0KN+N9N7jSaBHx8KAdv7MlCvcGEbp6u+OecCMvqH6BxNY15t9mjuZctzyvcZZgZFYRHxvbBgJ6KVmtZvfs03k86j0CVO/Yun9Cm4aqO2J1RgsVfHoObTIq9T41HiK/XDY9fu+8M1u47C2+5DP99Yhx6+3pCEAQ8uy0dX6UUwt1Vis0Lx+CW3va5W0NEVzB8kNOZsiYJZ8uroXCXNQsU0X198eCY3pgaHnDNPIW6BiN+zCzFN6mFOHSuAub/JUglgEkA/BVy/PfJcZZ9ahzph/QSLN18DCYBeCg6BC/PGgKJRIKCSzV4+usTlqGFiWE98No9kfC/Qb+N3Aodth8rxLZjRSiqrLU8PzGsBxaO74vovr7XnRvyW5EGs9/9GUaTgA0POeYOgiAIeOjjX/HT2QrcNsgfHz3c8gaDR3MvYe4Hv8Ak4JohtwajCQs/S0Fi1gX4eLlh2+KxCPW7cZAhoo5h+CCn89b/zlo2rVO6y3DvcDUeGN27zasyiiprsT21EF+nFiL/Ug2kEmDTwjEYY8U8D1vbfqwQT399AoIALBwXigH+Crz8XSZ09UZ4urnghTvDMW+kus2TSk0mAcnZF/HZL3n48WSpJWwNCVLiL+P74vahgZbN4QxGE+567zAyijS4Y2gg3n3wVnv9mtc4V16NGesOosEo4KMFI3Db4GtDj6a2Abev+wlFlbW4+5ZeWDN32DXH6PQGzPswGRlFGoT4emLb4rGiBEkiZ8HwQU6npt6At/efQ18/L8yMCrJqXsPVTCYBx/IvQy5zwdBglY2rtN7mX/OxantGs+dG9umON/84DL19PVt4V+tyK3T4+OccfJVSYJkbEqhyx6N/CMXcUWp8dbQA//zhFJTuMux7egL8FY7d9j5+9yl8kJSN3j6e2PPU+Gb//xQEAXGbj+OH9BL09vHEf58c1+Jw0IUqPe5Zfxj5l2oQFazC5r+MgaebfYeOiJwVwwdRF/Lp4Vy8uCsTbi5SPD11IP48rm+Lk1CtdVlXjy+P5OGTw3moqG6clOstl8FgMqGuwYTVdw/FvFG9bfJZ1tDpDZj0ZiLKtHosnzIQTzR1xAWAr44W4Jlt6ZBJJfhm8VgMU3e74bmyL1TjnvWHcbmmARPDeuA/D41ocxt/Imo7hg+iLuZ4/mX4esk7dLfjRuoajPg2rQj/+SkH58obu4yO6euDzQvH2KxXiLV2nSjGE5uPQy6TYt/yCVD7eOL8hWrc+dYh1DYY8cz0MPw1tm2rkI7lX8YD/0lGXYMJ80aqm5rBifN7EXVVDB9E1C4mk4CkMxeQnH0Rj8aEdmjjuI4SBAH3/ycZydmXMG1IT7x1/y24Z/1h/Fakxdh+vvjisdFWrULae7IMj3+eApMA+HnLIZGgad6LAJPQ+Hnm/wsAMyIC8dq9kfb55Yi6IIYPIuoSskqrcPtbP8FoEvCH/r74+dxFdPd0xe4nx7ercdqXR/Lwws7frmnI1pJvl/wBUa0M6xBRI4YPIuoy/t/3J/HRoRzLzx/OH46pQ6xrv361Uk0dKqr1kEgAqUQCiQSQQAKpBGgciZFg7b4z+D69xOErfYhuZtZ8f3PaNxF1assmD8C3acWoqNZj/piQDgUPAAhQubd61yRuUn98n16C3b+VIP9ijd3m2hA5K075JqJOTeHuio8fHoGVMwbh+TsGO+QzBwUoMWFgD5gEYMOhbId8JpEzYfggok4vMrgbFk3o1+7+Le3x+Pi+ABo3GLykq3fY5xI5A4YPIqLriO7ni4heStQ1mPD5L3lil0PUpTB8EBFdh0QiwV/G9wMAfPZLLuoajCJXRNR1MHwQEbXg9ogABHf3wEVdPb5JLRS7HKIug+GDiKgFMhcpHosJBQBs+CkbxrY2CCGiG2L4ICK6gftGqKHycEXuxRrsPVkqdjlEXQLDBxHRDXjJZZg/JgQA8MHBbHSyvoxENyWrwkd8fDxGjhwJhUIBf39/zJkzB1lZWZbXGxoa8Oyzz2Lo0KHw8vJCUFAQHnroIRQXF9u8cCIiR1kwtg/cZFIcz69ESt5lscshuulZFT6SkpKwZMkSJCcnY+/evTAYDJg6dSp0Oh0AoKamBseOHcMLL7yAY8eOYfv27Thz5gxmzZpll+KJiByhh0KOe27tBQD4IIlNx4g6qkN7u1y4cAH+/v5ISkrC+PHjr3vM0aNHMWrUKOTl5aF3796tnpN7uxBRZ3T+QjUmr0mCIAD7lk9Af39vsUsi6lSs+f7u0JwPjUYDAPDx8bnhMRKJBN26dbvu63q9HlqtttmDiKiz6dfDG5MH9wTQuPKFiNqv3eFDEAQsX74cMTExiIiIuO4xdXV1WLlyJR544IEWU1B8fDxUKpXloVar21sSEZFdmVuubz9WhPKqOpGrIbp5tTt8xMXFIT09HZs3b77u6w0NDZg3bx5MJhPee++9Fs+zatUqaDQay6OgoKC9JRER2dWIPj64tXc31BtN+PRwrtjlEN202hU+li5dil27duHAgQMIDg6+5vWGhgbcd999yMnJwd69e2849iOXy6FUKps9iIg6K3PL9S+S86HTG0SuhujmZFX4EAQBcXFx2L59O/bv34/Q0NBrjjEHj7Nnz2Lfvn3w9fW1WbFERGKbEt4ToX5e0NQ2YOtR3qklag+rwseSJUvwxRdfYNOmTVAoFCgtLUVpaSlqa2sBAAaDAffeey9SUlLw5Zdfwmg0Wo6pr+eW1ER083ORSvDncVdarhdcqhG5IqKbj1VLbSUSyXWf37hxIx5++GHk5uZe924IABw4cACxsbGtfgaX2hJRZ1fXYETsG4ko1dbBy80FK28fjAdH9YZUev2/I4mcgTXf3x3q82EPDB9EdDPIrdBhxTcncDS3seNpdF9fvH5vJNQ+niJXRiQOh/X5ICJyVn38vLD1L9F4cWY4PFxd8Ev2RUxbexCf/ZILE3e/Jbohhg8ionaSSiV45A+hSFg2DqNDfVBTb8T/fZuJ+/+TjLyLOrHLu67KmnoUVdaKXQY5OYYPIqIOCvH1wuaFY/CP2UPg6eaCIzmXMG3tQXx8KKdT3QX5NecSJv4rETGv7ccTm48j+0K12CWRk+KcDyIiGyq4VINnvknHL9kXAQBDe6kQGayCv8Id/ko5eirljf+tkMPXWw4XB01S3XG8EM9+k4F6o8nynFQC3HNrMJ64bQDnqlCHccIpEZGITCYBm37NR/x/T0FXb2zxOKkE8POWI6ibB+4bocZ9I4Ihc7HtDWlBEPDvfWfx1v/OAgCmDwnAwvGheO/AefzvdDkAwNVFgrkj1YibOAABKnebfj45D4YPIqJOoERTi/2ny1Gm1eNCVR3KtHqUV9WhXKtHRbUevx+R6evnhb9NC8OMiIAWWxtYo67BiGe+SceuE8UAgEUT+uGZaWGWJcHH8i9jzZ4zOHSuAgDgJpNi/pgQLI7tBz9veYc/n5wLwwcRUSdnNAm4WK1HeZUeydkX8V7ieVzSNTZjjApW4dnpgzC2v1+7z3+xWo/HP09FSt5lyKQS/HNOBOaN6n3dY5OzL+LNPVmWZcMeri54KDoEM6OCMCRIaZMgRF0fwwcR0U2mqq4B//kpBxt+ykZN01DNuAF+eHb6IET0Ull1rnPl1Xj0k6PIv1QDhbsM7/9pOP7QSpARBAE/na3Am3uycKJQY3neXyFHbFgPTBrkjz/094PC3dX6X46cAsMHEdFN6kKVHu/sP4tNv+ajwdj41/PMqCD8bepAhPh6tfr+w+cqsOiLVGjrDFD7eGDjwyPR31/R5s8XBAH7TpXjq5QC/HyuwhKEgMa5ISP7+GBimD8mDvJHvx5evCtCFgwfREQ3ufyLNXhzbxa+TWucryGTStDHzwvectmVh/uV//aSy1Bbb8B7iedhMAkYHtIdH84fDt8OzN3QG4z4NecSDpy+gANZ5cipaN67JMTXE09PDcOsqKAO/a7UNTB8EBF1EZnFGryekIWkMxfa/J6ZUUF4495IuLu62LSWnAodDpwux4GschzJvmRZtnv3Lb3w8uwhHJJxcgwfRERdzPkL1SjX6lGtN6Ba34BqvRHVdQbo9AZU6w2oqjOgpt6A0aE+WDC2j92HQ3R6Az44mI139p+FSQDUPh5YO3cYhof42PVzOxNBEDjsdBWGDyIicojUvEt4cksaCi/XQioB4iYNwBOT+re5X0lWaRV+yCiBySQgPEiJIUFKqLt7drodgnV6A06XVuFUiRYnS7Q4WazF6VItVB6uiB3YOAcmZoAfvOUyUeor0dTiPwdzsDOtCEHd3DF3ZG/MigqCysNxd6MYPoiIyGGq6hrw4q5MbD9WBAC4pXc3rJ07rMUJsuXaOnybVowdx4twskR7zevechkGByowJEiF8EAlwoOUGNDTG3KZbYeRWlJvMOFIzkWkF2pwskSLU8Va5FzUobVvSzcXKUaF+mDiIH/cNsgfffxanyDcUdkXqvF+0nnsOF5kmaBsJpdJccfQQNw3Uo3RoT52v0vD8EFERA6360Qxnt+Rgao6A7zcXPDy7Ajcc2svSCQS6PQG/JhZih3Hi/DzuQpLgzVXFwkmDPSHn7cbMou1yCqrQr3BdM25ZVIJhvRSYVZUEGZGBcJfYdtOrAajCb9kX8R3J4qR8FsptHWGa47xV8gRHqTE4EAlwgOVGByoQHFlHfY3zYPJu1jT7Pi+fl6YOMgfI0K6Q+nhCi+5DN5yF3g1TRD2cpO1u73+b0UavJd4Drt/K7WEotGhPlg4ri/yLtVg69F8nCm7sndPqJ8X7huhxj3De9n82pkxfBARkSiKKmvx1NY0/JpzCQAwIyIAcpkUP2aWobbhyrLd4SHdMeeWXrhzaCC6e7lZnm8wmpB9QYeTJRpkFjUOcWQWa6GpbbAcI5UAMQN64O5bemHqkJ7wdGvfUIfRJOBo7iVL4LjY1OQNAHoo5Iju64vwIHPQUKKHouWVQ4IgILtpQu7+0+X4NecSDG3YVNDDtTGMqDxk6NXdE+ruHlD7eELd3RO9fTyh9vGAysMVEokEgiDgSM4lvHvgHH46W2E5x+TB/lgc2x/DQ7o3qyetoBJbjxbguxPFljb/LlIJJg3yx9wRasSG9bBpO3+GDyIiEo3RJOCDg+exZs+ZZl/AfXw9cdctwZhzS1CbepaYCYKAosrGVvU7jhfheH6l5TVPNxdMGxKAObf0wh/6+bb4ZSoIAuoaTNDWNSD/Ug3+m1GCH9JLUF6ltxzj4+WGGREBuDMyCKNCfTq06V9VXQMOna3A/tPlOHehGjq9ATq9EdX6xknCbQkmZgq5DME+npAAlmEqF6kEMyMDsSi2HwYF3Pi7Uqc34If0EmxNKUBq3mXL+39ZOQn+StvdBWH4ICIi0aUXVuLNPWcQ4uuJu27phWHqbjaZd5BbocPOtCLsPF6E3KuGOvy85ZgwsAcMJhM0tQ3Q1DZAW9sATa0B2tqGZjv6mindZZg2JAAzo4Iw9gbhxZYEQYDeYGoWSC7X1KPwcg0KLtWi4HINCi7VoOByLS5cFY6Axv137hsRjL+M64fevtbvRHy2rApfpRRAU9uA1++NstWvBIDhg4iInIB5aGHn8SJ8l15i2RvnRlykEnT3dENMf1/MjArCuAE94Cazf+Bor9p6Y2MouVyDy7oGjBvoZ7c5Gx3F8EFERE6lwWjCT2cvIKNQCy+5C1QerlB6uEJ11UPp4QovNxf25rATa76/xVmQTEREZEOuLlJMGtQTkwb1FLsUaoPOe6+JiIiIuiSGDyIiInIohg8iIiJyKIYPIiIiciiGDyIiInIohg8iIiJyKIYPIiIiciiGDyIiInIohg8iIiJyKIYPIiIiciiGDyIiInIohg8iIiJyKIYPIiIicqhOt6utIAgAGrfmJSIiopuD+Xvb/D1+I50ufFRVVQEA1Gq1yJUQERGRtaqqqqBSqW54jERoS0RxIJPJhOLiYigUCkgkEpueW6vVQq1Wo6CgAEql0qbnpmvxejsWr7dj8Xo7Fq+3Y7XneguCgKqqKgQFBUEqvfGsjk5350MqlSI4ONiun6FUKvmH14F4vR2L19uxeL0di9fbsay93q3d8TDjhFMiIiJyKIYPIiIiciinCh9yuRwvvvgi5HK52KU4BV5vx+L1dixeb8fi9XYse1/vTjfhlIiIiLo2p7rzQUREROJj+CAiIiKHYvggIiIih2L4ICIiIodymvDx3nvvITQ0FO7u7hg+fDh++uknsUvqMg4ePIiZM2ciKCgIEokEO3fubPa6IAh46aWXEBQUBA8PD8TGxiIzM1OcYm9y8fHxGDlyJBQKBfz9/TFnzhxkZWU1O4bX23bWr1+PyMhIS6Ol6Oho7N692/I6r7V9xcfHQyKRYNmyZZbneM1t56WXXoJEImn2CAgIsLxuz2vtFOFj69atWLZsGZ5//nkcP34c48aNw4wZM5Cfny92aV2CTqdDVFQU3nnnneu+/vrrr2PNmjV45513cPToUQQEBGDKlCmWfXyo7ZKSkrBkyRIkJydj7969MBgMmDp1KnQ6neUYXm/bCQ4OxurVq5GSkoKUlBRMmjQJs2fPtvwFzGttP0ePHsWHH36IyMjIZs/zmtvWkCFDUFJSYnlkZGRYXrPrtRacwKhRo4RFixY1e27QoEHCypUrRaqo6wIg7Nixw/KzyWQSAgIChNWrV1ueq6urE1QqlfD++++LUGHXUl5eLgAQkpKSBEHg9XaE7t27Cxs2bOC1tqOqqiphwIABwt69e4UJEyYITz75pCAI/PNtay+++KIQFRV13dfsfa27/J2P+vp6pKamYurUqc2enzp1Kg4fPixSVc4jJycHpaWlza6/XC7HhAkTeP1tQKPRAAB8fHwA8Hrbk9FoxJYtW6DT6RAdHc1rbUdLlizBHXfcgcmTJzd7ntfc9s6ePYugoCCEhoZi3rx5yM7OBmD/a93pNpaztYqKChiNRvTs2bPZ8z179kRpaalIVTkP8zW+3vXPy8sTo6QuQxAELF++HDExMYiIiADA620PGRkZiI6ORl1dHby9vbFjxw6Eh4db/gLmtbatLVu24NixYzh69Og1r/HPt22NHj0an332GQYOHIiysjL885//xNixY5GZmWn3a93lw4eZRCJp9rMgCNc8R/bD6297cXFxSE9Px6FDh655jdfbdsLCwpCWlobKykps27YNCxYsQFJSkuV1XmvbKSgowJNPPok9e/bA3d29xeN4zW1jxowZlv8eOnQooqOj0a9fP3z66acYM2YMAPtd6y4/7OLn5wcXF5dr7nKUl5dfk+jI9swzp3n9bWvp0qXYtWsXDhw4gODgYMvzvN625+bmhv79+2PEiBGIj49HVFQU1q1bx2ttB6mpqSgvL8fw4cMhk8kgk8mQlJSEt956CzKZzHJdec3tw8vLC0OHDsXZs2ft/ue7y4cPNzc3DB8+HHv37m32/N69ezF27FiRqnIeoaGhCAgIaHb96+vrkZSUxOvfDoIgIC4uDtu3b8f+/fsRGhra7HVeb/sTBAF6vZ7X2g5uu+02ZGRkIC0tzfIYMWIEHnzwQaSlpaFv37685nak1+tx6tQpBAYG2v/Pd4enrN4EtmzZIri6ugofffSRcPLkSWHZsmWCl5eXkJubK3ZpXUJVVZVw/Phx4fjx4wIAYc2aNcLx48eFvLw8QRAEYfXq1YJKpRK2b98uZGRkCPfff78QGBgoaLVakSu/+SxevFhQqVRCYmKiUFJSYnnU1NRYjuH1tp1Vq1YJBw8eFHJycoT09HThueeeE6RSqbBnzx5BEHitHeHq1S6CwGtuS08//bSQmJgoZGdnC8nJycKdd94pKBQKy3ejPa+1U4QPQRCEd999VwgJCRHc3NyEW2+91bI0kTruwIEDAoBrHgsWLBAEoXHJ1osvvigEBAQIcrlcGD9+vJCRkSFu0Tep611nAMLGjRstx/B6286jjz5q+XujR48ewm233WYJHoLAa+0Ivw8fvOa2M3fuXCEwMFBwdXUVgoKChLvvvlvIzMy0vG7Pay0RBEHo+P0TIiIiorbp8nM+iIiIqHNh+CAiIiKHYvggIiIih2L4ICIiIodi+CAiIiKHYvggIiIih2L4ICIiIodi+CAiIiKHYvggIiIih2L4ICIiIodi+CAiIiKHYvggIiIih/r/VUYA2E4o57wAAAAASUVORK5CYII=",
						"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)"
			]
		}
	],
	"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
}