{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "demo_ConfidentSinkhornAllocation.ipynb",
      "provenance": [],
      "collapsed_sections": [],
      "toc_visible": true,
      "authorship_tag": "ABX9TyM1YDnCNhxzVnGQY13tScTc",
      "include_colab_link": true
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "view-in-github",
        "colab_type": "text"
      },
      "source": [
        "<a href=\"https://colab.research.google.com/github/ntienvu/confident_sinkhorn_allocation/blob/master/demo_ConfidentSinkhornAllocation.ipynb\" target=\"_parent\"><img src=\"https://colab.research.google.com/assets/colab-badge.svg\" alt=\"Open In Colab\"/></a>"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "!pip install git+https://ntienvu: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@github.com/ntienvu/confident_sinkhorn_allocation"
      ],
      "metadata": {
        "id": "53ok293zvVnp",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "ca2323dc-d19c-4b48-fe99-db7397e4845f"
      },
      "execution_count": 1,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
            "Collecting git+https://ntienvu:****@github.com/ntienvu/confident_sinkhorn_allocation\n",
            "  Cloning https://ntienvu:****@github.com/ntienvu/confident_sinkhorn_allocation to /tmp/pip-req-build-ukgdjklv\n",
            "  Running command git clone -q 'https://ntienvu:****@github.com/ntienvu/confident_sinkhorn_allocation' /tmp/pip-req-build-ukgdjklv\n",
            "Requirement already satisfied: colorama>=0.4.5 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (0.4.5)\n",
            "Requirement already satisfied: cycler>=0.11.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (0.11.0)\n",
            "Requirement already satisfied: fonttools>=4.33.3 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (4.33.3)\n",
            "Requirement already satisfied: joblib>=1.1.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.1.0)\n",
            "Requirement already satisfied: kiwisolver>=1.4.3 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.4.3)\n",
            "Requirement already satisfied: matplotlib>=3.1.2 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (3.1.3)\n",
            "Requirement already satisfied: numpy>=1.21.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.21.6)\n",
            "Requirement already satisfied: packaging>=21.3 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (21.3)\n",
            "Requirement already satisfied: pandas>=1.2.3 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.3.5)\n",
            "Requirement already satisfied: Pillow>=9.2.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (9.2.0)\n",
            "Requirement already satisfied: pyparsing>=3.0.9 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (3.0.9)\n",
            "Requirement already satisfied: python-dateutil>=2.8.2 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (2.8.2)\n",
            "Requirement already satisfied: pytz>=2022.1 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (2022.1)\n",
            "Requirement already satisfied: scikit-learn>=1.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.0.2)\n",
            "Requirement already satisfied: scipy>=1.7.1 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.7.3)\n",
            "Requirement already satisfied: six>=1.16.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.16.0)\n",
            "Requirement already satisfied: threadpoolctl>=3.1.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (3.1.0)\n",
            "Requirement already satisfied: tqdm>=4.64.0 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (4.64.0)\n",
            "Requirement already satisfied: xgboost>=1.6.1 in /usr/local/lib/python3.7/dist-packages (from csa==1.0) (1.6.1)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from kiwisolver>=1.4.3->csa==1.0) (4.1.1)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import sys\n",
        "sys.path.append('..')\n",
        "\n",
        "import numpy as np\n",
        "import os\n",
        "import argparse\n",
        "import logging\n",
        "import pickle\n",
        "from tqdm import tqdm\n",
        "from algorithm.pseudo_labeling import Pseudo_Labeling\n",
        "#from confident_sinkhorn_allocation.algorithm.flexmatch import FlexMatch\n",
        "#from confident_sinkhorn_allocation.algorithm.ups import UPS\n",
        "from algorithm.csa import CSA\n",
        "from xgboost import XGBClassifier\n",
        "from sklearn.metrics import accuracy_score\n",
        "\n",
        "from utilities.utils import get_train_test_unlabeled,append_acc_early_termination\n",
        "from utilities.utils import get_train_test_unlabeled_for_multilabel_classification\n",
        "\n",
        "import warnings\n",
        "warnings.filterwarnings('ignore')"
      ],
      "metadata": {
        "id": "Uy43buLIvVyv"
      },
      "execution_count": 2,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Get the data from the list of datasets:\n",
        "\n",
        "* segment_2310_20\n",
        "* wdbc_569_31\n",
        "* analcatdata_authorship\n",
        "* synthetic_control_6c\n",
        "* German-credit\n",
        "* madelon_no\n",
        "* dna_no\n",
        "* agaricus-lepiota\n",
        "* breast_cancer\n",
        "* digits"
      ],
      "metadata": {
        "id": "rqfm-kfmClJA"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# install Anaconda3\n",
        "# !wget -qO ac.sh https://repo.anaconda.com/archive/Anaconda3-2020.07-Linux-x86_64.sh \n",
        "# !bash ./ac.sh -b\n",
        "\n",
        "# # a fake google.colab library\n",
        "# !ln -s /usr/local/lib/python3.7/dist-packages/google \\\n",
        "#        /root/anaconda3/lib/python3.8/site-packages/google\n",
        "\n",
        "# # start jupyterlab, which now has Python3 = 3.8\n",
        "# !nohup /root/anaconda3/bin/jupyter-lab --ip=0.0.0.0&\n",
        "\n",
        "# # access through ngrok, click the link\n",
        "# !pip install pyngrok -q\n",
        "# from pyngrok import ngrok\n",
        "# print(ngrok.connect(8888))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "q3xhGHIKG7AC",
        "outputId": "b4b5dbec-94f5-45be-da59-802ba71a1511"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "ERROR: File or directory already exists: '/root/anaconda3'\n",
            "If you want to update an existing installation, use the -u option.\n",
            "ln: failed to create symbolic link '/root/anaconda3/lib/python3.8/site-packages/google/google': File exists\n",
            "nohup: appending output to 'nohup.out'\n",
            "NgrokTunnel: \"http://1c64-35-185-140-222.ngrok.io\" -> \"http://localhost:8888\"\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "dataset_name='digits'\n",
        "path_to_file='confident_sinkhorn_allocation/all_data.pickle'\n",
        "x_train,y_train, x_test, y_test, x_unlabeled=get_train_test_unlabeled(dataset_name,path_to_file,random_state=0)\n",
        "\n"
      ],
      "metadata": {
        "id": "-HOYZmqnClT4"
      },
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "print(x_train.shape)\n",
        "print(y_train.shape)\n",
        "\n",
        "print(\"number of training points = \",y_train.shape[0])\n",
        "\n",
        "print(\"number of test points = \",y_test.shape[0])\n",
        "\n",
        "print(\"number of unlabelled points = \",x_unlabeled.shape[0])\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "VJcf96UTT_1I",
        "outputId": "23e8f598-24ec-4106-8627-bb9e47a6efb8"
      },
      "execution_count": 5,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "(143, 64)\n",
            "(143, 1)\n",
            "number of training points =  143\n",
            "number of test points =  360\n",
            "number of unlabelled points =  1294\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Purely Supervised learning\n",
        "# Train an XGBoost model using on training data (labelled data)"
      ],
      "metadata": {
        "id": "8jHc6twUECW_"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# this is the XGBoost model for multi-class classification\n",
        "param = {}\n",
        "param['booster'] = 'gbtree'\n",
        "param['objective'] = 'binary:logistic'\n",
        "param['verbosity'] = 0\n",
        "param['silent'] = 1\n",
        "param['seed'] = 0\n",
        "\n",
        "# create XGBoost instance with default hyper-parameters\n",
        "xgb=XGBClassifier(**param,use_label_encoder=False)\n",
        "\n",
        "xgb.fit(x_train, y_train)\n",
        "\n",
        "# evaluate the performance on the test set\n",
        "y_test_pred = xgb.predict(x_test)      \n",
        "supervised_learning_accuracy= np.round( accuracy_score(y_test_pred, y_test)*100, 2)# round to 2 digits xx.yy %\n",
        "\n",
        "print('+++Test Acc: {:.2f}%'.format(supervised_learning_accuracy))\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "nQYIJtyAUjRc",
        "outputId": "6caade1f-df99-4497-f269-c54f4de4fb92"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 75.28%\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Perform Semi-supervised learning using Pseudo-labeling\n",
        "# Set a few hyperparameters for the model"
      ],
      "metadata": {
        "id": "sJus9ol7vV23"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "numTrials=1\n",
        "numIters=5\n",
        "upper_threshold=0.8\n",
        "dataset_name='digits'"
      ],
      "metadata": {
        "id": "egvG4QuLUVb1"
      },
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "pseudo_labeling_model = Pseudo_Labeling(x_unlabeled,x_test,y_test, \n",
        "                num_iters=numIters,\n",
        "                upper_threshold=upper_threshold,\n",
        "                verbose = True)\n",
        "\n",
        "pseudo_labeling_model.fit(x_train, y_train)\n",
        "        \n",
        "pseudo_labeling_accuracy=pseudo_labeling_model.test_acc"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Qlg10vE9VgMl",
        "outputId": "03891e6e-b7ae-4544-c221-4ac21214a1aa"
      },
      "execution_count": 8,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "no of unlabelled data: 1294 \t no of test data: 360\n",
            "===== Pseudo_Labeling\n",
            "==label_frequency without adjustment [22 20 16 13 18 11 17 12  6  8]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            " 20%|██        | 1/5 [00:00<00:03,  1.18it/s]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 75.28%\n",
            "MaxPseudoPoint [67, 61, 49, 40, 55, 34, 52, 37, 19, 25]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25])]  no training data  582\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 40%|████      | 2/5 [00:01<00:03,  1.02s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 76.11%\n",
            "MaxPseudoPoint [36, 32, 26, 21, 29, 18, 28, 20, 10, 13]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 24, 26, 21, 29, 18, 28, 20, 10, 13])]  no training data  807\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 60%|██████    | 3/5 [00:03<00:02,  1.28s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 76.67%\n",
            "MaxPseudoPoint [20, 18, 15, 12, 16, 10, 15, 11, 6, 8]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 24, 26, 21, 29, 18, 28, 20, 10, 13]), array([20, 12, 15, 12, 16, 10, 15, 11,  6,  8])]  no training data  932\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 80%|████████  | 4/5 [00:05<00:01,  1.41s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 76.11%\n",
            "MaxPseudoPoint [11, 10, 8, 7, 9, 6, 9, 6, 3, 4]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 24, 26, 21, 29, 18, 28, 20, 10, 13]), array([20, 12, 15, 12, 16, 10, 15, 11,  6,  8]), array([11,  5,  8,  7,  9,  6,  9,  6,  3,  4])]  no training data  1000\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 5/5 [00:06<00:00,  1.34s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 77.22%\n",
            "MaxPseudoPoint [5, 5, 4, 3, 4, 3, 4, 3, 2, 2]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 24, 26, 21, 29, 18, 28, 20, 10, 13]), array([20, 12, 15, 12, 16, 10, 15, 11,  6,  8]), array([11,  5,  8,  7,  9,  6,  9,  6,  3,  4]), array([5, 1, 4, 3, 4, 3, 4, 3, 2, 2])]  no training data  1031\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 78.89%\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        ""
      ],
      "metadata": {
        "id": "rovB8nYjVgVI"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Plot the comparison between Supervised Learning vs Pseudo-labeling"
      ],
      "metadata": {
        "id": "o_sBQhLiWEpv"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#!python -m pip uninstall matplotlib\n",
        "#!pip install matplotlib==3.1.3\n",
        "\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# plot in the same axis\n",
        "\n",
        "supervised_learning_result=[ supervised_learning_accuracy ]*len(pseudo_labeling_accuracy)\n",
        "\n",
        "plt.figure(figsize=(8,5))\n",
        "plt.plot(np.arange(len(pseudo_labeling_accuracy)),\\\n",
        "         supervised_learning_result,'m:',linewidth=4,label=\"Supervised Learning\") \n",
        "plt.plot(pseudo_labeling_accuracy,'k-.',linewidth=4,label='Pseudo-labeling')\n",
        "\n",
        "plt.xlabel(\"Pseudo-labeling Iteration\",fontsize=14)\n",
        "plt.ylabel(\"Test Accuracy\",fontsize=14)\n",
        "\n",
        "plt.legend(fontsize=14)\n",
        "\n",
        "plt.title(\"Dataset = \" + dataset_name,fontsize=14 )"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 372
        },
        "id": "d6vOdyqvWHWR",
        "outputId": "6d0bd722-851b-434c-cfc0-98f4f14461df"
      },
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0.5, 1.0, 'Dataset = digits')"
            ]
          },
          "metadata": {},
          "execution_count": 9
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 576x360 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Run the proposed Confident Sinkhorn Allocation (CSA)"
      ],
      "metadata": {
        "id": "hycXGI6cX7IB"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "num_XGB_models=10\n",
        "confidence_choice='ttest'\n",
        "\n",
        "csa_model = CSA(x_unlabeled,x_test,y_test, \n",
        "                num_iters=numIters,\n",
        "                confidence_choice=confidence_choice,\n",
        "                num_XGB_models=num_XGB_models,\n",
        "                verbose = True,\n",
        "            )\n",
        "csa_model.fit(x_train, y_train)\n",
        "\n",
        "csa_accuracy=csa_model.test_acc"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "U5J8NWFsX-mz",
        "outputId": "3603a72c-4ad6-4dcb-f447-e41afa81d71a"
      },
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "no of unlabelled data: 1294 \t no of test data: 360\n",
            "number of used XGB models  M= 10\n",
            "===== CSA_ttest\n",
            "==label_frequency without adjustment [22 20 16 13 18 11 17 12  6  8]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r  0%|          | 0/5 [00:00<?, ?it/s]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 75.28%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 20%|██        | 1/5 [00:57<03:48, 57.14s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=1294 #points/#classes=1073/10=107.30 reg=0.20\n",
            "MaxPseudoPoint [67, 61, 49, 40, 55, 34, 52, 37, 19, 25]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25])]  len of training data  582\n",
            "+++Test Acc: 78.89%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 40%|████      | 2/5 [02:00<03:02, 60.90s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=855 #points/#classes=680/10=68.00 reg=0.10\n",
            "MaxPseudoPoint [36, 32, 26, 21, 29, 18, 28, 20, 10, 13]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 32, 26, 21, 29, 18, 28, 20, 10, 13])]  len of training data  815\n",
            "+++Test Acc: 78.89%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 60%|██████    | 3/5 [03:15<02:14, 67.15s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=622 #points/#classes=456/10=45.60 reg=0.05\n",
            "MaxPseudoPoint [20, 18, 14, 12, 16, 10, 15, 11, 6, 7]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 32, 26, 21, 29, 18, 28, 20, 10, 13]), array([20, 18, 14, 12, 16, 10, 15, 11,  6,  7])]  len of training data  944\n",
            "+++Test Acc: 80.28%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 80%|████████  | 4/5 [04:42<01:15, 75.24s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=493 #points/#classes=340/10=34.00 reg=0.05\n",
            "MaxPseudoPoint [11, 10, 8, 6, 9, 6, 8, 6, 3, 4]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 32, 26, 21, 29, 18, 28, 20, 10, 13]), array([20, 18, 14, 12, 16, 10, 15, 11,  6,  7]), array([11, 10,  8,  6,  9,  6,  8,  6,  3,  4])]  len of training data  1015\n",
            "+++Test Acc: 79.17%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 5/5 [06:07<00:00, 73.41s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=422 #points/#classes=272/10=27.20 reg=0.05\n",
            "MaxPseudoPoint [5, 4, 4, 3, 4, 3, 4, 3, 2, 2]\n",
            "#augmented: [array([67, 61, 49, 40, 55, 34, 52, 37, 19, 25]), array([36, 32, 26, 21, 29, 18, 28, 20, 10, 13]), array([20, 18, 14, 12, 16, 10, 15, 11,  6,  7]), array([11, 10,  8,  6,  9,  6,  8,  6,  3,  4]), array([5, 4, 4, 3, 4, 3, 4, 3, 2, 2])]  len of training data  1049\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 79.17%\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Plot the comparison between Supervised, Pseudo-labeling and CSA"
      ],
      "metadata": {
        "id": "Dqxm85MYYMex"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# plot in the same axis\n",
        "\n",
        "supervised_learning_result=[ supervised_learning_accuracy ]*len(pseudo_labeling_accuracy)\n",
        "\n",
        "plt.figure(figsize=(8,5))\n",
        "\n",
        "# Supervised Learning\n",
        "plt.plot(np.arange(len(pseudo_labeling_accuracy)),\\\n",
        "         supervised_learning_result,'m:',linewidth=4,label=\"Supervised Learning\") \n",
        "\n",
        "# Pseudo Labeling\n",
        "plt.plot(pseudo_labeling_accuracy,'k-.',linewidth=4,label='Pseudo-labeling')\n",
        "\n",
        "# CSA\n",
        "plt.plot(csa_accuracy,'r-',linewidth=4,label='CSA')\n",
        "\n",
        "plt.xlabel(\"Pseudo-labeling Iteration\",fontsize=14)\n",
        "plt.ylabel(\"Test Accuracy\",fontsize=14)\n",
        "\n",
        "plt.legend(fontsize=12)\n",
        "\n",
        "plt.title(\"Dataset = \" + dataset_name,fontsize=14 )"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 372
        },
        "id": "35JXEyCHYMno",
        "outputId": "06cfb717-304d-4664-baba-972c7d9e9670"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0.5, 1.0, 'Dataset = digits')"
            ]
          },
          "metadata": {},
          "execution_count": 11
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 576x360 with 1 Axes>"
            ],
            "image/png": "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dTXAE+gBfAR8qrWuCFwFnndWTELcr6NHj1KjRg38/PyYOnUqq1atoqTts8vi3iQnwxtvpC23CtC3L/zwA/j7Z971Spc2hui//BIKFLDedv06PPcctG8PqZ4AESI7ctrQuiWR/wLUAK4Da4H/AkuAElrrRKVUPeBdrXXLjM6V04bWheuTv5t3ceuWkaztFdZ5/314802jJ51VTp82Ere9RXMKFYL//c+4xy7LJAuTZIuhda11ODAFOAtcAK4BB4EorfXtB3nPA6WcFZMQIhuIiIBGjdIm8Tx5jNnmY8dmfQItVw62bTMeRbMUD0px9Sr06gVBQfDPP1kbhxD3wZlD64WADkB5IADIDzh8U1EpNUgpdUApdSB1+VEhhAv77Tej3OrBg9btxYsbE96CgpwXi4cHvPyyUZu9fv2021evNu6dr1njvJiEcIAzJ7s1A05prS9rrROANUADwE8pdfv5p9JAuL2Dtdaztda1tda1i9pWahJCuJ7gYGMCm2251UceMcqtmlX29qGHYPduo4yr7SOFly9Dly5G+VfbyXhCmMSZifwsUFcplU8ZJbeeBv4AdgC3yy71A4KdGJMQwtnuVm51714oU8ac2G7z9IQxY4yFWR5/PO32pUuN3vmGDc6PTQgbzrxHvg9YBRwCjliuPRt4HXhFKXUCKALMTfckQgjXFh8PgwbdX7lVM1SpYpRynTQp7RKpFy4YXzwGDLD/PLoQTuLU58i11uO11g9rratprftqreO01n9rretorStqrYO01nHOjCknsF3fPKuO3blzJ6VLl76fENMcW7VqVat11YUbuHrVKLc6Z451u6cnfPGFY+VWzeDlBW+9Bfv3G7XZbc2fb/TOt2xxfmxCICVanaZcuXLkzZuXAgUKULx4cfr378/NmzfNDivbCgsLo3HjxmaHITLL8eNQt679cqubNsGQIebEdS9uL5U6blzaLxznz0PLljB0KMj/18LJJJE70bp167h58yaHDh3iwIEDTJo0yeyQhMh6u3YZSfzYMev2ChXg55+NKm6uIlcumDABfvnFGHa3NWuWMVlv1y7nxyZyLEnkJihVqhStW7cmNDSUBQsWUKFCBXx8fChfvjxLlixJ2W/evHlUrlyZQoUK0bJlS86cOQPYH+5u3LgxcyxDlklJSYwZMwZ/f38qVKjABpsJOREREbRv357ChQtTsWJF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D6fZFhgYyLx582jWrJkJkQlXo5Q6qLWubW+bDK2bwbYca5kyEBRkXjzCadq3b5/utox6ZNHR0axYsYLOnTtTrFgxnn32WTZs2CC1trOphIQEJk6cyOOPP243iQ8YMIAjR45IEheZQhK5s0VHSzlWN6W15ueff2bEiBH8/PPPdvdp27at1RB58eLFefnll9m7dy/Xrl3jt99+44033qB8+fLpXufGjRt8/fXXtGvXjhIlSvDCCy+wdetWEhMTM/0ziXsXFhZGvXr1eOedd9L8mZQsWZL169czd+5cChYsaFKEwu1orV3uVatWLe2yZs7U2rg7brwKFtT6+nWzoxIPaPny5bpMmTIaoxqiHjJkSLr7vvjii3rw4MF6+/btOjEx0e4+ycnJ+tdff9WvvPKKLl26dMp5M3oVLVpUDx06VP/6669Z9TFFBhITE/VHH32kc+XKZffPnrZ+owAAHpxJREFUp0+fPvrff/81O0zhooADOp2caHpSvp+XyybyxEStK1a0TuSvv252VCITrFu3zuofbX9/f52QkJAp505KStJ79+7VL7/8si5evPhdE/o777yTKdcVjjt69KiuV69eul+w1qxZY3aIwsVllMhlaN2ZgoMh9bOjUo7Vpfz5558cO3bM7rYWLVrg5+eX8v7KlSts3749U67r4eFBgwYNmDFjBuHh4Wzfvp3BgwdTpEgRu/t3797dbntCQkKax57Eg0lOTuazzz6jZs2adm+ndO3albCwMDp16mRCdCKnkETuTLYFYHr3hoAAc2IRDjl58iSTJ0+mRo0aVKlShcmTJ9vdL1euXHTu3Jm8efMSFBTE6tWradiwYabH4+npSZMmTZg1axYXLlzg+++/57nnnku531qtWjWqVKli99jZs2fz0EMP8dZbb3H48GFJ6png2WefZeTIkcTExFi1Fy5cmGXLlrFy5UqKFi1qUnQip5DHz5zlxx/hySet20JDoWpVc+IR6Tp79iwrV65kxYoV2P498/X15dKlS3Yf/7pw4QI+Pj6mPA8cFxfHli1bSE5OpkOHDnb3eeqpp9izZ0/K+5kzZzJ06FBnheiWNm/eTKtWrazannnmGWbPnk2JEiVMikq4o4weP5NE7iydOllXcmvdGjZuNC8eYeXChQt88803LF++PN0Z57etXbs23WSZXZ0/f57AwECrtpMnT1KhQgWTInIf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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Run ablation study of CSA without ttest, using all data points, like the SLA paper"
      ],
      "metadata": {
        "id": "-osJbfAAZPi9"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "confidence_choice=\"none\"\n",
        "\n",
        "# SLA model ~ CSA without ttest\n",
        "\n",
        "sla_model = CSA(x_unlabeled,x_test,y_test, \n",
        "                num_iters=numIters,\n",
        "                confidence_choice=confidence_choice,\n",
        "                num_XGB_models=num_XGB_models,\n",
        "                verbose = True,\n",
        "            )\n",
        "sla_model.fit(x_train, y_train)\n",
        "\n",
        "sla_accuracy=sla_model.test_acc"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "bduQKvMiZWBi",
        "outputId": "15596d05-1a49-40a5-da09-f735bf295bc9"
      },
      "execution_count": 12,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "no of unlabelled data: 1294 \t no of test data: 360\n",
            "number of used XGB models  M= 10\n",
            "===== CSA_none\n",
            "==label_frequency without adjustment [22 20 16 13 18 11 17 12  6  8]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r  0%|          | 0/5 [00:00<?, ?it/s]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 75.28%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 20%|██        | 1/5 [00:37<02:28, 37.17s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=1294 #points/#classes=1294/10=129.40 reg=0.20\n",
            "MaxPseudoPoint [67, 61, 49, 40, 55, 34, 52, 37, 19, 25]\n",
            "#augmented: [array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0])]  len of training data  144\n",
            "+++Test Acc: 75.56%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 40%|████      | 2/5 [01:17<01:56, 38.96s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=1293 #points/#classes=1293/10=129.30 reg=0.20\n",
            "MaxPseudoPoint [54, 49, 39, 32, 44, 27, 41, 29, 15, 20]\n",
            "#augmented: [array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0])]  len of training data  145\n",
            "+++Test Acc: 75.28%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 60%|██████    | 3/5 [01:55<01:16, 38.37s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=1292 #points/#classes=1292/10=129.20 reg=0.20\n",
            "MaxPseudoPoint [40, 37, 29, 24, 33, 20, 31, 22, 11, 15]\n",
            "#augmented: [array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0])]  len of training data  146\n",
            "+++Test Acc: 75.83%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\r 80%|████████  | 4/5 [02:32<00:38, 38.19s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=1291 #points/#classes=1291/10=129.10 reg=0.20\n",
            "MaxPseudoPoint [27, 25, 20, 16, 22, 14, 21, 15, 8, 10]\n",
            "#augmented: [array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0]), array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0])]  len of training data  147\n",
            "+++Test Acc: 77.22%\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 5/5 [03:13<00:00, 38.64s/it]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "#unlabel=1290 #points/#classes=1290/10=129.00 reg=0.20\n",
            "MaxPseudoPoint [14, 13, 10, 8, 11, 7, 11, 8, 4, 5]\n",
            "#augmented: [array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0]), array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0]), array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0]), array([1, 0, 0, 0, 0, 0, 0, 0, 0, 0])]  len of training data  148\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "+++Test Acc: 76.67%\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# plot in the same axis\n",
        "\n",
        "supervised_learning_result=[ supervised_learning_accuracy ]*len(pseudo_labeling_accuracy)\n",
        "\n",
        "plt.figure(figsize=(8,5))\n",
        "\n",
        "# Supervised Learning\n",
        "plt.plot(np.arange(len(pseudo_labeling_accuracy)),\\\n",
        "         supervised_learning_result,'m:',linewidth=4,label=\"Supervised Learning\") \n",
        "\n",
        "# Pseudo Labeling\n",
        "plt.plot(pseudo_labeling_accuracy,'k-.',linewidth=4,label='Pseudo-labeling')\n",
        "\n",
        "# SLA\n",
        "plt.plot(sla_accuracy,'b:',linewidth=4,label='SLA')\n",
        "\n",
        "# CSA\n",
        "plt.plot(csa_accuracy,'r-',linewidth=4,label='CSA')\n",
        "\n",
        "plt.xlabel(\"Pseudo-labeling Iteration\",fontsize=14)\n",
        "plt.ylabel(\"Test Accuracy\",fontsize=14)\n",
        "\n",
        "plt.legend(fontsize=12)\n",
        "\n",
        "plt.title(\"Dataset = \" + dataset_name,fontsize=14 )"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 372
        },
        "id": "j-JijnqQbdmC",
        "outputId": "71bf608f-a3d9-4af7-9574-dcd10073af56"
      },
      "execution_count": 13,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0.5, 1.0, 'Dataset = digits')"
            ]
          },
          "metadata": {},
          "execution_count": 13
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 576x360 with 1 Axes>"
            ],
            "image/png": "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FcWCBQuoW7cufn5+1KlTx2qO7Lx58wgMDKRcuXKEhIRw/PhxwH53d5s2bfj8888BY77t+PHjqVixInXr1mXNmjVW14+JiaF79+6UL1+e22+/PcclUG3Nnz+fwMBA/Pz8qFu3bsZSrJlNnTqVihUrUrt2bavPk5SUxPjx46lZsyZVqlRh1KhRJCQk2L1O7dq12bhxIwCTJk0iNDSURx55BD8/P4KCgsi8BsO+ffu4++678fPzo2/fvvTr149XX33V4c8kXMcbb7zB1KlTAfj222/p27dvxih14fgd+TXgaqbXFeAg0AZ4Og/X7Q+kr9AxFqNq3EngPeDlPJxPOMq2HGtQUJEsx6qUKtBXXpw8eZK1a9cSGBjI6NGjWbduHVevXmXnzp00btwYIGNFs5UrVxIbG0urVq0YMGCAQ+f/7LPPWL16Nb/++isREREsX77cqr1///7UqFGDmJgYli9fziuvvMIm2xXxslG5cmVWr17NlStXmD9/PuPGjWPfvn0Z7WfOnOH8+fNER0ezcOFCRo4cycGDBwF46aWX+Pvvv4mMjOTw4cNER0czefJkh677/fff079/fy5dukT37t15+mnjn6Pk5GR69erFsGHDuHDhAgMGDODbb7916JzCtVy5coXFixdbbdu6dStHj0rF8Axa61xfQCcgJNOrA9AYKObI8TbnKgacB6pY3s8C+lh+DgU2ZnPcSCACiKhZs6YWeXDhgta+vlobk8+M1/z5ZkdV4P78888s2zB6ggrs5ahatWppX19fXaZMGV2zZk39xBNP6GvXrukyZcro5cuX6/j4eKv9O3XqpD///POM96mpqdrHx0cfO3ZMHz16VAP6+vXrGe2tW7fWn332mdZa6wcffFB/8sknGW3r16/P2P/EiRPaw8NDX7lyJaP9pZde0kOHDrUbt71rZdajRw89c+ZMrbXW4eHh2tPTU1+7di2jvW/fvnry5Mk6LS1NlyxZUh8+fDijbefOnbp27doZx1avXt3q97VhwwattdYTJ07U7dq1y2jbv3+/LlGihNZa6y1btuhq1arptLS0jPb77rtPT5gwwW68ZrH3d1NkdfLkSf2f//xHA7p06dJ69+7dZofkdECEziavOjrY7Qet9fpMrw1a60itdV4eVHQG9mmtz1reDwVWWn7+BrA72E1rPUdrHay1Di6sK9gUuNmzrcuxVq0K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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    }
  ]
}