{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a785a4fe-c18e-4d3d-8397-8e5c693c8ee1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mlp\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import warnings\n",
    "import math\n",
    "\n",
    "from copy import deepcopy\n",
    "from skactiveml.classifier import SklearnClassifier\n",
    "from skactiveml.pool import UncertaintySampling, QueryByCommittee, RandomSampling, BatchBALD, DiscriminativeAL, GreedySamplingX, GreedySamplingTarget, QueryByCommittee, \\\n",
    "    KLDivergenceMaximization, ExpectedModelChangeMaximization\n",
    "from skactiveml.utils import call_func, unlabeled_indices\n",
    "from sklearn.datasets import fetch_openml\n",
    "from sklearn.ensemble import VotingClassifier\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from skorch import NeuralNetClassifier\n",
    "from torch import nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import transforms\n",
    "from tqdm import tqdm\n",
    "import matplotlib.colors as mcolors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "805fd0e6-937a-4db0-b773-5172a4659123",
   "metadata": {},
   "outputs": [],
   "source": [
    "mlp.rcParams[\"figure.facecolor\"] = \"white\"\n",
    "\n",
    "MISSING_LABEL = -5\n",
    "RANDOM_STATE = 0\n",
    "FONTSIZE = 12\n",
    "\n",
    "np.random.seed(RANDOM_STATE)\n",
    "torch.manual_seed(RANDOM_STATE)\n",
    "torch.cuda.manual_seed(RANDOM_STATE)\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n",
    "torch.backends.cudnn.deterministic = True\n",
    "\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f712aa2a-1f3d-4532-95cd-f412e19251ec",
   "metadata": {},
   "source": [
    "# 1. Classification"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ecd43708-0f97-45b4-9f40-05b9dcf96710",
   "metadata": {},
   "outputs": [],
   "source": [
    "def spiral_xy(i, total_points, spiral_num, n_shape = 50):\n",
    "    \"\"\"\n",
    "    Create the data for a normalized spiral.\n",
    "\n",
    "    Arguments:\n",
    "        i runs from 0 to total_points-1.\n",
    "        total_points is the total number of points in the spiral.\n",
    "        spiral_num is 1 or -1.\n",
    "        n_shape is an int which determines the shape of spiral wrt function, unscaled_spiral_xy.\n",
    "    \"\"\"\n",
    "    # Normalize i to always fit in the range [0, 96], which is the original range.\n",
    "    i_normalized = i * n_shape / (total_points - 1)\n",
    "    φ = i_normalized / 16 * math.pi\n",
    "    r = 6.5 * ((104 - i_normalized) / 104)\n",
    "    x = (r * math.cos(φ) * spiral_num) / 13 + 0.5\n",
    "    y = (r * math.sin(φ) * spiral_num) / 13 + 0.5  # spiral_num mirrors the orientation of the spiral\n",
    "    return (x, y)\n",
    "\n",
    "\n",
    "def spiral(spiral_num, n=100, n_shape = 50):\n",
    "    \"\"\"\n",
    "    Generate either a clockwise (+1) spiral or a counter clockwise (-1) spiral for a total of n points.\n",
    "\n",
    "    Arguments:\n",
    "        spiral_num: 1 or -1 determines the orientation of the spiral.\n",
    "        n: total number of points in a spiral.\n",
    "    \"\"\"\n",
    "    return [spiral_xy(i, n, spiral_num, n_shape) for i in range(n//2)]\n",
    "\n",
    "\n",
    "def generate_spiral_data(n=100, n_train = 80, n_shape = 50, seed = RANDOM_STATE, default_label = True):\n",
    "    \"\"\"\n",
    "    Generate binary spiral classification data.\n",
    "\n",
    "    Arguments:\n",
    "        n: total number of points in a spiral.\n",
    "        n_train: numbr of training points.\n",
    "        seed: permutation randomization seed.\n",
    "        default_label: True uses label +/-1 and False uses label 0/1\n",
    "    \"\"\"\n",
    "    a = spiral(1,n,n_shape)\n",
    "    b = spiral(-1,n,n_shape)\n",
    "    # Combine spiral from both orientation as one and scaling feature space from (0,1)^2 to (-1,1)^2\n",
    "    X_all=2*np.concatenate((a,b),axis=0)-1 \n",
    "    X_all=np.append(X_all,np.ones((n,1)),axis=1) # Adding bias to the feature space\n",
    "    # concatenate the labels of the spiral, which is their orientation (+1/-1)\n",
    "    if default_label:\n",
    "        y_all=np.concatenate((np.ones(n//2),-np.ones(n//2))) \n",
    "    else:\n",
    "        y_all=np.concatenate((np.ones(n//2),np.zeros(n//2))) # reset -1 to 0.\n",
    "    # randomize data indices\n",
    "    np.random.seed(seed)\n",
    "    idx = np.random.permutation(n)\n",
    "    X_all = X_all[idx]\n",
    "    y_all = y_all[idx]\n",
    "    # Split into training and testing sets\n",
    "    X_train, y_train = X_all[:n_train], y_all[:n_train]\n",
    "    X_test, y_test = X_all[n_train:], y_all[n_train:]\n",
    "    \n",
    "    return X_all, y_all, X_train, y_train, X_test, y_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "84655ea3-c290-4d29-a6db-f37a6c94ba5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_all, y_all, X_train, y_train, X_test, y_test = generate_spiral_data(seed = RANDOM_STATE, default_label = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1079d287-9421-4ec0-9e43-7d9e9a509e50",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Convert data to float32 as required by PyTorch\n",
    "X_train = X_train.astype(np.float32)\n",
    "X_test = X_test.astype(np.float32)\n",
    "y_train = y_train.astype(np.int64)\n",
    "y_test = y_test.astype(np.int64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "379db825-63ca-4cd5-b418-d015b8d967e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "classes = np.unique(y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "39911c22-c990-4f12-9f83-6477b7f515ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(80, 3) (80,) [0 1]\n"
     ]
    }
   ],
   "source": [
    "# sanity check\n",
    "print(X_train.shape,y_train.shape, np.unique(y_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "84febba1-e60d-43db-84cc-b93b1ce3a503",
   "metadata": {},
   "outputs": [],
   "source": [
    "class ClassifierModule(nn.Module):\n",
    "    def __init__(self, n_classes=2, dropout=0.5):\n",
    "        super(ClassifierModule, self).__init__()\n",
    "        self.fc1 = nn.Linear(3, 623)  # Input is 3-dimensional (x, y, bias)\n",
    "        self.fc3 = nn.Linear(623, n_classes)  # Output is 2 classes (binary classification)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)  # Dropout applied only during training\n",
    "        x = self.fc3(x)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9d5b628c-2af5-4bd7-93d6-e8b4acbafc3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# create initial estimators\n",
    "estimators = []\n",
    "for i in range(5):\n",
    "    # Initialize the NeuralNetClassifier with skorch\n",
    "    net = NeuralNetClassifier(\n",
    "    ClassifierModule,\n",
    "    max_epochs=2000,\n",
    "    lr=0.001,\n",
    "    verbose=False,\n",
    "    criterion = torch.nn.CrossEntropyLoss,\n",
    "    optimizer=torch.optim.SGD,\n",
    "    optimizer__momentum=0.9,\n",
    "    optimizer__weight_decay=3e-3,\n",
    "    batch_size=16,\n",
    "    iterator_train__shuffle=True,  # Shuffle with the seed fixed\n",
    "    train_split=None)  # Disable internal validation split)\n",
    "\n",
    "    net.initialize()\n",
    "    clf = SklearnClassifier(\n",
    "        estimator=net,\n",
    "        missing_label=MISSING_LABEL,\n",
    "        random_state=i,\n",
    "        classes=classes,\n",
    "    )\n",
    "    estimators.append((f'clf {i}', clf))\n",
    "\n",
    "# Creat voting ensemble out of given ensemble list.\n",
    "ensemble_init = SklearnClassifier(\n",
    "    estimator=VotingClassifier(estimators=estimators, voting='soft'),\n",
    "    missing_label=MISSING_LABEL,\n",
    "    random_state=RANDOM_STATE,\n",
    "    classes=classes,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "45843287-2c29-4df2-8652-2b7c5edf23d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def scikit_activeml_clf(n_cycles,X_all,y_all,X_train,y_train,X_test,y_test,strategy, estimators, seed = RANDOM_STATE, plot = False):\n",
    "    # output is test/train accuracy rate, final ensemble, and chosen indices\n",
    "    torch.manual_seed(RANDOM_STATE)\n",
    "    torch.cuda.manual_seed(RANDOM_STATE)\n",
    "    \n",
    "    if strategy == 'greedyX':\n",
    "        qs = GreedySamplingX(random_state=RANDOM_STATE, missing_label=MISSING_LABEL)\n",
    "    elif strategy == 'qbc':\n",
    "        qs = QueryByCommittee(random_state=RANDOM_STATE, missing_label=MISSING_LABEL)\n",
    "    \n",
    "   \n",
    "    ensemble = deepcopy(ensemble_init)\n",
    "\n",
    "    # Create array of missing labels as initial labels.\n",
    "    y = np.full_like(y_train, fill_value=MISSING_LABEL, dtype=np.int64)\n",
    "    X = X_train\n",
    "\n",
    "    # Label one sample from each class for warm start. No warm start\n",
    "    # for i in range(2):\n",
    "    #     y[np.argwhere(y_train==i)[0]] = i\n",
    "    \n",
    "    \n",
    "    queries = []\n",
    "\n",
    "    # Execute active learning cycle.\n",
    "    for c in tqdm(range(n_cycles)):\n",
    "        # Fit and evaluate ensemble.\n",
    "        ensemble.fit(X, y) # base model\n",
    "        # test_acc = ensemble.score(X_test, y_test)\n",
    "        # train_acc = ensemble.score(X_train, y_train)\n",
    "        # train_acc_dict[qs_name][c] = train_acc\n",
    "\n",
    "        # Select and update training data.\n",
    "        query_idx = call_func(\n",
    "            qs.query,\n",
    "            X=X,\n",
    "            y=y,\n",
    "            clf=ensemble,\n",
    "            fit_clf=False,\n",
    "            ensemble=ensemble,\n",
    "            fit_ensemble=False,\n",
    "            batch_size=1,\n",
    "        )\n",
    "        # query_idx = ulbd_indices[query_idx]\n",
    "        y[query_idx] = y_train[query_idx]\n",
    "        queries.append(query_idx)\n",
    "\n",
    "    # Fit and evaluate ensemble after queries.\n",
    "    ensemble.fit(X, y)\n",
    "    test_acc = ensemble.score(X_test, y_test)\n",
    "    train_acc = ensemble.score(X_train, y_train)\n",
    "    \n",
    "    if plot:\n",
    "        # Plot decision boundary\n",
    "        x_min, x_max = -1, 1\n",
    "        y_min, y_max = -1, 1\n",
    "\n",
    "        # Create a grid of points\n",
    "        x1 = np.linspace(x_min, x_max, 100)\n",
    "        x2 = np.linspace(y_min, y_max, 100)\n",
    "        x1, x2 = np.meshgrid(x1, x2)\n",
    "        Xtest = np.c_[x1.ravel(), x2.ravel()]\n",
    "        Xtest = np.append(Xtest, np.ones((Xtest.shape[0], 1)), axis=1)  # Add the bias term\n",
    "        Xtest = Xtest.astype(np.float32)\n",
    "        # print(len(Xtest))\n",
    "        yest = ensemble.predict(Xtest)\n",
    "        # print(len(yest))\n",
    "        yest = yest.reshape(x1.shape)\n",
    "\n",
    "        # Create subplots\n",
    "        fig, ax = plt.subplots(figsize=(7, 7))\n",
    "\n",
    "        # Define the custom colors\n",
    "        colors = ['#920783', '#00b7c7']  # Switched the colors to match the image\n",
    "        cmap = mcolors.ListedColormap(colors)\n",
    "\n",
    "        # Plot the decision boundary with custom colors\n",
    "        ax.contourf(x1, x2, yest, alpha=0.3, cmap=cmap)\n",
    "        scatter = ax.scatter(X_train[:, 0], X_train[:, 1], c=y_train, edgecolor='k', s=20, cmap=cmap)\n",
    "\n",
    "        ax.set_xlabel('x1')\n",
    "        ax.set_ylabel('x2')\n",
    "        ax.set_xlim(x_min, x_max)\n",
    "        ax.set_ylim(y_min, y_max)\n",
    "\n",
    "        plt.show()\n",
    "        \n",
    "    return test_acc, train_acc, ensemble, queries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "62b39c1f-5bde-4ed8-904c-9f7f943ca5ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 1,  5, 10, 15, 20, 25, 30, 35, 40, 45, 50])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "itr_ls = np.arange(0,55,5)\n",
    "itr_ls[0] = 1\n",
    "itr_ls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d81600a7-889c-4060-8cca-8077c0c38658",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 41.20it/s]\n",
      "100%|██████████| 1/1 [00:00<00:00, 108.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [00:45<00:00,  9.13s/it]\n",
      "100%|██████████| 5/5 [00:45<00:00,  9.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [01:53<00:00, 11.32s/it]\n",
      "100%|██████████| 10/10 [01:55<00:00, 11.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 15/15 [03:10<00:00, 12.69s/it]\n",
      "100%|██████████| 15/15 [03:14<00:00, 12.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "15\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20/20 [04:58<00:00, 14.91s/it]\n",
      "100%|██████████| 20/20 [05:03<00:00, 15.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 25/25 [07:04<00:00, 16.97s/it]\n",
      "100%|██████████| 25/25 [07:13<00:00, 17.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "25\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 30/30 [09:42<00:00, 19.42s/it]\n",
      "100%|██████████| 30/30 [09:38<00:00, 19.30s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "30\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 35/35 [12:33<00:00, 21.53s/it]\n",
      "100%|██████████| 35/35 [12:50<00:00, 22.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "35\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 40/40 [16:44<00:00, 25.11s/it]\n",
      "100%|██████████| 40/40 [16:49<00:00, 25.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 45/45 [20:29<00:00, 27.32s/it]\n",
      "100%|██████████| 45/45 [20:20<00:00, 27.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "45\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [22:49<00:00, 27.40s/it]\n",
      "100%|██████████| 50/50 [22:34<00:00, 27.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50\n"
     ]
    }
   ],
   "source": [
    "test_acc_greedy = []\n",
    "train_acc_greedy = []\n",
    "test_acc_qbc = []\n",
    "train_acc_qbc = []\n",
    "for i in itr_ls:\n",
    "    test_acc, train_acc, ensemble, queries = scikit_activeml_clf(i,X_all,y_all,X_train,y_train,X_test,y_test,'greedyX', 623, RANDOM_STATE, False)\n",
    "    test_acc_greedy.append(test_acc)\n",
    "    train_acc_greedy.append(train_acc)\n",
    "    test_acc, train_acc, ensemble, queries = scikit_activeml_clf(i,X_all,y_all,X_train,y_train,X_test,y_test,'qbc', 623, RANDOM_STATE, False)\n",
    "    test_acc_qbc.append(test_acc)\n",
    "    train_acc_qbc.append(train_acc)\n",
    "    print(i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a2c3021f-44aa-43c9-a9b8-711bc6fb1c2e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle # for saving lists"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1bd0b749-4b81-4228-8e8b-4c65455acb9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(f'acc_greedyX_test50_seed0.pkl', 'wb') as f:\n",
    "    pickle.dump(test_acc_greedy, f)\n",
    "\n",
    "with open(f'acc_greedyX_train50_seed0.pkl', 'wb') as f:\n",
    "    pickle.dump(train_acc_greedy, f)\n",
    "    \n",
    "with open(f'acc_qbc_test50_seed0.pkl', 'wb') as f:\n",
    "    pickle.dump(test_acc_qbc, f)\n",
    "\n",
    "with open(f'acc_qbc_train50_seed0.pkl', 'wb') as f:\n",
    "    pickle.dump(train_acc_qbc, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a692e649-5af8-45be-8d8c-bd00cad00a2e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execute active learning using greedyX.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 15/15 [03:05<00:00, 12.39s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execute active learning using qbc.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 15/15 [03:06<00:00, 12.43s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Modified setup.\n",
    "n_cycles = 15\n",
    "batch_size = 1 # query 1 data point per step\n",
    "# n_sub_set = 1000 # no subset\n",
    "# qs_dict = {\n",
    "#     'random sampling': RandomSampling(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "#     'uncertainty sampling': UncertaintySampling(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "#     'query-by-committee': QueryByCommittee(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "#     'batch-bald': BatchBALD(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "# }\n",
    "qs_dict = {\n",
    "        'greedyX': GreedySamplingX(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "        'qbc': QueryByCommittee(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "}\n",
    "\n",
    "test_acc_dict = {key: np.zeros(n_cycles+1) for key in qs_dict}\n",
    "train_acc_dict = {key: np.zeros(n_cycles+1) for key in qs_dict}\n",
    "\n",
    "# Perform active learning with each query strategy.\n",
    "for qs_name, qs in qs_dict.items():\n",
    "    torch.manual_seed(RANDOM_STATE)\n",
    "    torch.cuda.manual_seed(RANDOM_STATE)\n",
    "\n",
    "    print(f'Execute active learning using {qs_name}.')\n",
    "\n",
    "    # Copy initial ensemble model.\n",
    "    ensemble = deepcopy(ensemble_init)\n",
    "\n",
    "    # Create array of missing labels as initial labels.\n",
    "    y = np.full_like(y_train, fill_value=MISSING_LABEL, dtype=np.int64)\n",
    "    X = X_train\n",
    "\n",
    "    # Label one sample from each class for warm start. No warm start\n",
    "    # for i in range(2):\n",
    "    #     y[np.argwhere(y_train==i)[0]] = i\n",
    "\n",
    "    # Execute active learning cycle.\n",
    "    for c in tqdm(range(n_cycles)):\n",
    "        # Fit and evaluate ensemble.\n",
    "        ensemble.fit(X, y) # base model\n",
    "        test_acc = ensemble.score(X_test, y_test)\n",
    "        test_acc_dict[qs_name][c] = test_acc\n",
    "        train_acc = ensemble.score(X_train, y_train)\n",
    "        train_acc_dict[qs_name][c] = train_acc\n",
    "\n",
    "        # ulbd_indices = np.random.choice(unlabeled_indices(y, MISSING_LABEL), n_sub_set)\n",
    "\n",
    "        # Select and update training data.\n",
    "        query_idx = call_func(\n",
    "            qs.query,\n",
    "            X=X,\n",
    "            y=y,\n",
    "            clf=ensemble,\n",
    "            fit_clf=False,\n",
    "            ensemble=ensemble,\n",
    "            fit_ensemble=False,\n",
    "            batch_size=batch_size,\n",
    "        )\n",
    "        # query_idx = ulbd_indices[query_idx]\n",
    "        y[query_idx] = y_train[query_idx]\n",
    "\n",
    "    # Fit and evaluate ensemble after queries.\n",
    "    ensemble.fit(X, y)\n",
    "    test_acc = ensemble.score(X_test, y_test)\n",
    "    test_acc_dict[qs_name][c] = test_acc\n",
    "    train_acc = ensemble.score(X_train, y_train)\n",
    "    train_acc_dict[qs_name][c] = train_acc\n",
    "        \n",
    "    # Plot decision boundary\n",
    "    x_min, x_max = -1, 1\n",
    "    y_min, y_max = -1, 1\n",
    "\n",
    "    # Create a grid of points\n",
    "    x1 = np.linspace(x_min, x_max, 100)\n",
    "    x2 = np.linspace(y_min, y_max, 100)\n",
    "    x1, x2 = np.meshgrid(x1, x2)\n",
    "    Xtest = np.c_[x1.ravel(), x2.ravel()]\n",
    "    Xtest = np.append(Xtest, np.ones((Xtest.shape[0], 1)), axis=1)  # Add the bias term\n",
    "    Xtest = Xtest.astype(np.float32)\n",
    "    # print(len(Xtest))\n",
    "    yest = ensemble.predict(Xtest)\n",
    "    # print(len(yest))\n",
    "    yest = yest.reshape(x1.shape)\n",
    "\n",
    "    # Create subplots\n",
    "    fig, ax = plt.subplots(figsize=(7, 7))\n",
    "\n",
    "    # Define the custom colors\n",
    "    colors = ['#920783', '#00b7c7']  # Switched the colors to match the image\n",
    "    cmap = mcolors.ListedColormap(colors)\n",
    "\n",
    "    # Plot the decision boundary with custom colors\n",
    "    ax.contourf(x1, x2, yest, alpha=0.3, cmap=cmap)\n",
    "    scatter = ax.scatter(X_train[:, 0], X_train[:, 1], c=y_train, edgecolor='k', s=20, cmap=cmap)\n",
    "\n",
    "    ax.set_xlabel('x1')\n",
    "    ax.set_ylabel('x2')\n",
    "    ax.set_xlim(x_min, x_max)\n",
    "    ax.set_ylim(y_min, y_max)\n",
    "\n",
    "    plt.show()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49a05724-aad4-461c-be94-1d60f0131bcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# visualize test accuracy\n",
    "cycles = np.arange(n_cycles+1, dtype=int)\n",
    "plt.figure(figsize=(16, 9))\n",
    "for qs_name, acc in test_acc_dict.items():\n",
    "    plt.plot(cycles, acc, label=f'{qs_name}: AULC={round(acc.mean(), 2)}')\n",
    "plt.xticks(cycles, fontsize=FONTSIZE)\n",
    "plt.yticks(fontsize=FONTSIZE)\n",
    "plt.xlabel('# cycle', fontsize=FONTSIZE)\n",
    "plt.ylabel('test accuracy', fontsize=FONTSIZE)\n",
    "plt.legend(loc='lower right', fontsize='x-large')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "407c6831-c6c1-4001-a1be-8a88cdbe3500",
   "metadata": {},
   "outputs": [],
   "source": [
    "# visualize test accuracy\n",
    "cycles = np.arange(n_cycles+1, dtype=int)\n",
    "plt.figure(figsize=(16, 9))\n",
    "for qs_name, acc in train_acc_dict.items():\n",
    "    plt.plot(cycles, acc, label=f'{qs_name}: AULC={round(acc.mean(), 2)}')\n",
    "plt.xticks(cycles, fontsize=FONTSIZE)\n",
    "plt.yticks(fontsize=FONTSIZE)\n",
    "plt.xlabel('# cycle', fontsize=FONTSIZE)\n",
    "plt.ylabel('train accuracy', fontsize=FONTSIZE)\n",
    "plt.legend(loc='lower right', fontsize='x-large')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4d8b2c6-7a0d-4cf6-a4e3-4d594339c656",
   "metadata": {},
   "source": [
    "# 2. Regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8eaa350-b562-45ee-99ea-133a5dbe8f6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data generationn\n",
    "def generate_quadratic_regression(n = 100, n_train = 80, seed = 0, noise = False, noise_param = 0.05, plot = True):\n",
    "    x_vals = np.linspace(-1, 1, n)  # Generate n points uniformly spaced between -1 and 1\n",
    "    y_true = x_vals ** 2  # Calculate y = x^2\n",
    "    \n",
    "    # Add some noise to make it a more realistic regression problem\n",
    "    if noise:\n",
    "        noise = noise_param * np.random.randn(n)\n",
    "        y_vals = y_vals + noise\n",
    "    else:\n",
    "        y_vals = y_true\n",
    "    \n",
    "    # Plot the generated data\n",
    "    if plot:\n",
    "        plt.figure(figsize=(7, 7))\n",
    "        plt.scatter(x_vals, y_true, color='blue', label='Data Points')\n",
    "        plt.plot(x_vals, y_vals, color='black', label='True y = x^2', linewidth=2)\n",
    "        \n",
    "        plt.title('Continuous Quadratic Regression Dataset')\n",
    "        plt.xlabel('x')\n",
    "        plt.ylabel('y')\n",
    "        plt.legend()\n",
    "        plt.show()\n",
    "    else:\n",
    "        pass\n",
    "\n",
    "    # Adding bias to the data\n",
    "    X_all = np.column_stack((x_vals, np.ones(n)))  # Shape: (n, 2) where the second column is the bias term\n",
    "    y_all = y_vals # y_all is unchanged\n",
    "\n",
    "    # randomly select X,y\n",
    "    np.random.seed(seed)\n",
    "    \n",
    "    # Randomly select 80 indices\n",
    "    selected_indices = np.random.choice(np.arange(n), size=n_train, replace=False)\n",
    "    unselected_indices = np.setdiff1d(np.arange(n), selected_indices)\n",
    "    \n",
    "    # Select the corresponding rows from X and values from Y for train dataset\n",
    "    X = X_all[selected_indices]\n",
    "    y = y_all[selected_indices]\n",
    "    \n",
    "    # Test set\n",
    "    X_test = X_all[unselected_indices]\n",
    "    y_test = y_all[unselected_indices]\n",
    "\n",
    "    return X_all, y_all, X, y, X_test, y_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3180b73-ed79-4d66-8294-9fc3e4df14c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_all, y_all, X_train, y_train, X_test, y_test = generate_quadratic_regression(seed = RANDOM_STATE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7573355-f00b-4fff-b747-ab13af2e33b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Convert data to float32 as required by PyTorch\n",
    "X_all = X_all.astype(np.float32)\n",
    "y_all = y_all.astype(np.float32)\n",
    "X_train = X_train.astype(np.float32)\n",
    "X_test = X_test.astype(np.float32)\n",
    "y_train = y_train.astype(np.float32)\n",
    "y_test = y_test.astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e31a4856-b5dc-48f3-9041-5359e0572edc",
   "metadata": {},
   "outputs": [],
   "source": [
    "class ClassifierModule(nn.Module):\n",
    "    def __init__(self, n_classes=1):\n",
    "        super(ClassifierModule, self).__init__()\n",
    "        self.fc1 = nn.Linear(2, 160) \n",
    "        self.fc3 = nn.Linear(160, n_classes) \n",
    "\n",
    "    def forward(self, x):\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)  # Dropout applied only during training\n",
    "        x = self.fc3(x)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b47170b5-ab33-4edc-89d9-927bbba7a539",
   "metadata": {},
   "outputs": [],
   "source": [
    "from skorch import NeuralNetRegressor\n",
    "from sklearn.ensemble import (\n",
    "    GradientBoostingRegressor,\n",
    "    RandomForestRegressor,\n",
    "    VotingRegressor,\n",
    ")\n",
    "from skactiveml.regressor import SklearnRegressor, NICKernelRegressor\n",
    "from sklearn.linear_model import LinearRegression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c78026b1-4ff8-48a6-8bc5-0b000573dbe2",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SklearnRegressorFixed(SklearnRegressor):\n",
    "    def predict(self, X):\n",
    "        predictions = super().predict(X)\n",
    "        # Flatten the output if it's 2D (n_samples, 1) to (n_samples,)\n",
    "        if predictions.ndim > 1:\n",
    "            predictions = predictions.ravel()\n",
    "        return predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9880998e-375e-4c03-8de7-1eb7e5aa00ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "# create initial estimators\n",
    "estimators = []\n",
    "for i in range(5):\n",
    "    # Initialize the NeuralNetRegressor with skorch\n",
    "    net = NeuralNetRegressor(\n",
    "        ClassifierModule, \n",
    "        max_epochs=2000,\n",
    "        lr=0.001,\n",
    "        verbose=False,\n",
    "        optimizer=torch.optim.SGD,\n",
    "        optimizer__momentum=0.9,\n",
    "        optimizer__weight_decay=3e-3,\n",
    "        batch_size=16,\n",
    "        iterator_train__shuffle=True,  # Shuffle with the seed fixed\n",
    "        train_split=None  # Disable internal validation split\n",
    "    )\n",
    "\n",
    "    net.initialize()\n",
    "    reg = SklearnRegressorFixed( \n",
    "        estimator=net,\n",
    "        missing_label=MISSING_LABEL,\n",
    "        random_state=i,\n",
    "    )\n",
    "    estimators.append((f'reg {i}', reg))\n",
    "\n",
    "# Create voting ensemble out of the regressor estimators.\n",
    "# ensemble_init = VotingRegressor(estimators=estimators)\n",
    "\n",
    "ensemble_init = SklearnRegressor(\n",
    "    estimator=VotingRegressor(estimators=estimators),\n",
    "    missing_label=MISSING_LABEL,\n",
    "    random_state=RANDOM_STATE,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93458584-83e8-4137-a5d4-47ccb11cb8cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import mean_squared_error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0e405ba-8a37-4b79-9b80-c770709d2764",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Modified setup.\n",
    "n_cycles = 10\n",
    "batch_size = 1 # query 1 data point per step\n",
    "\n",
    "qs_dict = {\n",
    "        'greedyX': GreedySamplingX(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "        'greedyTarget': GreedySamplingTarget(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "        'qbc': QueryByCommittee(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "        # 'kldiv': KLDivergenceMaximization(\n",
    "        #     random_state=RANDOM_STATE, missing_label=MISSING_LABEL,\n",
    "        #     integration_dict_target_val={\n",
    "        #         \"method\": \"assume_linear\",\n",
    "        #         \"n_integration_samples\": 3,\n",
    "        #     },\n",
    "        #     integration_dict_cross_entropy={\n",
    "        #         \"method\": \"assume_linear\",\n",
    "        #         \"n_integration_samples\": 3,\n",
    "        #     }\n",
    "        # )\n",
    "        'emc': ExpectedModelChangeMaximization(random_state=RANDOM_STATE, missing_label=MISSING_LABEL),\n",
    "  \n",
    "}\n",
    "\n",
    "test_acc_dict = {key: np.zeros(n_cycles+1) for key in qs_dict}\n",
    "train_acc_dict = {key: np.zeros(n_cycles+1) for key in qs_dict}\n",
    "\n",
    "# Perform active learning with each query strategy.\n",
    "for qs_name, qs in qs_dict.items():\n",
    "    torch.manual_seed(RANDOM_STATE)\n",
    "    torch.cuda.manual_seed(RANDOM_STATE)\n",
    "\n",
    "    print(f'Execute active learning using {qs_name}.')\n",
    "\n",
    "    # Copy initial ensemble model.\n",
    "    ensemble = deepcopy(ensemble_init)\n",
    "\n",
    "    y = np.full_like(y_train, fill_value=MISSING_LABEL, dtype=np.float32)\n",
    "    X = X_train\n",
    "    \n",
    "    X_selected = []\n",
    "    y_selected = []\n",
    "\n",
    "    # Execute active learning cycle.\n",
    "    for c in tqdm(range(n_cycles)):\n",
    "        # Fit and evaluate ensemble.\n",
    "        ensemble.fit(X, y) # base model\n",
    "        test_acc = mean_squared_error(y_test, ensemble.predict(X_test))\n",
    "        test_acc_dict[qs_name][c] = test_acc\n",
    "        train_acc = mean_squared_error(y_train, ensemble.predict(X_train))\n",
    "        train_acc_dict[qs_name][c] = train_acc\n",
    "\n",
    "        # Select and update training data.\n",
    "        query_idx = call_func(\n",
    "            qs.query,\n",
    "            X=X,\n",
    "            y=y,\n",
    "            reg=ensemble,\n",
    "            fit_reg=False,\n",
    "            ensemble=ensemble,\n",
    "            fit_ensemble=False,\n",
    "            batch_size=batch_size,\n",
    "        )\n",
    "        \n",
    "        query_idx = query_idx[0]\n",
    "        y[query_idx] = y_train[query_idx]\n",
    "        xs = X_train[query_idx]\n",
    "        X_selected.append(xs[0])\n",
    "        # print(X_selected)\n",
    "        y_selected.append(y_train[query_idx])\n",
    "\n",
    "    # Fit and evaluate ensemble.\n",
    "    ensemble.fit(X,y)\n",
    "    test_acc = mean_squared_error(y_test, ensemble.predict(X_test))\n",
    "    test_acc_dict[qs_name][c] = test_acc\n",
    "    train_acc = mean_squared_error(y_train, ensemble.predict(X_train))\n",
    "    train_acc_dict[qs_name][c] = train_acc\n",
    "    \n",
    "    # prediction\n",
    "    y_pred = ensemble.predict(X_all)\n",
    "        \n",
    "    # Plot the predictions\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    plt.plot(X_all[:,:-1].ravel(), y_all, 'k-', label='True y = x^2')\n",
    "    plt.scatter(X_selected, y_selected, color='blue', label=f'Queried Points ({qs_name})', s=50)\n",
    "    # plot test points\n",
    "    plt.scatter(X_test[:,:-1].ravel(), y_test, color='red', label='Test Data', alpha=0.5, marker='x')\n",
    "    plt.plot(X_all[:,:-1].ravel(), y_pred, label=f'Prediction ({qs_name})', linewidth=2)\n",
    "    #plt.fill_between(X_all[:,:-1].ravel(), y_pred - 1.96 * y_std, y_pred + 1.96 * y_std, color='lightblue', alpha=0.3, label='95% Confidence Interval')\n",
    "    plt.title(f'Active Learning ({qs_name})')\n",
    "    plt.xlabel('x')\n",
    "    plt.ylabel('y')\n",
    "    plt.legend()\n",
    "    plt.savefig(f'{qs_name}.pdf', bbox_inches='tight')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d6713f8-1402-4c3d-992a-fc9c75de22e3",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
