{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../')\n",
    "import seaborn as sns \n",
    "from multiprocessing import Process\n",
    "from omegaconf import OmegaConf\n",
    "from src.utils.run_lib import *\n",
    "import numpy as np \n",
    "from src.core.passive_learning import *\n",
    "from src.core.auto_labeling import *\n",
    "from src.datasets import dataset_factory \n",
    "from src.datasets.dataset_utils import * \n",
    "from src.utils.common_utils import * \n",
    "from src.utils.vis_utils import *\n",
    "from src.utils.run_lib import * \n",
    "import copy \n",
    "import random \n",
    "from src.datasets.numpy_dataset import * \n",
    "\n",
    "\n",
    "root_dir = '../'\n",
    "conf_dir = f'{root_dir}configs/calib-exp/'\n",
    "\n",
    "base_conf_file = '{}/mnist_lenet_base_conf.yaml'.format(conf_dir)\n",
    "conf           = OmegaConf.load(base_conf_file)\n",
    "\n",
    "training_conf  = OmegaConf.load('{}/training_confs/dropout_conf.yaml'.format(conf_dir))\n",
    "\n",
    "root_pfx       = 'mnist_lenet_calib-exp-runs'\n",
    "root_pfx       = f'{root_dir}/outputs/{root_pfx}/'\n",
    "\n",
    "\n",
    "conf['root_pfx']    = root_pfx\n",
    "\n",
    "conf.training_conf = training_conf\n",
    "\n",
    "\n",
    "logger   = get_logger('../temp/logs/act_lbl_test.log',stdout_redirect=True,level=logging.DEBUG)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[09/16/2023 11:25:36 AM : DEBUG : data_manag : ] : torch.Size([42000, 28, 28])\n",
      "[09/16/2023 11:25:36 AM : INFO  : data_manag : ] : Loaded dataset mnist\n",
      "[09/16/2023 11:25:36 AM : INFO  : data_manag : ] : Std train size: 42000 and Std. Val. Size:18000\n",
      "42000 18000\n",
      "[09/16/2023 11:25:36 AM : DEBUG : passive_le : ] : Querying 100 seed training points\n",
      "[09/16/2023 11:25:36 AM : DEBUG : passive_le : ] : Queried 100 seed points for training\n",
      "[09/16/2023 11:25:36 AM : DEBUG : passive_le : ] : Validation Data Size :5000\n",
      "[09/16/2023 11:25:36 AM : DEBUG : passive_le : ] : Querying rest of the training points 400 in single batch\n",
      "[09/16/2023 11:25:36 AM : INFO  : passive_le : ] : Labeled data size for training: 500\n",
      "[09/16/2023 11:25:36 AM : INFO  : pytorch_cl : ] : {'model_name': 'lenet', 'num_classes': 10, 'fit_intercept': True, 'lib': 'pytorch'}\n",
      "[09/16/2023 11:25:36 AM : INFO  : passive_le : ] : --------------- Begin Model Training ------------\n",
      "[09/16/2023 11:25:36 AM : INFO  : passive_le : ] : Training conf :{'loss_function': 'std_cross_entropy', 'dropout_prob': 0.2, 'optimizer': 'sgd', 'learning_rate': 0.1, 'loss_tolerance': 1e-06, 'max_epochs': 500, 'normalize_weights': False, 'batch_size': 32, 'ckpt_load_path': 'None', 'ckpt_save_path': 'None', 'train_from_scratch': True, 'train_from_ckpt': False, 'use_lr_schedule': True, 'shuffle': False, 'device': 'cuda:0', 'store_embedding': False, 'save_ckpt': False, 'num_trials': 1}\n",
      "[09/16/2023 11:25:36 AM : INFO  : passive_le : ] : Model conf : {'model_name': 'lenet', 'num_classes': 10, 'fit_intercept': True, 'lib': 'pytorch'}\n",
      "[09/16/2023 11:25:36 AM : INFO  : pytorch_cl : ] : {'model_name': 'lenet', 'num_classes': 10, 'fit_intercept': True, 'lib': 'pytorch'}\n",
      "[09/16/2023 11:25:36 AM : DEBUG : model_trai : ] : Training conf : {'loss_function': 'std_cross_entropy', 'dropout_prob': 0.2, 'optimizer': 'sgd', 'learning_rate': 0.1, 'loss_tolerance': 1e-06, 'max_epochs': 500, 'normalize_weights': False, 'batch_size': 32, 'ckpt_load_path': 'None', 'ckpt_save_path': 'None', 'train_from_scratch': True, 'train_from_ckpt': False, 'use_lr_schedule': True, 'shuffle': False, 'device': 'cuda:0', 'store_embedding': False, 'save_ckpt': False, 'num_trials': 1, 'weight_decay': 0.0001, 'momentum': 0.9, 'loss_tol': 1e-06, 'max_max_epochs': 10000, 'stopping_criterion': 'max_epochs', 'log_val_err': False, 'log_val_ece': False, 'log_train_ece': False, 'train_err_tol': 0.001, 'log_batch_loss_freq': 20, 'log_val_err_freq': 5, 'log_val_ece_freq': 5, 'verbose_logging': False, 'log_train_ece_freq': 5, 'nesterov': False, 'mixup_alpha': 0, 'num_train_pts': 500}\n",
      "[09/16/2023 11:25:36 AM : DEBUG : model_trai : ] : Using loss function : <class 'models.torch.losses.common_losses.StdCrossEntropyLoss'>\n",
      "[09/16/2023 11:25:36 AM : DEBUG : model_trai : ] : Using stopping criterion max_epochs\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Train Epoch: 0 [0/500 (0%)]\tLoss: 2.307016 \t result: {'loss': 2.3155202865600586}\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Epoch: 0 Training Error : 0.6260 , Training Loss : 0.0596\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Train Epoch: 1 [0/500 (0%)]\tLoss: 1.158161 \t result: {'loss': 3.4039218425750732}\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Epoch: 1 Training Error : 0.2780 , Training Loss : 0.0254\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Train Epoch: 2 [0/500 (0%)]\tLoss: 0.558032 \t result: {'loss': 4.9499359130859375}\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Epoch: 2 Training Error : 0.1840 , Training Loss : 0.0167\n",
      "[09/16/2023 11:25:37 AM : DEBUG : model_trai : ] : Train Epoch: 3 [0/500 (0%)]\tLoss: 0.395793 \t result: {'loss': 5.591113090515137}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 3 Training Error : 0.1080 , Training Loss : 0.0102\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 4 [0/500 (0%)]\tLoss: 0.272807 \t result: {'loss': 8.087785720825195}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 4 Training Error : 0.0680 , Training Loss : 0.0068\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 5 [0/500 (0%)]\tLoss: 0.144348 \t result: {'loss': 7.618263244628906}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 5 Training Error : 0.0440 , Training Loss : 0.0053\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 6 [0/500 (0%)]\tLoss: 0.138013 \t result: {'loss': 7.26992654800415}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 6 Training Error : 0.0440 , Training Loss : 0.0051\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 7 [0/500 (0%)]\tLoss: 0.141034 \t result: {'loss': 7.220210075378418}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 7 Training Error : 0.0360 , Training Loss : 0.0049\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 8 [0/500 (0%)]\tLoss: 0.138871 \t result: {'loss': 8.233396530151367}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 8 Training Error : 0.0320 , Training Loss : 0.0045\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 9 [0/500 (0%)]\tLoss: 0.128119 \t result: {'loss': 7.078312873840332}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 9 Training Error : 0.0620 , Training Loss : 0.0054\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 10 [0/500 (0%)]\tLoss: 0.201880 \t result: {'loss': 8.496857643127441}\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Epoch: 10 Training Error : 0.0660 , Training Loss : 0.0060\n",
      "[09/16/2023 11:25:38 AM : DEBUG : model_trai : ] : Train Epoch: 11 [0/500 (0%)]\tLoss: 0.355677 \t result: {'loss': 8.69735336303711}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 11 Training Error : 0.1020 , Training Loss : 0.0112\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 12 [0/500 (0%)]\tLoss: 0.567052 \t result: {'loss': 8.220572471618652}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 12 Training Error : 0.0940 , Training Loss : 0.0080\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 13 [0/500 (0%)]\tLoss: 0.330314 \t result: {'loss': 7.429996967315674}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 13 Training Error : 0.0580 , Training Loss : 0.0045\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 14 [0/500 (0%)]\tLoss: 0.555579 \t result: {'loss': 9.903791427612305}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 14 Training Error : 0.0500 , Training Loss : 0.0055\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 15 [0/500 (0%)]\tLoss: 0.043290 \t result: {'loss': 9.62639045715332}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 15 Training Error : 0.0180 , Training Loss : 0.0021\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 16 [0/500 (0%)]\tLoss: 0.041993 \t result: {'loss': 9.675753593444824}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 16 Training Error : 0.0140 , Training Loss : 0.0013\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 17 [0/500 (0%)]\tLoss: 0.030111 \t result: {'loss': 10.365139961242676}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 17 Training Error : 0.0040 , Training Loss : 0.0009\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 18 [0/500 (0%)]\tLoss: 0.029220 \t result: {'loss': 9.894991874694824}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 18 Training Error : 0.0020 , Training Loss : 0.0008\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Train Epoch: 19 [0/500 (0%)]\tLoss: 0.025043 \t result: {'loss': 9.338690757751465}\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Epoch: 19 Training Error : 0.0000 , Training Loss : 0.0006\n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Training Stopping criterion met. \n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : \n",
      "[09/16/2023 11:25:39 AM : DEBUG : model_trai : ] : Average training loss : 0.009217582180630414\n",
      "[09/16/2023 11:25:39 AM : INFO  : passive_le : ] : --------------- End Model Training ------------\n",
      "tensor(18.0130)\n",
      "0.10129999999999995\n"
     ]
    }
   ],
   "source": [
    "conf['train_pts_query_conf']['seed_train_size']= 10\n",
    "conf['train_pts_query_conf']['max_num_train_pts']= 50\n",
    "\n",
    "set_seed(conf['random_seed'])\n",
    "\n",
    "dm = DataManager(conf,logger,lib=conf['model_conf']['lib'])\n",
    "\n",
    "print(len(dm.ds_std_train), len(dm.ds_std_val))\n",
    "\n",
    "pl = PassiveLearning(conf,dm,logger)\n",
    "\n",
    "out = pl.run()\n",
    "\n",
    "w = pl.cur_clf.get_weights()\n",
    "print(torch.norm(w))\n",
    "test_err = get_test_error(pl.cur_clf,dm.ds_std_test,conf['inference_conf'])\n",
    "print(test_err)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAcMAAAHHCAYAAADDFzPIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/OQEPoAAAACXBIWXMAAA9hAAAPYQGoP6dpAABfFUlEQVR4nO3deVwU9f8H8NewsMsiN4KCoah4JqZBmvdF4dfyqrwVtOyytCTLLM0uRc3IStMyBM1b0zI1TUnLzDRRUlPxQMVMFBF2uXYX2Pn9QeyP5ZBd2INdXs/HYx8Pd3Z25r0j7IvPzOczH0EURRFERET1mIO1CyAiIrI2hiEREdV7DEMiIqr3GIZERFTvMQyJiKjeYxgSEVG9xzAkIqJ6j2FIRET1HsOQiIjqPYYh1TsHDx6EIAg4ePCgbtnEiRMRFBRUo+0JgoCXX3652vUSEhIgCAKuXr2qW9a3b1/07dtX9/zq1asQBAEJCQk1qsXcBEHAu+++a+0yiEyOYUh1WmmAlD4cHR3RpEkTTJw4ETdu3LB2eRaxe/duswRQUFCQ7rg6ODjA09MTISEheO6553D06FGT74+oLnO0dgFEhnj//ffRvHlzqFQq/PHHH0hISMBvv/2GM2fOwNnZudbbX7lyJbRarQkqrdqECRMwevRoyGSyKtdp1qwZCgoK4OTkpFu2e/duLFu2zCyB2KlTJ7z22msAgJycHJw7dw5btmzBypUrMX36dMTGxuqtX1BQAEdHfm2Q/eFPNdmE//3vfwgLCwMATJ48GQ0bNsTChQuxY8cOjBw5stbbLxs+5iKRSCCRSO65jiAIJgl3QzVp0gTjx4/XW7Zw4UKMHTsWn3zyCVq1aoUXX3xR95olaysliiJUKhXkcrnF9031B0+Tkk3q1asXAODy5ct6y8+fP4+nnnoK3t7ecHZ2RlhYGHbs2FHt9iq7Zrh48WJ0794dPj4+kMvlCA0NxdatW6vcxrp169CmTRs4OzsjNDQUv/76q97rlV0zLK/8NcOJEydi2bJlAKB3ulgURQQFBWHo0KEVtqFSqeDh4YHnn3++2s9dGblcjm+++Qbe3t6YN28eyk5sU/6a4bVr1zBlyhS0adMGcrkcPj4+GDFiRKWf8dSpU+jTpw/kcjnuu+8+fPjhh4iPj69wTIKCgvD4449j7969CAsLg1wux5dffgkAiI+PR//+/eHn5weZTIb27dtj+fLlFfZVuo2DBw/qthESEqK7Trxt2zaEhITo/q9OnjxZo2NF9oMtQ7JJpV+eXl5eumV///03evTogSZNmuDNN99EgwYNsHnzZgwbNgzffvsthg8fbtQ+Pv30UwwZMgTjxo2DRqPBxo0bMWLECOzcuROPPfaY3rq//PILNm3ahGnTpkEmk+GLL77AwIEDcezYMXTo0KHGn/P555/Hv//+i3379uGbb77RLRcEAePHj8eiRYtw9+5deHt761774YcfoFQqK7T4jOHq6orhw4cjLi4OZ8+exf3331/pen/++Sd+//13jB49Gvfddx+uXr2K5cuXo2/fvjh79ixcXFwAADdu3EC/fv0gCAJmzZqFBg0a4Ouvv67ylHFKSgrGjBmD559/Hs8++yzatGkDAFi+fDnuv/9+DBkyBI6Ojvjhhx8wZcoUaLVavPTSS3rbuHTpEsaOHYvnn38e48ePx+LFizF48GCsWLECb731FqZMmQIAiImJwciRI5GSkgIHB7YP6i2RqA6Lj48XAYj79+8XMzIyxOvXr4tbt24VfX19RZlMJl6/fl237oABA8SQkBBRpVLplmm1WrF79+5iq1atdMsOHDggAhAPHDigWxYVFSU2a9ZMb9/5+fl6zzUajdihQwexf//+essBiADE48eP65Zdu3ZNdHZ2FocPH17hs1y5ckW3rE+fPmKfPn10z69cuSICEOPj43XLXnrpJbGyX9WUlBQRgLh8+XK95UOGDBGDgoJErVZb4T1lNWvWTHzssceqfP2TTz4RAYjff/+93medO3eu7nn5YySKonjkyBERgLhmzRrdsqlTp4qCIIgnT57ULcvMzBS9vb0rHJNmzZqJAMQ9e/ZU2HZl+4uIiBBbtGhR4bMBEH///Xfdsr1794oARLlcLl67dk23/Msvv6zw80D1D/8MIpsQHh4OX19fBAYG4qmnnkKDBg2wY8cO3HfffQCAu3fv4ueff8bIkSORk5ODO3fu4M6dO8jMzERERAQuXrxodO/TsteosrKyoFAo0KtXL5w4caLCut26dUNoaKjuedOmTTF06FDs3bsXxcXFNfzU99a6dWt07doV69at0y27e/cufvzxR4wbNw6CINRq+66urgBKOtZUpewxKiwsRGZmJoKDg+Hp6al3nPbs2YNu3bqhU6dOumXe3t4YN25cpdtt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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cur_val_ds,cur_val_idcs    = dm.get_current_validation_data()\n",
    "\n",
    "val_inf_out = pl.cur_clf.predict(cur_val_ds,conf['inference_conf'])\n",
    "bin_data = compute_calibration(cur_val_ds.Y, val_inf_out['labels'], val_inf_out['confidence'], num_bins=15)\n",
    "ax = plt.subplot()\n",
    "reliability_diagram_subplot(ax, bin_data, draw_ece=True, draw_bin_importance=False, title=\"Reliability Diagram\", \n",
    "                             xlabel=\"Confidence\", ylabel=\"Expected Accuracy\",disable_labels=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: ylabel='Density'>"
      ]
     },
     "execution_count": 4,
     "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": [
    "from utils.counting_utils import * \n",
    "\n",
    "out = get_scores_numbers(val_inf_out, cur_val_ds.Y,10)\n",
    "\n",
    "sns.kdeplot(out['correct_scores'])\n",
    "sns.kdeplot(out['incorrect_scores'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[09/16/2023 11:25:40 AM : INFO  : auto_label : ] : ========================= Begin Auto-Labeling selective ==========================\n",
      "[09/16/2023 11:25:40 AM : DEBUG : auto_label : ] : Auto Labeling Conf : {'method_name': 'selective', 'score_type': 'confidence', 'class_wise': 'independent', 'auto_label_err_threshold': 0.05, 'C_1': 0, 'ucb': 'sigma', 'fast': True}\n",
      "[09/16/2023 11:25:40 AM : INFO  : auto_label : ] : Number of unlabeled points : 41500\n",
      "[09/16/2023 11:25:40 AM : INFO  : auto_label : ] : Using number of validation points : 5000\n",
      "[09/16/2023 11:25:40 AM : INFO  : auto_label : ] : Using Auto-Labeling Error Threshold = 0.05\n",
      "[09/16/2023 11:25:40 AM : DEBUG : auto_label : ] : Expected Calibration Error on Validation set : 0.045231591004133244\n",
      "[09/16/2023 11:25:40 AM : INFO  : auto_label : ] : Determining Thresholds : Class Wise : independent\n",
      "[09/16/2023 11:25:40 AM : DEBUG : threshold_ : ] : C_1 = 0 UCB = sigma\n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.8730894923210144 for class 0   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.8258206248283386 for class 1   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.71026211977005 for class 2   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.940819501876831 for class 3   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.9564809799194336 for class 4   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.5980187058448792 for class 5   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.5939328074455261 for class 6   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.7685075402259827 for class 7   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.9323535561561584 for class 8   \n",
      "[09/16/2023 11:25:41 AM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.8348082304000854 for class 9   \n",
      "[09/16/2023 11:25:41 AM : INFO  : auto_label : ] : auto-labeling thresholds from val set: [0.8730895, 0.8258206, 0.7102621, 0.9408195, 0.956481, 0.5980187, 0.5939328, 0.76850754, 0.93235356, 0.83480823]\n",
      "[09/16/2023 11:25:43 AM : INFO  : auto_label : ] : Num auto labeled points : 36058 \n",
      "[09/16/2023 11:25:43 AM : INFO  : auto_label : ] : Num validation pts to remove : 4350\n",
      "[09/16/2023 11:25:43 AM : INFO  : auto_label : ] : ============================== Done Auto-Labeling ==============================\n",
      "{'auto_labeled_acc': 0.945310333351822, 'coverage_1': 0.8585238095238096, 'coverage_2': 0}\n"
     ]
    }
   ],
   "source": [
    "dm.unmark_auto_labeled()\n",
    "\n",
    "auto_labeler = AutoLabeling(conf,dm,pl.cur_clf,logger)\n",
    "out = auto_labeler.run()\n",
    "out = dm.get_auto_labeling_counts()\n",
    "print(out)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ml-kernel-tbal",
   "language": "python",
   "name": "ml-kernel-tbal"
  },
  "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.10.10"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
