{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "import sys\n",
    "from multiprocessing import Process\n",
    "from os.path import join\n",
    "\n",
    "sys.path.append('../')\n",
    "sys.path.append('../../')\n",
    "\n",
    "from omegaconf import OmegaConf\n",
    "from src.utils.run_lib import *\n",
    "from src.utils.conf_utils import * \n",
    "\n",
    "calib_val_frac = 0.5\n",
    "\n",
    "root_dir = '../../'\n",
    "conf_dir = f'{root_dir}configs/calib-exp/'\n",
    "\n",
    "method = 'passive_learning'\n",
    "\n",
    "model_ds_key = 'cifar10_med_net'\n",
    "\n",
    "root_pfx = f'test_runs/{model_ds_key}_calib/'\n",
    "\n",
    "base_conf                = OmegaConf.load(f'{conf_dir}/{model_ds_key}_base_conf.yaml')\n",
    "base_conf['output_root'] = join(root_dir, 'outputs', root_pfx)\n",
    "\n",
    "base_conf['eval'] = 'full'\n",
    "base_conf['root_pfx'] = root_pfx\n",
    "base_conf['calib_conf'] = None \n",
    "\n",
    "\n",
    "run_train_time = True   \n",
    "run_post_hoc   = False \n",
    "\n",
    "all_outs = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_conf['method'] = method #'passive_learning' # single round\n",
    "#base_conf['method'] = 'active_labeling'  # multi round\n",
    "base_conf['training_conf']['weight_decay'] = 0.001\n",
    "base_conf['training_conf']['learning_rate'] = 0.001\n",
    "base_conf['training_conf']['max_epochs'] = 50\n",
    "base_conf['training_conf']['batch_size'] = 32\n",
    "\n",
    "base_conf['val_pts_query_conf']['max_num_val_pts'] = 1000\n",
    "\n",
    "base_conf['train_pts_query_conf']['max_num_train_pts'] = 4000\n",
    "\n",
    "base_conf['train_pts_query_conf']['seed_train_size'] = 4000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def safe_to_numpy(x):\n",
    "    if(torch.is_tensor(x)):\n",
    "        return x.numpy()\n",
    "    else:\n",
    "        return x "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def augment_conf(conf):\n",
    "    calib_conf = conf['calib_conf']\n",
    "    if(calib_conf!=None):\n",
    "        conf['run_dir']        = join(conf['output_root'], calib_conf['name'])\n",
    "    else:\n",
    "        conf['run_dir']        = join(conf['output_root'], \"None\")\n",
    "    \n",
    "    \n",
    "    if(calib_conf and (calib_conf['type']=='post_hoc')):\n",
    "        ckpt_file_name = get_model_ckpt_file_name(conf)\n",
    "\n",
    "        conf.training_conf['save_ckpt'] = True \n",
    "        conf.training_conf['train_from_scratch'] = False  \n",
    "        conf.training_conf['ckpt_save_path'] = join(root_dir, 'ckpt', ckpt_file_name)\n",
    "        conf.training_conf['ckpt_load_path'] = join(root_dir, 'ckpt', ckpt_file_name)\n",
    "\n",
    "    if( calib_conf and  (calib_conf['type']=='train_time')):\n",
    "        for k in  calib_conf.training_conf.keys():\n",
    "            conf.training_conf[k] = calib_conf.training_conf[k]\n",
    "\n",
    "        ckpt_file_name = get_model_ckpt_file_name(conf)\n",
    "\n",
    "        conf.training_conf['ckpt_save_path'] = f'{root_dir}/ckpt/{ckpt_file_name}'\n",
    "\n",
    "    conf['log_file_path']  = join(conf['run_dir'], conf['method'] + '.log')\n",
    "    conf['out_file_path']  = join(conf['run_dir'], conf['method'] + '.pkl')\n",
    "    conf['conf_file_path'] = join(conf['run_dir'], conf['method'] + '.yaml')\n",
    "\n",
    "    return conf \n",
    "\n",
    "conf = base_conf\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_conf_2(conf,pas_learn):\n",
    "\n",
    "    overwrite = True \n",
    "\n",
    "    if('calib_conf' in conf and conf['calib_conf'] not in [None, \"None\"]):\n",
    "        conf['calib_conf']['device'] = conf['device']\n",
    "\n",
    "    if(not overwrite):\n",
    "        if(os.path.exists(conf['out_file_path'])):\n",
    "            print(f\"path exists {conf['out_file_path']}\")\n",
    "    try:\n",
    "        os.makedirs(conf['run_dir'])\n",
    "    except OSError:\n",
    "        pass\n",
    "\n",
    "    ckpt_save_path = conf.training_conf['ckpt_save_path'] \n",
    "\n",
    "    if(ckpt_save_path) :\n",
    "        #check if ckpt_save_path directories exist, if not create.\n",
    "        ckpt_dir_path  = os.path.sep.join( ckpt_save_path.split(os.path.sep)[:-1])\n",
    "\n",
    "        try:\n",
    "            os.makedirs(ckpt_dir_path)\n",
    "        except OSError:\n",
    "            pass\n",
    "\n",
    "    set_defaults(conf)\n",
    "\n",
    "    conf['inference_conf']['device'] = conf['device']\n",
    "\n",
    "    if('conf_file_path' in conf):\n",
    "        with open(conf['conf_file_path'],'w') as f:\n",
    "                OmegaConf.save(config=conf, f=f)\n",
    "\n",
    "    logger = get_logger(conf['log_file_path'],stdout_redirect=True,level=logging.DEBUG)\n",
    "    \n",
    "    set_seed(conf['random_seed'])\n",
    "    # get data\n",
    "    dm = DataManager(conf,logger, lib=conf['model_conf']['lib'])\n",
    "\n",
    "    logger.info('Loaded dataset {}'.format(conf['data_conf']['name']))\n",
    "    logger.info(f' std_train_size : {len(dm.ds_std_train)} and  std_val_size: {len(dm.ds_std_val)}')\n",
    "    \n",
    "    if(not pas_learn):\n",
    "        pas_learn = PassiveLearning(conf,dm,logger)\n",
    "\n",
    "        out = pas_learn.run()\n",
    "\n",
    "    auto_lbl_conf = conf['auto_lbl_conf']\n",
    "\n",
    "    auto_lbl_conf['method_name']= 'selective' \n",
    "\n",
    "    #<<<<<<<<<<<<<<<<<<<<<<<<< BEGIN CALIBRATION BLOCK <<<<<<<<<<<<<<<<<<<<<<<<<\n",
    "    cur_calibrator = None \n",
    "    if( conf['calib_conf'] and conf['calib_conf']['type']=='post_hoc'):\n",
    "        calib_conf    = conf['calib_conf'] \n",
    "        logger.info('========================= Training Post-hoc Calibrator   =========================')\n",
    "        \n",
    "        logger.info(f\"Calib Conf : {conf['calib_conf']}\")\n",
    "\n",
    "        cur_calibrator  = get_calibrator(pas_learn.cur_clf,calib_conf,logger)\n",
    "\n",
    "        # randomly split the current available validation points into two parts.\n",
    "        # one part will be used for training the calibrator and other part for finding \n",
    "        # the auto-labeling thresholds.\n",
    "        dm.select_calib_val_points(calib_frac=calib_conf['calib_val_frac'])\n",
    "        \n",
    "        cur_val_ds_c , cur_val_idcs_c    = dm.get_cur_calib_val_ds()\n",
    "        print(len(cur_val_ds_c), len(cur_val_idcs_c))\n",
    "        cur_val_ds_nc , cur_val_idcs_nc    = dm.get_cur_non_calib_val_ds()\n",
    "\n",
    "        #print(np.histogram(cur_val_ds_c.Y.numpy()))\n",
    "\n",
    "        values, counts = np.unique(cur_val_ds_c.Y.numpy(), return_counts=True)\n",
    "        print(values)\n",
    "        print(counts)\n",
    "\n",
    "        logger.info(f\"Number of validation points for training calibrator : {len(cur_val_idcs_c)}\")\n",
    "        cur_calibrator.fit(cur_val_ds_c,ds_val_nc=cur_val_ds_nc)\n",
    "    else:\n",
    "        logger.info('=========================    No Post-hoc Calibration     =========================')\n",
    "        cur_calibrator = None \n",
    "\n",
    "    #>>>>>>>>>>>>>>>>>>>>>>>>>>> END CALIBRATION BLOCK  >>>>>>>>>>>>>>>>>>>>>>>>>>>\n",
    "\n",
    "    auto_labeler = AutoLabeling(conf,dm,pas_learn.cur_clf,logger,cur_calibrator)\n",
    "    out = auto_labeler.run()\n",
    "    counts_sel = dm.get_auto_labeling_counts()\n",
    "\n",
    "\n",
    "    logger.info(f\" Selective Auto-labeling counts: {counts_sel}\")\n",
    "\n",
    "    counts_sel['avg_ece_on_val'] =  out['ECE_on_val'] if 'ECE_on_val' in out else None\n",
    "    counts_sel['avg_ece_no_calib_on_val'] = out['ECE_on_val_no_calib'] if 'ECE_on_val_no_calib' in out else None\n",
    "    \n",
    "    dm.unmark_auto_labeled()\n",
    "\n",
    "    return pas_learn,cur_calibrator, dm, counts_sel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "50000\n",
      "50000\n",
      "[01/22/2024 06:29:01 PM : DEBUG : data_manag : ] : torch.Size([40000, 3, 32, 32])\n",
      "50000\n",
      "50000\n",
      "[01/22/2024 06:29:01 PM : INFO  : data_manag : ] : Loaded dataset cifar10\n",
      "[01/22/2024 06:29:01 PM : INFO  : data_manag : ] : Std train size: 40000 and Std. Val. Size:8000\n",
      "[01/22/2024 06:29:01 PM : INFO  : 996596987 : ] : Loaded dataset cifar10\n",
      "[01/22/2024 06:29:01 PM : INFO  : 996596987 : ] :  std_train_size : 40000 and  std_val_size: 8000\n",
      "[01/22/2024 06:29:01 PM : DEBUG : passive_le : ] : Querying 4000 seed training points\n",
      "[01/22/2024 06:29:01 PM : DEBUG : passive_le : ] : Queried 4000 seed points for training\n",
      "[01/22/2024 06:29:01 PM : DEBUG : passive_le : ] : Validation Data Size :1000\n",
      "[01/22/2024 06:29:01 PM : DEBUG : passive_le : ] : Querying rest of the training points 0 in single batch\n",
      "[01/22/2024 06:29:01 PM : INFO  : passive_le : ] : Labeled data size for training: 4000\n",
      "[01/22/2024 06:29:01 PM : INFO  : passive_le : ] : Labeled data size for validation: 1000\n",
      "[01/22/2024 06:29:01 PM : INFO  : passive_le : ] : Loading model from path: ../../ckpt/cifar_med_net_cifar10__Nt_4000__loss_function_std_cross_entropy__optimizer_sgd__learning_rate_0.001__batch_size_32__momentum_0.9__weight_decay_0.001__max_epochs_50.ckpt\n",
      "[01/22/2024 06:29:02 PM : INFO  : model_fact : ] : {'name': 'cifar_med_net', 'num_classes': 10, 'lib': 'pytorch'}\n",
      "[01/22/2024 06:29:04 PM : INFO  : passive_le : ] : Test error of the model : 46.88\n",
      "[01/22/2024 06:29:04 PM : INFO  : 996596987 : ] : ========================= Training Post-hoc Calibrator   =========================\n",
      "[01/22/2024 06:29:04 PM : INFO  : 996596987 : ] : Calib Conf : {'name': 'auto_label_opt_v0', 'device': 'cuda:0', 'calib_val_frac': 0.5, 'type': 'post_hoc', 'l1': 1.0, 'l2': 5.0, 'l3': 0.0, 'regularize': False, 'class_wise': 'independent', 'features_key': 'concat', 'alpha_1': 0.01, 'training_conf_g': {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 100, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}, 'training_conf_t': {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 200, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}, 'auto_lbl_conf': {'method_name': 'selective', 'score_type': 'confidence', 'class_wise': 'independent', 'auto_label_err_threshold': 0.05, 'C_1': 0.25, 'ucb': 'sigma'}, 'l4': 0.0, 'num_classes': 10, 'model_conf': {'input_dimension': -1, 'output_dimension': -1, 'layers': [{'type': 'linear', 'dim_factor': 2}, {'type': 'activation', 'act_fun': 'tanh'}], 'num_classes': 10}}\n",
      "[01/22/2024 06:29:04 PM : INFO  : calibrator : ] : Creating instance of calibrator : auto_label_opt_v0\n",
      "[01/22/2024 06:29:04 PM : INFO  : calibrator : ] : using auto-label-opt-v0 to learn g\n",
      "[01/22/2024 06:29:04 PM : INFO  : data_manag : ] : Selecting 0.5 fraction of calibration val points out of total :1000\n",
      "[01/22/2024 06:29:04 PM : INFO  : data_manag : ] :  Cur calib ds size : 500\n",
      "500 500\n",
      "[0 1 2 3 4 5 6 7 8 9]\n",
      "[54 46 53 55 49 45 43 50 56 49]\n",
      "[01/22/2024 06:29:04 PM : INFO  : 996596987 : ] : Number of validation points for training calibrator : 500\n",
      "{'name': 'auto_label_opt_v0', 'device': 'cuda:0', 'calib_val_frac': 0.5, 'type': 'post_hoc', 'l1': 1.0, 'l2': 5.0, 'l3': 0.0, 'regularize': False, 'class_wise': 'independent', 'features_key': 'concat', 'alpha_1': 0.01, 'training_conf_g': {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 100, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}, 'training_conf_t': {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 200, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}, 'auto_lbl_conf': {'method_name': 'selective', 'score_type': 'confidence', 'class_wise': 'independent', 'auto_label_err_threshold': 0.05, 'C_1': 0.25, 'ucb': 'sigma'}, 'l4': 0.0, 'num_classes': 10, 'model_conf': {'input_dimension': -1, 'output_dimension': -1, 'layers': [{'type': 'linear', 'dim_factor': 2}, {'type': 'activation', 'act_fun': 'tanh'}], 'num_classes': 10}}\n",
      "[01/22/2024 06:29:04 PM : INFO  : auto_label : ] : {'name': 'auto_label_opt_v0', 'device': 'cuda:0', 'calib_val_frac': 0.5, 'type': 'post_hoc', 'l1': 1.0, 'l2': 5.0, 'l3': 0.0, 'regularize': False, 'class_wise': 'independent', 'features_key': 'concat', 'alpha_1': 0.01, 'training_conf_g': {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 100, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}, 'training_conf_t': {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 200, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}, 'auto_lbl_conf': {'method_name': 'selective', 'score_type': 'confidence', 'class_wise': 'independent', 'auto_label_err_threshold': 0.05, 'C_1': 0.25, 'ucb': 'sigma'}, 'l4': 0.0, 'num_classes': 10, 'model_conf': {'input_dimension': -1, 'output_dimension': -1, 'layers': [{'type': 'linear', 'dim_factor': 2}, {'type': 'activation', 'act_fun': 'tanh'}], 'num_classes': 10}}\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Features Shape : torch.Size([500, 522])\n",
      "[01/22/2024 06:29:04 PM : INFO  : auto_label : ] : Using auto-labeling model : ClasswiseAutoLabelingModel(\n",
      "  (g_model): DynamicMLP(\n",
      "    (net): Sequential(\n",
      "      (0): Linear(in_features=522, out_features=1044, bias=True)\n",
      "      (1): Tanh()\n",
      "      (2): Linear(in_features=1044, out_features=10, bias=True)\n",
      "    )\n",
      "  )\n",
      "  (t): Linear(in_features=10, out_features=1, bias=False)\n",
      ")\n",
      "[01/22/2024 06:29:04 PM : INFO  : auto_label : ] : g model DynamicMLP(\n",
      "  (net): Sequential(\n",
      "    (0): Linear(in_features=522, out_features=1044, bias=True)\n",
      "    (1): Tanh()\n",
      "    (2): Linear(in_features=1044, out_features=10, bias=True)\n",
      "  )\n",
      ")\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 100, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : {'optimizer': 'adam', 'learning_rate': 0.001, 'batch_size': 64, 'max_epochs': 200, 'weight_decay': 0.1, 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False}\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Using optimizer for g: <class 'torch.optim.adam.Adam'>\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Using optimizer for t: <class 'torch.optim.adam.Adam'>\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : 1.0, 5.0, 0.0\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 0 Learning Rate g : 0.001\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 0 Loss :1.8095656118392944\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 0 Surrogate Coverage : 0.5002537965774536 Surrogate Error: 0.46196451783180237 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 0 At t = 0.5, 0 Coverage : 0.7080000042915344 \t Error : 0.42816901206970215\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 0 Model Norm  13.884351620464765\n",
      "[01/22/2024 06:29:04 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 0   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 1   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 2   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 3   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 4   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 5   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 6   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 7   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 8   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 9   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.0\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch : 0  Actual Coverage on NC VAL : 0.0\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 1 Learning Rate g : 0.0009997532801828658\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 1 Loss :1.8094689559936523\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 1 Surrogate Coverage : 0.5002848505973816 Surrogate Error: 0.4619496464729309 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 1 At t = 0.5, 1 Coverage : 0.7300000190734863 \t Error : 0.42896175384521484\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 1 Model Norm  9.75515921325577\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 2 Learning Rate g : 0.0009990133642141358\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 2 Loss :1.8094241018295287\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 2 Surrogate Coverage : 0.5002966523170471 Surrogate Error: 0.4619472026824951 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 2 At t = 0.5, 2 Coverage : 0.7380000352859497 \t Error : 0.42702701687812805\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 2 Model Norm  6.463380419143868\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 3 Learning Rate g : 0.00099778098230154\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 3 Loss :1.809471519470215\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 3 Surrogate Coverage : 0.5002922415733337 Surrogate Error: 0.4619511663913727 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 3 At t = 0.5, 3 Coverage : 0.7520000338554382 \t Error : 0.42970821261405945\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 3 Model Norm  4.008156030945926\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 4 Learning Rate g : 0.000996057350657239\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 4 Loss :1.8095306067466737\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 4 Surrogate Coverage : 0.5002785921096802 Surrogate Error: 0.46195971965789795 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 4 At t = 0.5, 4 Coverage : 0.6920000314712524 \t Error : 0.42363113164901733\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 4 Model Norm  2.3155410231684987\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 5 Learning Rate g : 0.0009938441702975688\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 5 Loss :1.8095614223480225\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 5 Surrogate Coverage : 0.500268816947937 Surrogate Error: 0.46196499466896057 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 5 At t = 0.5, 5 Coverage : 0.6880000233650208 \t Error : 0.426086962223053\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 5 Model Norm  1.2689834389507477\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 6 Learning Rate g : 0.0009911436253643444\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 6 Loss :1.8095817012786866\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 6 Surrogate Coverage : 0.5002641677856445 Surrogate Error: 0.4619686007499695 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 6 At t = 0.5, 6 Coverage : 0.7600000500679016 \t Error : 0.43044620752334595\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 6 Model Norm  0.7286805949644632\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 7 Learning Rate g : 0.0009879583809693736\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 7 Loss :1.8095928230285645\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 7 Surrogate Coverage : 0.5002633333206177 Surrogate Error: 0.4619707465171814 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 7 At t = 0.5, 7 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 7 Model Norm  0.5081596485852484\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 8 Learning Rate g : 0.0009842915805643154\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 8 Loss :1.8095878467559814\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 8 Surrogate Coverage : 0.5002633333206177 Surrogate Error: 0.4619717299938202 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 8 At t = 0.5, 8 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 8 Model Norm  0.39982237565337325\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 9 Learning Rate g : 0.0009801468428384714\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 9 Loss :1.809588550567627\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 9 Surrogate Coverage : 0.5002642869949341 Surrogate Error: 0.4619726538658142 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 9 At t = 0.5, 9 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 9 Model Norm  0.3035321899875767\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 10 Learning Rate g : 0.0009755282581475767\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 10 Loss :1.8096262159347534\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 10 Surrogate Coverage : 0.5002653002738953 Surrogate Error: 0.4619735777378082 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 10 At t = 0.5, 10 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 10 Model Norm  0.21000638804429864\n",
      "[01/22/2024 06:29:04 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10000207275152206 for class 0   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10004143416881561 for class 1   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10000105202198029 for class 2   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10003522038459778 for class 3   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.09999537467956543 for class 4   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10003164410591125 for class 5   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10004309564828873 for class 6   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.09999682754278183 for class 7   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10002732276916504 for class 8   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10012440383434296 for class 9   \n",
      "[01/22/2024 06:29:04 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch : 10  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 11 Learning Rate g : 0.0009704403844771127\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 11 Loss :1.809608606338501\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 11 Surrogate Coverage : 0.5002658367156982 Surrogate Error: 0.4619746208190918 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 11 At t = 0.5, 11 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 11 Model Norm  0.13156752558747062\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 12 Learning Rate g : 0.0009648882429441257\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 12 Loss :1.8096135482788085\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 12 Surrogate Coverage : 0.5002660155296326 Surrogate Error: 0.4619752764701843 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 12 At t = 0.5, 12 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 12 Model Norm  0.07672475547360087\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 13 Learning Rate g : 0.0009588773128419905\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 13 Loss :1.8096315059661865\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 13 Surrogate Coverage : 0.5002663731575012 Surrogate Error: 0.4619761109352112 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 13 At t = 0.5, 13 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 13 Model Norm  0.04576757041868448\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 14 Learning Rate g : 0.0009524135262330098\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 14 Loss :1.8096067771911621\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 14 Surrogate Coverage : 0.5002673864364624 Surrogate Error: 0.46197691559791565 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 14 At t = 0.5, 14 Coverage : 0.7740000486373901 \t Error : 0.4355670213699341\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 14 Model Norm  0.031320156138152054\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 15 Learning Rate g : 0.0009455032620941839\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 15 Loss :1.8096230602264405\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 15 Surrogate Coverage : 0.5002673268318176 Surrogate Error: 0.4619775712490082 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 15 At t = 0.5, 15 Coverage : 0.7940000295639038 \t Error : 0.43467336893081665\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 15 Model Norm  0.023491370413091146\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 16 Learning Rate g : 0.0009381533400219318\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 16 Loss :1.8096216564178467\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 16 Surrogate Coverage : 0.5002678632736206 Surrogate Error: 0.4619785249233246 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 16 At t = 0.5, 16 Coverage : 0.8860000371932983 \t Error : 0.46171170473098755\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 16 Model Norm  0.01711546665909498\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 17 Learning Rate g : 0.0009303710135019719\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 17 Loss :1.8096293964385985\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 17 Surrogate Coverage : 0.5002679228782654 Surrogate Error: 0.46197938919067383 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 17 At t = 0.5, 17 Coverage : 0.8860000371932983 \t Error : 0.46171170473098755\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 17 Model Norm  0.011629808737359243\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 18 Learning Rate g : 0.0009221639627510076\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 18 Loss :1.8096285591125487\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 18 Surrogate Coverage : 0.5002678632736206 Surrogate Error: 0.4619801938533783 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 18 At t = 0.5, 18 Coverage : 0.8860000371932983 \t Error : 0.46171170473098755\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 18 Model Norm  0.007524938979728017\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 19 Learning Rate g : 0.000913540287137281\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 19 Loss :1.809632851600647\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 19 Surrogate Coverage : 0.5002682209014893 Surrogate Error: 0.4619809091091156 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 19 At t = 0.5, 19 Coverage : 0.8860000371932983 \t Error : 0.46171170473098755\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 19 Model Norm  0.0049306405779512\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 20 Learning Rate g : 0.0009045084971874739\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 20 Loss :1.8096429634094238\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 20 Surrogate Coverage : 0.5002681612968445 Surrogate Error: 0.4619816243648529 \n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 20 At t = 0.5, 20 Coverage : 0.8860000371932983 \t Error : 0.46171170473098755\n",
      "[01/22/2024 06:29:04 PM : DEBUG : auto_label : ] : Epoch: 20 Model Norm  0.005400911314869267\n",
      "[01/22/2024 06:29:05 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 0   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1001398116350174 for class 1   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 2   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 3   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 4   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 5   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001745074987411 for class 6   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 7   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10001744329929352 for class 8   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1001398116350174 for class 9   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch : 20  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 21 Learning Rate g : 0.0008950775061878452\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 21 Loss :1.8096424808502198\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 21 Surrogate Coverage : 0.5002681016921997 Surrogate Error: 0.4619821012020111 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 21 At t = 0.5, 21 Coverage : 0.9080000519752502 \t Error : 0.4593406617641449\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 21 Model Norm  0.0055477772684922235\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 22 Learning Rate g : 0.0008852566213878947\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 22 Loss :1.809650954246521\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 22 Surrogate Coverage : 0.500268280506134 Surrogate Error: 0.4619826078414917 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 22 At t = 0.5, 22 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 22 Model Norm  0.004904555407182979\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 23 Learning Rate g : 0.0008750555348152298\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 23 Loss :1.8096500186920166\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 23 Surrogate Coverage : 0.5002679228782654 Surrogate Error: 0.46198347210884094 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 23 At t = 0.5, 23 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 23 Model Norm  0.003690800037764375\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 24 Learning Rate g : 0.0008644843137107057\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 24 Loss :1.809666955947876\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 24 Surrogate Coverage : 0.5002683997154236 Surrogate Error: 0.46198415756225586 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 24 At t = 0.5, 24 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 24 Model Norm  0.0042957019478018785\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 25 Learning Rate g : 0.0008535533905932737\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 25 Loss :1.8096543560028076\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 25 Surrogate Coverage : 0.500268816947937 Surrogate Error: 0.4619845747947693 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 25 At t = 0.5, 25 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 25 Model Norm  0.0051077504616058745\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 26 Learning Rate g : 0.0008422735529643444\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 26 Loss :1.8096567764282228\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 26 Surrogate Coverage : 0.5002692937850952 Surrogate Error: 0.4619850516319275 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 26 At t = 0.5, 26 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 26 Model Norm  0.004198232099587803\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 27 Learning Rate g : 0.0008306559326618259\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 27 Loss :1.8096618003845215\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 27 Surrogate Coverage : 0.5002692937850952 Surrogate Error: 0.4619857966899872 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 27 At t = 0.5, 27 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 27 Model Norm  0.0033512266545669867\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 28 Learning Rate g : 0.0008187119948743449\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 28 Loss :1.8096654663085938\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 28 Surrogate Coverage : 0.5002691745758057 Surrogate Error: 0.4619862139225006 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 28 At t = 0.5, 28 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 28 Model Norm  0.003732516477660145\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 29 Learning Rate g : 0.0008064535268264883\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 29 Loss :1.8096651554107666\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 29 Surrogate Coverage : 0.5002691745758057 Surrogate Error: 0.4619867503643036 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 29 At t = 0.5, 29 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 29 Model Norm  0.00427514234119075\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 30 Learning Rate g : 0.0007938926261462367\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 30 Loss :1.8096687746047975\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 30 Surrogate Coverage : 0.5002692937850952 Surrogate Error: 0.46198713779449463 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 30 At t = 0.5, 30 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 30 Model Norm  0.0041084629933604\n",
      "[01/22/2024 06:29:05 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 0   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 1   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 2   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 3   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 4   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 5   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 6   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 7   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 8   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.1002216637134552 for class 9   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch : 30  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 31 Learning Rate g : 0.0007810416889260654\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 31 Loss :1.80966268825531\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 31 Surrogate Coverage : 0.5002692937850952 Surrogate Error: 0.4619876444339752 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 31 At t = 0.5, 31 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 31 Model Norm  0.004567286907377209\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 32 Learning Rate g : 0.0007679133974894983\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 32 Loss :1.8096698598861694\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 32 Surrogate Coverage : 0.50026935338974 Surrogate Error: 0.46198782324790955 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 32 At t = 0.5, 32 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 32 Model Norm  0.004887039190708001\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 33 Learning Rate g : 0.0007545207078751857\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 33 Loss :1.8096719284057616\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 33 Surrogate Coverage : 0.5002697110176086 Surrogate Error: 0.46198809146881104 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 33 At t = 0.5, 33 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 33 Model Norm  0.004621601057561668\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 34 Learning Rate g : 0.0007408768370508577\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 34 Loss :1.8096721210479736\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 34 Surrogate Coverage : 0.5002702474594116 Surrogate Error: 0.4619884192943573 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 34 At t = 0.5, 34 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 34 Model Norm  0.004263565711322833\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 35 Learning Rate g : 0.0007269952498697734\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 35 Loss :1.8096734962463379\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 35 Surrogate Coverage : 0.5002707242965698 Surrogate Error: 0.461988627910614 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 35 At t = 0.5, 35 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 35 Model Norm  0.004262393999357638\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 36 Learning Rate g : 0.0007128896457825364\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 36 Loss :1.8096738872528075\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 36 Surrogate Coverage : 0.500271201133728 Surrogate Error: 0.46198877692222595 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 36 At t = 0.5, 36 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 36 Model Norm  0.0044809740274705636\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 37 Learning Rate g : 0.0006985739453173903\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 37 Loss :1.809672306060791\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 37 Surrogate Coverage : 0.5002713203430176 Surrogate Error: 0.4619891345500946 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 37 At t = 0.5, 37 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 37 Model Norm  0.004440464604254434\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 38 Learning Rate g : 0.0006840622763423391\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 38 Loss :1.8096790294647216\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 38 Surrogate Coverage : 0.5002711415290833 Surrogate Error: 0.4619894325733185 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 38 At t = 0.5, 38 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 38 Model Norm  0.0043168000655988735\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 39 Learning Rate g : 0.0006693689601226458\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 39 Loss :1.8096786251068115\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 39 Surrogate Coverage : 0.500271201133728 Surrogate Error: 0.4619896411895752 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 39 At t = 0.5, 39 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 39 Model Norm  0.004517764428143314\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 40 Learning Rate g : 0.0006545084971874737\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 40 Loss :1.809677812576294\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 40 Surrogate Coverage : 0.5002714395523071 Surrogate Error: 0.4619898498058319 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 40 At t = 0.5, 40 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 40 Model Norm  0.0034387633784900462\n",
      "[01/22/2024 06:29:05 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 0   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 1   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 2   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 3   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 4   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 5   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 6   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 7   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 8   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016706585884094 for class 9   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch : 40  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 41 Learning Rate g : 0.0006394955530196147\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 41 Loss :1.8096780138015747\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 41 Surrogate Coverage : 0.5002716779708862 Surrogate Error: 0.4619901478290558 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 41 At t = 0.5, 41 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 41 Model Norm  0.0036628514275353933\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 42 Learning Rate g : 0.0006243449435824273\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 42 Loss :1.8096812524795531\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 42 Surrogate Coverage : 0.500271737575531 Surrogate Error: 0.4619902968406677 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 42 At t = 0.5, 42 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 42 Model Norm  0.004315941602126892\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 43 Learning Rate g : 0.0006090716206982714\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 43 Loss :1.8096818342208862\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 43 Surrogate Coverage : 0.5002717971801758 Surrogate Error: 0.4619903564453125 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 43 At t = 0.5, 43 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 43 Model Norm  0.004691605459398427\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 44 Learning Rate g : 0.0005936906572928625\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 44 Loss :1.809683648109436\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 44 Surrogate Coverage : 0.5002719759941101 Surrogate Error: 0.4619905352592468 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 44 At t = 0.5, 44 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 44 Model Norm  0.004031208345549161\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 45 Learning Rate g : 0.0005782172325201156\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 45 Loss :1.8096808776855469\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 45 Surrogate Coverage : 0.5002721548080444 Surrogate Error: 0.461990624666214 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 45 At t = 0.5, 45 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 45 Model Norm  0.004116491415347709\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 46 Learning Rate g : 0.0005626666167821523\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 46 Loss :1.8096828136444092\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 46 Surrogate Coverage : 0.5002723336219788 Surrogate Error: 0.4619908034801483 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 46 At t = 0.5, 46 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 46 Model Norm  0.003939585760547504\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 47 Learning Rate g : 0.0005470541566592572\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 47 Loss :1.8096853961944581\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 47 Surrogate Coverage : 0.5002725720405579 Surrogate Error: 0.46199095249176025 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 47 At t = 0.5, 47 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 47 Model Norm  0.0043110419065889695\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 48 Learning Rate g : 0.0005313952597646569\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 48 Loss :1.8096806392669678\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 48 Surrogate Coverage : 0.5002726912498474 Surrogate Error: 0.46199098229408264 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 48 At t = 0.5, 48 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 48 Model Norm  0.004906182177406762\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 49 Learning Rate g : 0.0005157053795390643\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 49 Loss :1.8096833877563476\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 49 Surrogate Coverage : 0.5002729296684265 Surrogate Error: 0.4619911313056946 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 49 At t = 0.5, 49 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 49 Model Norm  0.00436290865766172\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 50 Learning Rate g : 0.0005000000000000002\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 50 Loss :1.8096809883117675\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 50 Surrogate Coverage : 0.5002731084823608 Surrogate Error: 0.46199125051498413 \n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 50 At t = 0.5, 50 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:05 PM : DEBUG : auto_label : ] : Epoch: 50 Model Norm  0.0038229504134619013\n",
      "[01/22/2024 06:29:05 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 0   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 1   \n",
      "[01/22/2024 06:29:05 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 2   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 3   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 4   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 5   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 6   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 7   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 8   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10016331821680069 for class 9   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch : 50  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 51 Learning Rate g : 0.00048429462046093607\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 51 Loss :1.8096838102340698\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 51 Surrogate Coverage : 0.5002732872962952 Surrogate Error: 0.46199122071266174 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 51 At t = 0.5, 51 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 51 Model Norm  0.0038294468540747677\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 52 Learning Rate g : 0.0004686047402353435\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 52 Loss :1.8096834468841552\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 52 Surrogate Coverage : 0.5002733469009399 Surrogate Error: 0.46199145913124084 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 52 At t = 0.5, 52 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 52 Model Norm  0.0037133737932911635\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 53 Learning Rate g : 0.000452945843340743\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 53 Loss :1.8096844234466554\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 53 Surrogate Coverage : 0.5002734661102295 Surrogate Error: 0.4619915187358856 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 53 At t = 0.5, 53 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 53 Model Norm  0.003959723748267486\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 54 Learning Rate g : 0.00043733338321784806\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 54 Loss :1.8096839380264282\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 54 Surrogate Coverage : 0.500273585319519 Surrogate Error: 0.4619915783405304 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 54 At t = 0.5, 54 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 54 Model Norm  0.004038866609335264\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 55 Learning Rate g : 0.0004217827674798847\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 55 Loss :1.8096850032806397\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 55 Surrogate Coverage : 0.5002735257148743 Surrogate Error: 0.46199169754981995 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 55 At t = 0.5, 55 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 55 Model Norm  0.003968337085098169\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 56 Learning Rate g : 0.00040630934270713783\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 56 Loss :1.8096866073608397\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 56 Surrogate Coverage : 0.5002733469009399 Surrogate Error: 0.4619917869567871 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 56 At t = 0.5, 56 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 56 Model Norm  0.003947965335100953\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 57 Learning Rate g : 0.000390928379301729\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 57 Loss :1.809685890197754\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 57 Surrogate Coverage : 0.5002734661102295 Surrogate Error: 0.4619918763637543 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 57 At t = 0.5, 57 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 57 Model Norm  0.004337213002145317\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 58 Learning Rate g : 0.0003756550564175727\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 58 Loss :1.809687520980835\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 58 Surrogate Coverage : 0.5002737045288086 Surrogate Error: 0.46199193596839905 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 58 At t = 0.5, 58 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 58 Model Norm  0.004338001832366002\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 59 Learning Rate g : 0.00036050444698038553\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 59 Loss :1.8096887531280517\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 59 Surrogate Coverage : 0.5002736449241638 Surrogate Error: 0.46199193596839905 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 59 At t = 0.5, 59 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 59 Model Norm  0.0042776195332407995\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 60 Learning Rate g : 0.00034549150281252655\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 60 Loss :1.8096864852905274\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 60 Surrogate Coverage : 0.5002737641334534 Surrogate Error: 0.4619919955730438 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 60 At t = 0.5, 60 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 60 Model Norm  0.003530537243932488\n",
      "[01/22/2024 06:29:06 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 0   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 1   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 2   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 3   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 4   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 5   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 6   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 7   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 8   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10014470666646957 for class 9   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch : 60  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 61 Learning Rate g : 0.0003306310398773544\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 61 Loss :1.8096856575012208\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 61 Surrogate Coverage : 0.5002740621566772 Surrogate Error: 0.4619920551776886 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 61 At t = 0.5, 61 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 61 Model Norm  0.0035940194502472886\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 62 Learning Rate g : 0.00031593772365766127\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 62 Loss :1.8096865940093994\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 62 Surrogate Coverage : 0.5002741813659668 Surrogate Error: 0.461992084980011 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 62 At t = 0.5, 62 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 62 Model Norm  0.0038165182340890173\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 63 Learning Rate g : 0.0003014260546826097\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 63 Loss :1.809687005996704\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 63 Surrogate Coverage : 0.5002742409706116 Surrogate Error: 0.4619922637939453 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 63 At t = 0.5, 63 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 63 Model Norm  0.0038033444434404378\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 64 Learning Rate g : 0.0002871103542174637\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 64 Loss :1.8096883907318115\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 64 Surrogate Coverage : 0.5002741813659668 Surrogate Error: 0.4619922935962677 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 64 At t = 0.5, 64 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 64 Model Norm  0.003875667927786708\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 65 Learning Rate g : 0.0002730047501302267\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 65 Loss :1.8096894397735597\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 65 Surrogate Coverage : 0.5002743005752563 Surrogate Error: 0.4619923532009125 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 65 At t = 0.5, 65 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 65 Model Norm  0.0038573374040424824\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 66 Learning Rate g : 0.00025912316294914234\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 66 Loss :1.8096874656677246\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 66 Surrogate Coverage : 0.5002743601799011 Surrogate Error: 0.46199244260787964 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 66 At t = 0.5, 66 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 66 Model Norm  0.003737078979611397\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 67 Learning Rate g : 0.0002454792921248144\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 67 Loss :1.809688356399536\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 67 Surrogate Coverage : 0.5002744197845459 Surrogate Error: 0.46199244260787964 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 67 At t = 0.5, 67 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 67 Model Norm  0.003974554128944874\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 68 Learning Rate g : 0.00023208660251050164\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 68 Loss :1.809688907623291\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 68 Surrogate Coverage : 0.500274658203125 Surrogate Error: 0.461992472410202 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 68 At t = 0.5, 68 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 68 Model Norm  0.003914392553269863\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 69 Learning Rate g : 0.00021895831107393473\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 69 Loss :1.8096887559890746\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 69 Surrogate Coverage : 0.5002747178077698 Surrogate Error: 0.4619925320148468 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 69 At t = 0.5, 69 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 69 Model Norm  0.004260041750967503\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 70 Learning Rate g : 0.00020610737385376356\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 70 Loss :1.809688175201416\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 70 Surrogate Coverage : 0.5002747178077698 Surrogate Error: 0.4619925320148468 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 70 At t = 0.5, 70 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 70 Model Norm  0.004199512302875519\n",
      "[01/22/2024 06:29:06 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 0   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 1   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 2   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 3   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 4   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 5   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 6   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 7   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 8   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10022850334644318 for class 9   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch : 70  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 71 Learning Rate g : 0.00019354647317351177\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 71 Loss :1.8096868228912353\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 71 Surrogate Coverage : 0.5002747774124146 Surrogate Error: 0.4619925022125244 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 71 At t = 0.5, 71 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 71 Model Norm  0.004229276906698942\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 72 Learning Rate g : 0.0001812880051256552\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 72 Loss :1.8096876649856568\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 72 Surrogate Coverage : 0.5002748370170593 Surrogate Error: 0.46199244260787964 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 72 At t = 0.5, 72 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 72 Model Norm  0.004134295973926783\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 73 Learning Rate g : 0.00016934406733817422\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 73 Loss :1.8096886415481568\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 73 Surrogate Coverage : 0.5002747774124146 Surrogate Error: 0.4619925320148468 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 73 At t = 0.5, 73 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 73 Model Norm  0.0039537157863378525\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 74 Learning Rate g : 0.0001577264470356557\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 74 Loss :1.809689344406128\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 74 Surrogate Coverage : 0.5002747178077698 Surrogate Error: 0.4619925320148468 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 74 At t = 0.5, 74 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 74 Model Norm  0.00407565338537097\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 75 Learning Rate g : 0.00014644660940672634\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 75 Loss :1.8096882972717285\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 75 Surrogate Coverage : 0.5002747178077698 Surrogate Error: 0.4619925320148468 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 75 At t = 0.5, 75 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 75 Model Norm  0.0040558078326284885\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 76 Learning Rate g : 0.0001355156862892944\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 76 Loss :1.809688973426819\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 76 Surrogate Coverage : 0.5002747178077698 Surrogate Error: 0.4619925916194916 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 76 At t = 0.5, 76 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 76 Model Norm  0.003973293583840132\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 77 Learning Rate g : 0.00012494446518477025\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 77 Loss :1.8096895084381104\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 77 Surrogate Coverage : 0.5002747774124146 Surrogate Error: 0.4619925916194916 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 77 At t = 0.5, 77 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 77 Model Norm  0.003829119261354208\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 78 Learning Rate g : 0.00011474337861210548\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 78 Loss :1.8096880226135255\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 78 Surrogate Coverage : 0.5002747178077698 Surrogate Error: 0.46199262142181396 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 78 At t = 0.5, 78 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 78 Model Norm  0.0037643318064510822\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 79 Learning Rate g : 0.00010492249381215483\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 79 Loss :1.8096891651153564\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 79 Surrogate Coverage : 0.5002747774124146 Surrogate Error: 0.46199262142181396 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 79 At t = 0.5, 79 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 79 Model Norm  0.003669874044135213\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 80 Learning Rate g : 9.549150281252637e-05\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 80 Loss :1.8096893787384034\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 80 Surrogate Coverage : 0.5002747774124146 Surrogate Error: 0.46199262142181396 \n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 80 At t = 0.5, 80 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:06 PM : DEBUG : auto_label : ] : Epoch: 80 Model Norm  0.0036457336973398924\n",
      "[01/22/2024 06:29:06 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 0   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 1   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 2   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 3   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 4   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 5   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 6   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 7   \n",
      "[01/22/2024 06:29:06 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 8   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019399225711823 for class 9   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch : 80  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 81 Learning Rate g : 8.645971286271918e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 81 Loss :1.809689390182495\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 81 Surrogate Coverage : 0.5002747774124146 Surrogate Error: 0.46199268102645874 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 81 At t = 0.5, 81 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 81 Model Norm  0.0036065559834241867\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 82 Learning Rate g : 7.78360372489926e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 82 Loss :1.8096897144317627\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 82 Surrogate Coverage : 0.5002748370170593 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 82 At t = 0.5, 82 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 82 Model Norm  0.0036442773416638374\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 83 Learning Rate g : 6.962898649802815e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 83 Loss :1.8096894588470458\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 83 Surrogate Coverage : 0.5002748370170593 Surrogate Error: 0.46199268102645874 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 83 At t = 0.5, 83 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 83 Model Norm  0.003780853468924761\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 84 Learning Rate g : 6.184665997806824e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 84 Loss :1.809689082145691\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 84 Surrogate Coverage : 0.5002748966217041 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 84 At t = 0.5, 84 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 84 Model Norm  0.003943354357033968\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 85 Learning Rate g : 5.449673790581613e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 85 Loss :1.8096885137557983\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 85 Surrogate Coverage : 0.5002748966217041 Surrogate Error: 0.46199268102645874 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 85 At t = 0.5, 85 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 85 Model Norm  0.004001017194241285\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 86 Learning Rate g : 4.758647376699034e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 86 Loss :1.80968825340271\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 86 Surrogate Coverage : 0.5002750158309937 Surrogate Error: 0.4619925916194916 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 86 At t = 0.5, 86 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 86 Model Norm  0.004009193275123835\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 87 Learning Rate g : 4.112268715800956e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 87 Loss :1.8096887340545655\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 87 Surrogate Coverage : 0.5002750754356384 Surrogate Error: 0.4619925916194916 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 87 At t = 0.5, 87 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 87 Model Norm  0.003981930669397116\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 88 Learning Rate g : 3.511175705587434e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 88 Loss :1.809688570022583\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 88 Surrogate Coverage : 0.5002750158309937 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 88 At t = 0.5, 88 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 88 Model Norm  0.003957821987569332\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 89 Learning Rate g : 2.9559615522887284e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 89 Loss :1.8096885929107667\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 89 Surrogate Coverage : 0.5002750754356384 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 89 At t = 0.5, 89 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 89 Model Norm  0.003954272251576185\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 90 Learning Rate g : 2.447174185242324e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 90 Loss :1.8096885776519775\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 90 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.4619925916194916 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 90 At t = 0.5, 90 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 90 Model Norm  0.003938586916774511\n",
      "[01/22/2024 06:29:07 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 0   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 1   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 2   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 3   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 4   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 5   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 6   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 7   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 8   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10019709169864655 for class 9   \n",
      "[01/22/2024 06:29:07 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch : 90  Actual Coverage on NC VAL : 0.57\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 91 Learning Rate g : 1.9853157161528526e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 91 Loss :1.8096896238327027\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 91 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 91 At t = 0.5, 91 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 91 Model Norm  0.003915319684892893\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 92 Learning Rate g : 1.570841943568452e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 92 Loss :1.8096880989074706\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 92 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 92 At t = 0.5, 92 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 92 Model Norm  0.003917388152331114\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 93 Learning Rate g : 1.204161903062634e-05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 93 Loss :1.8096872634887695\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 93 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199262142181396 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 93 At t = 0.5, 93 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 93 Model Norm  0.003919894807040691\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 94 Learning Rate g : 8.85637463565564e-06\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 94 Loss :1.809687644958496\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 94 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 94 At t = 0.5, 94 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 94 Model Norm  0.003931893967092037\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 95 Learning Rate g : 6.155829702431171e-06\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 95 Loss :1.8096882495880127\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 95 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 95 At t = 0.5, 95 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 95 Model Norm  0.003939663991332054\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 96 Learning Rate g : 3.942649342761118e-06\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 96 Loss :1.8096898860931396\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 96 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199262142181396 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 96 At t = 0.5, 96 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 96 Model Norm  0.00393923744559288\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 97 Learning Rate g : 2.2190176984600023e-06\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 97 Loss :1.8096887159347534\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 97 Surrogate Coverage : 0.5002750754356384 Surrogate Error: 0.46199268102645874 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 97 At t = 0.5, 97 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 97 Model Norm  0.003935104236006737\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 98 Learning Rate g : 9.866357858642206e-07\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 98 Loss :1.8096889209747316\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 98 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199265122413635 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 98 At t = 0.5, 98 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 98 Model Norm  0.003933093976229429\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 99 Learning Rate g : 2.467198171342e-07\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 99 Loss :1.8096882362365723\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 99 Surrogate Coverage : 0.5002751350402832 Surrogate Error: 0.46199262142181396 \n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 99 At t = 0.5, 99 Coverage : 1.0 \t Error : 0.46107783913612366\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Epoch: 99 Model Norm  0.003932709340006113\n",
      "[01/22/2024 06:29:07 PM : INFO  : auto_label : ] : xxxxxxxxxxxxxxxxxxxxx  Auto-labeling actual remaining unlabeled data  xxxxxxxxxxxxxxxxxxxxx\n",
      "[01/22/2024 06:29:07 PM : INFO  : auto_label : ] : ========================= Begin Auto-Labeling selective ==========================\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Auto Labeling Conf : {'method_name': 'selective', 'score_type': 'confidence', 'class_wise': 'independent', 'auto_label_err_threshold': 0.05, 'C_1': 0.25, 'ucb': 'sigma', 'fast': True}\n",
      "[01/22/2024 06:29:07 PM : INFO  : auto_label : ] : Number of unlabeled points : 36000\n",
      "[01/22/2024 06:29:07 PM : INFO  : data_manag : ] :  Cur calib ds size : 500\n",
      "[01/22/2024 06:29:07 PM : INFO  : auto_label : ] : Using number of validation points : 500\n",
      "[01/22/2024 06:29:07 PM : INFO  : auto_label : ] : Using Auto-Labeling Error Threshold = 0.05\n",
      "[01/22/2024 06:29:07 PM : DEBUG : auto_label : ] : Expected Calibration Error on Validation set : 0.5298809868097305\n",
      "[01/22/2024 06:29:08 PM : DEBUG : auto_label : ] : Expected Calibration Error on Validation set with NO Calibration : 0.3243530508875847\n",
      "[01/22/2024 06:29:08 PM : INFO  : auto_label : ] : Determining Thresholds : Class Wise : independent\n",
      "[01/22/2024 06:29:08 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10000207275152206 for class 0   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10004143416881561 for class 1   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10000105202198029 for class 2   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10003522038459778 for class 3   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.09999537467956543 for class 4   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10003164410591125 for class 5   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10004309564828873 for class 6   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.09999682754278183 for class 7   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10002732276916504 for class 8   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.10012440383434296 for class 9   \n",
      "[01/22/2024 06:29:08 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.57\n",
      "[01/22/2024 06:29:08 PM : INFO  : auto_label : ] : auto-labeling thresholds from val set: [0.10000207, 0.100041434, 0.10000105, 0.10003522, 0.099995375, 0.100031644, 0.100043096, 0.09999683, 0.10002732, 0.100124404]\n",
      "[01/22/2024 06:29:10 PM : INFO  : auto_label : ] : Num auto labeled points : 20004 \n",
      "[01/22/2024 06:29:10 PM : INFO  : auto_label : ] : Num validation pts to remove : 289\n",
      "[01/22/2024 06:29:10 PM : INFO  : auto_label : ] : ============================== Done Auto-Labeling ==============================\n",
      "[01/22/2024 06:29:10 PM : INFO  : 996596987 : ] :  Selective Auto-labeling counts: {'auto_labeled_acc': 0.966006798640272, 'coverage_1': 0.5001, 'coverage_2': 0}\n"
     ]
    }
   ],
   "source": [
    "conf['calib_conf'] = OmegaConf.load(f'{conf_dir}/post-hoc/auto_lbl_opt_v0_conf.yaml')\n",
    "\n",
    "calib_conf = conf['calib_conf']\n",
    "\n",
    "calib_conf['l1']=1.0 \n",
    "calib_conf['l2']=5.0 # 3 or 5\n",
    "calib_conf['l3']=0.0  #1.0\n",
    "calib_conf['l4']=0.0\n",
    "calib_conf['calib_val_frac'] = calib_val_frac \n",
    "\n",
    "#calib_conf['features_key']  = 'logits'\n",
    "#calib_conf['features_key']  = 'pre_logits'\n",
    "calib_conf['features_key']  = 'concat'\n",
    "\n",
    "#calib_conf['class_wise'] = 'joint'\n",
    "calib_conf['class_wise'] = 'independent'\n",
    "#calib_conf['class_wise'] =\"joint_g_independent_t\"\n",
    "model = \"two_layer\"\n",
    "#model = \"linear\" \n",
    "calib_conf['num_classes'] = 10 \n",
    "\n",
    "\n",
    "if(model==\"two_layer\"):\n",
    "    model_conf = OmegaConf.load('{}/model_confs/two_layer_net_base_conf.yaml'.format(conf_dir))\n",
    "\n",
    "    model_conf.layers[0]['dim_factor']=2\n",
    "    model_conf.layers[1]['act_fun']='tanh'\n",
    "\n",
    "else:\n",
    "    model_conf = {} \n",
    "\n",
    "model_conf['num_classes'] = 10\n",
    "\n",
    "calib_conf['model_conf'] = model_conf \n",
    "\n",
    "\n",
    "#calib_conf['regularize'] = False  \n",
    "calib_conf['regularize'] = False \n",
    "calib_conf['auto_lbl_conf'] = conf.auto_lbl_conf\n",
    "\n",
    "\n",
    "#calib_conf['features_key']  = 'logits'\n",
    "\n",
    "#calib_conf['alpha_1'] = 0.0001 #/1.5\n",
    "calib_conf['alpha_1'] =0.01 #/1.5\n",
    "\n",
    "calib_conf['training_conf_g']['batch_size'] = 64  # 64\n",
    "\n",
    "calib_conf['training_conf_g']['optimizer'] = 'adam'\n",
    "calib_conf['training_conf_g']['learning_rate'] = 0.001\n",
    "calib_conf['training_conf_g']['weight_decay'] =  0.1\n",
    "\n",
    "calib_conf['training_conf_t']['optimizer'] = 'adam'\n",
    "calib_conf['training_conf_t']['learning_rate'] = 0.001\n",
    "calib_conf['training_conf_t']['weight_decay'] = 0.1\n",
    "\n",
    "\n",
    "calib_conf['training_conf_g']['max_epochs'] = 100\n",
    "\n",
    "augment_conf(conf)\n",
    "pl2, calib2, dm2, counts = run_conf_2(conf,None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "dm = dm2 \n",
    "pl = pl2 \n",
    "calib = calib2 \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.inspection import DecisionBoundaryDisplay\n",
    "import matplotlib as mpl\n",
    "\n",
    "\n",
    "def visualize_scores_dist(ax, inf_out, clf=None, calibrator=None, ds=None, plot_type={}, normalize=False):\n",
    "    \n",
    "    if(inf_out==None):\n",
    "        if(calibrator):\n",
    "            inf_out = calibrator.predict(ds,inference_conf=None)\n",
    "        else:\n",
    "            inf_out = clf.predict(ds,inference_conf=None)\n",
    "    \n",
    "    \n",
    "    y_hat = safe_to_numpy(inf_out['labels'])\n",
    "    Y     = safe_to_numpy(inf_out['true_labels'])\n",
    "    idx = np.arange(0,len(Y),1) \n",
    "\n",
    "    correct_idcs   = idx[y_hat==Y]\n",
    "    incorrect_idcs = idx[y_hat!=Y]\n",
    "\n",
    "    scores = safe_to_numpy(inf_out['confidence'])\n",
    "    #sns.histplot(np.clip(scores[correct_idcs],0,1),ax=ax_scores_dist)\n",
    "    #sns.histplot(np.clip(scores[incorrect_idcs],0,1),ax=ax_scores_dist)\n",
    "    p =plot_type\n",
    "    if(normalize):\n",
    "        scores = scores - min(scores)\n",
    "        scores = scores/max(scores)\n",
    "    \n",
    "    if(plot_type['name']=='hist'):\n",
    "        \n",
    "        \n",
    "        h1, edges1 = np.histogram(scores[correct_idcs],bins=p['num_bins'],density=True, )\n",
    "        h1 = h1/np.sum(h1)\n",
    "        h2, edges2 = np.histogram(scores[incorrect_idcs],bins=p['num_bins'],density=True, )\n",
    "        h2 = h2/np.sum(h2)\n",
    "        ax.bar(edges1[1:], height=h1, width=0.01,color='blue',label='Correct') #histtype=p['histtype']\n",
    "        ax.bar(edges2[1:], height=h2, width=0.01,color='red',label='Incorrect')\n",
    "        ax.set_xlim(-0.1,1.1)\n",
    "        ax.set_ylim(0,max(max(h1),max(h2)))\n",
    "        \n",
    "\n",
    "    elif(plot_type['name']=='kde'):\n",
    "        #sns.color_palette(\"hls\", 8)\n",
    "        sns.kdeplot(np.clip(scores[correct_idcs],0,1),ax=ax, clip=(-1,1.05), fill=p['fill'],label='Correct',linewidth=2.0,alpha=0.4)\n",
    "        sns.kdeplot(np.clip(scores[incorrect_idcs],0,1),ax=ax, clip=(-1,1.05), fill=p['fill'],label='Incorrect',linewidth=2.0,alpha=0.4)\n",
    "    ax.legend(loc='upper left')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "36000\n"
     ]
    },
    {
     "data": {
      "image/png": "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TRg1ahTCw8MRFxeHG264ARcvXsSUKVOwfv16vPLKKxAEAYIg4OTJk75664iILsFgDBDvvf8hIsLDsOV/y/DSnCfw7Px/YvWP6wAAdrsdN909HZu278H7rz2Hg/v3Y/78+dDrpS7WHTt2YOLEibjrrruwb98+PP3003jqqaewdOlSt9f45z//iX79+mHXrl146qmnAADV1dV48cUX8c477+DAgQNISkrCQw89hM2bN2P58uXYu3cv7rjjDtx44404evQoAGD37t247rrr0KtXL2zevBkbN27E2LFjYbPZ8Morr2DYsGG47777UFBQgIKCAqSnp/vtfSQiYldqgOib3QtzZjwAAOia3R+v//tDrFm3AddfOwo/rF2Prbv2IWfdZ+jWuSOQlI6sLl2cj12wYAGuu+46Z9h169YNBw8exD/+8Q9MmTLFeb9rr70Wjz32mPPzn376CRaLBW+88Qb69esHADh16hSWLFmCU6dOIS0tDQAwc+ZMrFq1CkuWLMELL7yAl156CYMGDcIbb7zhfK7s7GzntdFoRHh4OFJSUrz/RhERXQZbjAGib3ZP1yeCDqkpySg6XwwA2L13PzqkpUihCFwyAScnJwcjRoxwu23EiBE4evSo86BhABg0aNAlr2s0GtG3b1/n5/v27YPNZkO3bt0QGRnp/Fi/fj2OHz8u1VPfYiQiUiO2GANESIh8CzhpbM5utwMAwhoe5CufqNMKERERl9wWFhYGQbbLTmVlJfR6PXbs2OHsqnWIjIx0PoaISK3YYgwU8lMzGsxK7du7F87kF+LI8TzphgYzU3v27IlNmza53bZp0yZ069btknC7nAEDBsBms6GoqAhdunRx+3B0jfbt2xdr1qxp8jmMRqNbS5WIyJ/YYmxKbbm0lMIfr+MNot113SAYR149AtcMH4rb7/8LFsyZgS69BuLQ2e0QBAE33ngjHnvsMQwePBhz587FnXfeic2bN+P11193GwNsqW7duuHuu+/GpEmT8PLLL2PAgAE4f/481qxZg759++KWW27Bk08+iT59+mDatGl48MEHYTQasXbtWtxxxx1o164dOnXqhC1btuDkyZOIjIxEfHw8l4AQkd/wp02TRGl9oa8/PFjc32S9Dg3XMQL47D9vY3C/XvjttL+i19CRePzxx52tsoEDB+K///0vli9fjt69e2P27Nl49tln3Sbe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lxb02GJshifHXqWkpATkMVltOQLsn//8J+bPn48ffvgBffv29WWZPtfa9+H48eM4efIkxo4d67zNbrcDAAwGAw4fPozOnTv7tmgf8eT/RGpqKkJCQqDX65239ezZE4WFhairq4PRaPRpzb7iyXvx1FNP4Z577sG9994LAOjTpw+qqqpw//33429/+xt0uuBotzT1MzM6OlqR1iLAFmOzPDn2atiwYW73B4DVq1dr/pgsT48Ae+mllzB37lysWrUKgwYN8kepPtXa96FHjx7Yt28fdu/e7fy49dZbMXr0aOzevRvp6en+LN+rPPk/MWLECBw7dsz5ywEAHDlyBKmpqZoNRcCz96K6uvqS8HP8wiAG0RbWqvyZqdi0H41Yvny5aDKZxKVLl4oHDx4U77//fjE2NlYsLCwURVEU77nnHnHWrFnO+2/atEk0GAziP//5TzEnJ0ecM2dOQC3XaM17MX/+fNFoNIqffvqpWFBQ4PyoqKhQ6q/gFa19HxoKpFmprX0vTp06JUZFRYkPPfSQePjwYXHlypViUlKS+Nxzzyn1V/Ca1r4Xc+bMEaOiosSPPvpIPHHihPj999+LnTt3FidOnKjUX8ErKioqxF27dom7du0SAYgLFiwQd+3aJebl5YmiKIqzZs0S77nnHuf9Hcs1/vKXv4g5OTniokWLuFxDC1577TUxIyNDNBqN4pAhQ8RffvnF+bWRI0eKkydPdrv/f//7X7Fbt26i0WgUs7Ozxa+//trPFftOa96Ljh07igAu+ZgzZ47/C/ey1v6fkAukYBTF1r8XP//8szh06FDRZDKJWVlZ4vPPPy9arVY/V+0brXkvLBaL+PTTT4udO3cWQ0NDxfT0dHHatGnixYsX/V+4F61du7bR73vH333y5MniyJEjL3lM//79RaPRKGZlZYlLlizxe91yPHaKiIhIhmOMREREMgxGIiIiGQYjERGRDIORiIhIhsFIREQkw2AkIiKSYTASERHJMBiJiIhkGIxEREQyDEYiIiIZBiMREZHM/wcMWbEwHI272AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dm.unmark_auto_labeled()\n",
    "\n",
    "ds_ = dm.get_subset_dataset(dm.get_current_unlabeled_idcs())\n",
    "print(len(ds_))\n",
    "inf_out = {}\n",
    "if(calib):\n",
    "    inf_out = calib.predict(ds_,inference_conf=None)\n",
    "else:\n",
    "    inf_out = pl.cur_clf.predict(ds_,inference_conf=None)\n",
    "inf_out['true_labels'] = ds_.Y\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, 1,figsize=(5, 4))\n",
    "\n",
    "#cs = visualize_decision_boundary(axs[0],pl.cur_clf,calibrator=None,dm=dm)\n",
    "#fig.colorbar(cs, ax=axs[0], shrink=0.9)\n",
    "\n",
    "#visualize_scores_dist(axs, inf_out, plot_type={\"name\":\"hist\", \"num_bins\":15})\n",
    "visualize_scores_dist(axs, inf_out, plot_type={\"name\":\"kde\",\"fill\":True},normalize=True)\n",
    "\n",
    "#bin_data = compute_calibration(inf_out['true_labels'], inf_out['labels'], inf_out['confidence'], num_bins=10)\n",
    "#reliability_diagram_subplot(axs[2], bin_data, draw_ece=True, draw_bin_importance=False, title=\"Reliability Diagram\", \n",
    "#                                 xlabel=\"Confidence\", ylabel=\"Expected Accuracy\",disable_labels=False)\n",
    "\n",
    "#fig.colorbar(cs, ax=axs[0], shrink=0.9)\n",
    "#visualize_error_cov(axs[3], inf_out, normalize=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.10015847, 0.10020682, 0.1002064 , ..., 0.10021973, 0.10027228,\n",
       "       0.09997754], dtype=float32)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "inf_out['confidence']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle \n",
    "with open('../../outputs/figure-2/cifar10-med-net-std-xent_FalCon_inf_out_unlbld.pkl',\"wb\") as f :\n",
    "    pickle.dump(inf_out, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plt' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m fig, axs \u001b[39m=\u001b[39m plt\u001b[39m.\u001b[39msubplots(\u001b[39m1\u001b[39m, \u001b[39m1\u001b[39m,figsize\u001b[39m=\u001b[39m(\u001b[39m5\u001b[39m, \u001b[39m4\u001b[39m))\n\u001b[1;32m      3\u001b[0m bin_data \u001b[39m=\u001b[39m compute_calibration(inf_out[\u001b[39m'\u001b[39m\u001b[39mtrue_labels\u001b[39m\u001b[39m'\u001b[39m], inf_out[\u001b[39m'\u001b[39m\u001b[39mlabels\u001b[39m\u001b[39m'\u001b[39m], inf_out[\u001b[39m'\u001b[39m\u001b[39mconfidence\u001b[39m\u001b[39m'\u001b[39m], num_bins\u001b[39m=\u001b[39m\u001b[39m10\u001b[39m)\n\u001b[1;32m      4\u001b[0m reliability_diagram_subplot(axs, bin_data, draw_ece\u001b[39m=\u001b[39m\u001b[39mTrue\u001b[39;00m, draw_bin_importance\u001b[39m=\u001b[39m\u001b[39mFalse\u001b[39;00m, title\u001b[39m=\u001b[39m\u001b[39m\"\u001b[39m\u001b[39mReliability Diagram\u001b[39m\u001b[39m\"\u001b[39m, \n\u001b[1;32m      5\u001b[0m                                  xlabel\u001b[39m=\u001b[39m\u001b[39m\"\u001b[39m\u001b[39mConfidence\u001b[39m\u001b[39m\"\u001b[39m, ylabel\u001b[39m=\u001b[39m\u001b[39m\"\u001b[39m\u001b[39mExpected Accuracy\u001b[39m\u001b[39m\"\u001b[39m,disable_labels\u001b[39m=\u001b[39m\u001b[39mFalse\u001b[39;00m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plt' is not defined"
     ]
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 1,figsize=(5, 4))\n",
    "\n",
    "bin_data = compute_calibration(inf_out['true_labels'], inf_out['labels'], inf_out['confidence'], num_bins=10)\n",
    "reliability_diagram_subplot(axs, 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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "act-lbl",
   "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.10.10"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
