{
 "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 07:51:50 PM : DEBUG : data_manag : ] : torch.Size([40000, 3, 32, 32])\n",
      "50000\n",
      "50000\n",
      "[01/22/2024 07:51:51 PM : INFO  : data_manag : ] : Loaded dataset cifar10\n",
      "[01/22/2024 07:51:51 PM : INFO  : data_manag : ] : Std train size: 40000 and Std. Val. Size:8000\n",
      "[01/22/2024 07:51:51 PM : INFO  : 996596987 : ] : Loaded dataset cifar10\n",
      "[01/22/2024 07:51:51 PM : INFO  : 996596987 : ] :  std_train_size : 40000 and  std_val_size: 8000\n",
      "[01/22/2024 07:51:51 PM : DEBUG : passive_le : ] : Querying 4000 seed training points\n",
      "[01/22/2024 07:51:51 PM : DEBUG : passive_le : ] : Queried 4000 seed points for training\n",
      "[01/22/2024 07:51:51 PM : DEBUG : passive_le : ] : Validation Data Size :1000\n",
      "[01/22/2024 07:51:51 PM : DEBUG : passive_le : ] : Querying rest of the training points 0 in single batch\n",
      "[01/22/2024 07:51:51 PM : INFO  : passive_le : ] : Labeled data size for training: 4000\n",
      "[01/22/2024 07:51:51 PM : INFO  : passive_le : ] : Labeled data size for validation: 1000\n",
      "[01/22/2024 07:51:51 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 07:51:51 PM : INFO  : model_fact : ] : {'name': 'cifar_med_net', 'num_classes': 10, 'lib': 'pytorch'}\n",
      "[01/22/2024 07:51:53 PM : INFO  : passive_le : ] : Test error of the model : 46.88\n",
      "[01/22/2024 07:51:53 PM : INFO  : 996596987 : ] : ========================= Training Post-hoc Calibrator   =========================\n",
      "[01/22/2024 07:51:53 PM : INFO  : 996596987 : ] : Calib Conf : {'name': 'temp_scaling', 'calib_val_frac': 0.6, 'type': 'post_hoc', 'training_conf': {'optimizer': 'adam', 'learning_rate': 0.01, 'batch_size': 64, 'shuffle': True, 'max_epochs': 100, 'log_train_ece': True, 'log_train_ece_freq': 1, 'weight_decay': 0.1}, 'device': 'cuda:0'}\n",
      "[01/22/2024 07:51:53 PM : INFO  : calibrator : ] : Creating instance of calibrator : temp_scaling\n",
      "[01/22/2024 07:51:53 PM : INFO  : model_fact : ] : {'name': 'temp_scaling'}\n",
      "[01/22/2024 07:51:53 PM : INFO  : data_manag : ] : Selecting 0.6 fraction of calibration val points out of total :1000\n",
      "[01/22/2024 07:51:53 PM : INFO  : data_manag : ] :  Cur calib ds size : 600\n",
      "600 600\n",
      "[0 1 2 3 4 5 6 7 8 9]\n",
      "[63 53 63 67 56 54 50 63 69 62]\n",
      "[01/22/2024 07:51:53 PM : INFO  : 996596987 : ] : Number of validation points for training calibrator : 600\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Training conf : {'optimizer': 'adam', 'learning_rate': 0.01, 'batch_size': 64, 'shuffle': True, 'max_epochs': 100, 'log_train_ece': True, 'log_train_ece_freq': 1, 'weight_decay': 0.1, 'loss_function': 'std_cross_entropy', 'momentum': 0.9, 'use_lr_schedule': True, 'nesterov': False, 'loss_tol': 1e-06, 'device': 'cpu', 'stopping_criterion': 'max_epochs', 'log_val_err': False, 'log_val_ece': False, 'train_err_tol': 0.001, 'log_batch_loss_freq': 20, 'log_val_err_freq': 5, 'log_val_ece_freq': 5, 'verbose_logging': False, 'normalize_weights': False, 'mixup_alpha': 0, 'num_train_pts': 600}\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Using loss function : <class 'src.classifiers.torch.losses.common_losses.StdCrossEntropyLoss'>\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Using stopping criterion max_epochs\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Train Epoch: 0 [0/600 (0%)]\tLoss: 2.672737 \t result: {'loss': 13.983175277709961}\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch: 0 Training Error : 0.4517 , Training Loss : 0.0563\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch:0 Expected Calibration Error on Train Set : 0.3402887511253357\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Train Epoch: 1 [0/600 (0%)]\tLoss: 3.304835 \t result: {'loss': 14.984169960021973}\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch: 1 Training Error : 0.4517 , Training Loss : 0.0503\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch:1 Expected Calibration Error on Train Set : 0.3327638922135035\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Train Epoch: 2 [0/600 (0%)]\tLoss: 2.470282 \t result: {'loss': 12.271007537841797}\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch: 2 Training Error : 0.4517 , Training Loss : 0.0468\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch:2 Expected Calibration Error on Train Set : 0.3226881695787112\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Train Epoch: 3 [0/600 (0%)]\tLoss: 2.492013 \t result: {'loss': 11.994524002075195}\n",
      "[01/22/2024 07:51:53 PM : DEBUG : model_trai : ] : Epoch: 3 Training Error : 0.4517 , Training Loss : 0.0438\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch:3 Expected Calibration Error on Train Set : 0.31086446151137354\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Train Epoch: 4 [0/600 (0%)]\tLoss: 3.006513 \t result: {'loss': 12.371197700500488}\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch: 4 Training Error : 0.4517 , Training Loss : 0.0408\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch:4 Expected Calibration Error on Train Set : 0.3047203287978967\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Train Epoch: 5 [0/600 (0%)]\tLoss: 2.881807 \t result: {'loss': 12.857338905334473}\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch: 5 Training Error : 0.4517 , Training Loss : 0.0410\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch:5 Expected Calibration Error on Train Set : 0.29802952632308005\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Train Epoch: 6 [0/600 (0%)]\tLoss: 2.458646 \t result: {'loss': 9.00837230682373}\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch: 6 Training Error : 0.4517 , Training Loss : 0.0391\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch:6 Expected Calibration Error on Train Set : 0.29174837604165077\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Train Epoch: 7 [0/600 (0%)]\tLoss: 2.327610 \t result: {'loss': 10.707261085510254}\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch: 7 Training Error : 0.4517 , Training Loss : 0.0368\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch:7 Expected Calibration Error on Train Set : 0.2881210560103257\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Train Epoch: 8 [0/600 (0%)]\tLoss: 1.574307 \t result: {'loss': 9.377180099487305}\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch: 8 Training Error : 0.4517 , Training Loss : 0.0357\n",
      "[01/22/2024 07:51:54 PM : DEBUG : model_trai : ] : Epoch:8 Expected Calibration Error on Train Set : 0.28277052044868467\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Train Epoch: 9 [0/600 (0%)]\tLoss: 2.937977 \t result: {'loss': 7.829930782318115}\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch: 9 Training Error : 0.4517 , Training Loss : 0.0350\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch:9 Expected Calibration Error on Train Set : 0.27769333521525064\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Train Epoch: 10 [0/600 (0%)]\tLoss: 1.381569 \t result: {'loss': 8.465267181396484}\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch: 10 Training Error : 0.4517 , Training Loss : 0.0352\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch:10 Expected Calibration Error on Train Set : 0.27195321013530094\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Train Epoch: 11 [0/600 (0%)]\tLoss: 2.107968 \t result: {'loss': 8.319786071777344}\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch: 11 Training Error : 0.4517 , Training Loss : 0.0340\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch:11 Expected Calibration Error on Train Set : 0.2674152827759584\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Train Epoch: 12 [0/600 (0%)]\tLoss: 1.985268 \t result: {'loss': 8.258728981018066}\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch: 12 Training Error : 0.4517 , Training Loss : 0.0329\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch:12 Expected Calibration Error on Train Set : 0.26552014340957003\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Train Epoch: 13 [0/600 (0%)]\tLoss: 1.819992 \t result: {'loss': 10.132250785827637}\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch: 13 Training Error : 0.4517 , Training Loss : 0.0326\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Epoch:13 Expected Calibration Error on Train Set : 0.2616396835446358\n",
      "[01/22/2024 07:51:55 PM : DEBUG : model_trai : ] : Train Epoch: 14 [0/600 (0%)]\tLoss: 1.584954 \t result: {'loss': 8.273634910583496}\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch: 14 Training Error : 0.4517 , Training Loss : 0.0317\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch:14 Expected Calibration Error on Train Set : 0.2578862850864728\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Train Epoch: 15 [0/600 (0%)]\tLoss: 1.924644 \t result: {'loss': 7.725030899047852}\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch: 15 Training Error : 0.4517 , Training Loss : 0.0318\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch:15 Expected Calibration Error on Train Set : 0.254391408264637\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Train Epoch: 16 [0/600 (0%)]\tLoss: 1.739155 \t result: {'loss': 7.8048481941223145}\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch: 16 Training Error : 0.4517 , Training Loss : 0.0315\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch:16 Expected Calibration Error on Train Set : 0.24998839298884074\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Train Epoch: 17 [0/600 (0%)]\tLoss: 1.936334 \t result: {'loss': 7.468456268310547}\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch: 17 Training Error : 0.4517 , Training Loss : 0.0319\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch:17 Expected Calibration Error on Train Set : 0.2458342112104098\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Train Epoch: 18 [0/600 (0%)]\tLoss: 1.713959 \t result: {'loss': 7.622708797454834}\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch: 18 Training Error : 0.4517 , Training Loss : 0.0308\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch:18 Expected Calibration Error on Train Set : 0.24262538557251295\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Train Epoch: 19 [0/600 (0%)]\tLoss: 1.981476 \t result: {'loss': 7.145499229431152}\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch: 19 Training Error : 0.4517 , Training Loss : 0.0302\n",
      "[01/22/2024 07:51:56 PM : DEBUG : model_trai : ] : Epoch:19 Expected Calibration Error on Train Set : 0.23968415856361389\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Train Epoch: 20 [0/600 (0%)]\tLoss: 1.668400 \t result: {'loss': 7.271134853363037}\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch: 20 Training Error : 0.4517 , Training Loss : 0.0297\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch:20 Expected Calibration Error on Train Set : 0.2369423418243726\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Train Epoch: 21 [0/600 (0%)]\tLoss: 2.295749 \t result: {'loss': 6.447736740112305}\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch: 21 Training Error : 0.4517 , Training Loss : 0.0296\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch:21 Expected Calibration Error on Train Set : 0.23428555046518643\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Train Epoch: 22 [0/600 (0%)]\tLoss: 2.352509 \t result: {'loss': 6.285821437835693}\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch: 22 Training Error : 0.4517 , Training Loss : 0.0293\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch:22 Expected Calibration Error on Train Set : 0.23084382995963096\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Train Epoch: 23 [0/600 (0%)]\tLoss: 2.176254 \t result: {'loss': 7.249316692352295}\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch: 23 Training Error : 0.4517 , Training Loss : 0.0295\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch:23 Expected Calibration Error on Train Set : 0.2285817449291547\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Train Epoch: 24 [0/600 (0%)]\tLoss: 1.874082 \t result: {'loss': 7.804121971130371}\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch: 24 Training Error : 0.4517 , Training Loss : 0.0293\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch:24 Expected Calibration Error on Train Set : 0.2264138379196326\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Train Epoch: 25 [0/600 (0%)]\tLoss: 1.838651 \t result: {'loss': 6.909505844116211}\n",
      "[01/22/2024 07:51:57 PM : DEBUG : model_trai : ] : Epoch: 25 Training Error : 0.4517 , Training Loss : 0.0286\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch:25 Expected Calibration Error on Train Set : 0.22323816602428753\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Train Epoch: 26 [0/600 (0%)]\tLoss: 1.816748 \t result: {'loss': 7.309403896331787}\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch: 26 Training Error : 0.4517 , Training Loss : 0.0284\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch:26 Expected Calibration Error on Train Set : 0.22129855965574582\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Train Epoch: 27 [0/600 (0%)]\tLoss: 1.731806 \t result: {'loss': 6.612514972686768}\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch: 27 Training Error : 0.4517 , Training Loss : 0.0290\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch:27 Expected Calibration Error on Train Set : 0.21846677646040916\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Train Epoch: 28 [0/600 (0%)]\tLoss: 1.708906 \t result: {'loss': 6.526913642883301}\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch: 28 Training Error : 0.4517 , Training Loss : 0.0283\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch:28 Expected Calibration Error on Train Set : 0.21664797395467758\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Train Epoch: 29 [0/600 (0%)]\tLoss: 2.018803 \t result: {'loss': 6.437442779541016}\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch: 29 Training Error : 0.4517 , Training Loss : 0.0288\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch:29 Expected Calibration Error on Train Set : 0.2149313452343146\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Train Epoch: 30 [0/600 (0%)]\tLoss: 1.375092 \t result: {'loss': 6.611231327056885}\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch: 30 Training Error : 0.4517 , Training Loss : 0.0284\n",
      "[01/22/2024 07:51:58 PM : DEBUG : model_trai : ] : Epoch:30 Expected Calibration Error on Train Set : 0.21328257739543915\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Train Epoch: 31 [0/600 (0%)]\tLoss: 1.582922 \t result: {'loss': 5.809292316436768}\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch: 31 Training Error : 0.4517 , Training Loss : 0.0280\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch:31 Expected Calibration Error on Train Set : 0.2115637225906054\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Train Epoch: 32 [0/600 (0%)]\tLoss: 2.200346 \t result: {'loss': 7.116784572601318}\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch: 32 Training Error : 0.4517 , Training Loss : 0.0284\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch:32 Expected Calibration Error on Train Set : 0.21003425767024358\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Train Epoch: 33 [0/600 (0%)]\tLoss: 1.917467 \t result: {'loss': 5.164168357849121}\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch: 33 Training Error : 0.4517 , Training Loss : 0.0275\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch:33 Expected Calibration Error on Train Set : 0.20859810461600625\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [0/600 (0%)]\tLoss: 1.687622 \t result: {'loss': 6.053312301635742}\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch: 34 Training Error : 0.4517 , Training Loss : 0.0274\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch:34 Expected Calibration Error on Train Set : 0.20734300767381986\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Train Epoch: 35 [0/600 (0%)]\tLoss: 1.645374 \t result: {'loss': 6.27869176864624}\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch: 35 Training Error : 0.4517 , Training Loss : 0.0271\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch:35 Expected Calibration Error on Train Set : 0.20613901784022648\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Train Epoch: 36 [0/600 (0%)]\tLoss: 2.072832 \t result: {'loss': 6.816074371337891}\n",
      "[01/22/2024 07:51:59 PM : DEBUG : model_trai : ] : Epoch: 36 Training Error : 0.4517 , Training Loss : 0.0277\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch:36 Expected Calibration Error on Train Set : 0.20502494181195896\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Train Epoch: 37 [0/600 (0%)]\tLoss: 1.892771 \t result: {'loss': 6.127776622772217}\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch: 37 Training Error : 0.4517 , Training Loss : 0.0267\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch:37 Expected Calibration Error on Train Set : 0.20285403500000634\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Train Epoch: 38 [0/600 (0%)]\tLoss: 2.096245 \t result: {'loss': 6.781317234039307}\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch: 38 Training Error : 0.4517 , Training Loss : 0.0279\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch:38 Expected Calibration Error on Train Set : 0.20192215964198112\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Train Epoch: 39 [0/600 (0%)]\tLoss: 1.378895 \t result: {'loss': 6.345462799072266}\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch: 39 Training Error : 0.4517 , Training Loss : 0.0277\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch:39 Expected Calibration Error on Train Set : 0.2009003208577633\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Train Epoch: 40 [0/600 (0%)]\tLoss: 1.886069 \t result: {'loss': 6.68440580368042}\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch: 40 Training Error : 0.4517 , Training Loss : 0.0282\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch:40 Expected Calibration Error on Train Set : 0.199849780301253\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Train Epoch: 41 [0/600 (0%)]\tLoss: 1.401470 \t result: {'loss': 6.374943733215332}\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch: 41 Training Error : 0.4517 , Training Loss : 0.0272\n",
      "[01/22/2024 07:52:00 PM : DEBUG : model_trai : ] : Epoch:41 Expected Calibration Error on Train Set : 0.19891368066271145\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Train Epoch: 42 [0/600 (0%)]\tLoss: 1.940160 \t result: {'loss': 6.2444257736206055}\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch: 42 Training Error : 0.4517 , Training Loss : 0.0272\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch:42 Expected Calibration Error on Train Set : 0.19797848880290986\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Train Epoch: 43 [0/600 (0%)]\tLoss: 1.748379 \t result: {'loss': 5.7642083168029785}\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch: 43 Training Error : 0.4517 , Training Loss : 0.0276\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch:43 Expected Calibration Error on Train Set : 0.19710899690786998\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Train Epoch: 44 [0/600 (0%)]\tLoss: 1.766462 \t result: {'loss': 5.424086093902588}\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch: 44 Training Error : 0.4517 , Training Loss : 0.0269\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch:44 Expected Calibration Error on Train Set : 0.19628918305039406\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Train Epoch: 45 [0/600 (0%)]\tLoss: 1.371631 \t result: {'loss': 6.665934085845947}\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch: 45 Training Error : 0.4517 , Training Loss : 0.0269\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch:45 Expected Calibration Error on Train Set : 0.19454715887705484\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Train Epoch: 46 [0/600 (0%)]\tLoss: 1.892486 \t result: {'loss': 6.252538681030273}\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch: 46 Training Error : 0.4517 , Training Loss : 0.0270\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch:46 Expected Calibration Error on Train Set : 0.1936856625477473\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Train Epoch: 47 [0/600 (0%)]\tLoss: 2.022325 \t result: {'loss': 5.900910377502441}\n",
      "[01/22/2024 07:52:01 PM : DEBUG : model_trai : ] : Epoch: 47 Training Error : 0.4517 , Training Loss : 0.0281\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch:47 Expected Calibration Error on Train Set : 0.19307092408339183\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Train Epoch: 48 [0/600 (0%)]\tLoss: 1.793479 \t result: {'loss': 6.691869258880615}\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch: 48 Training Error : 0.4517 , Training Loss : 0.0275\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch:48 Expected Calibration Error on Train Set : 0.19234123587608337\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Train Epoch: 49 [0/600 (0%)]\tLoss: 1.478790 \t result: {'loss': 7.570878982543945}\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch: 49 Training Error : 0.4517 , Training Loss : 0.0281\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch:49 Expected Calibration Error on Train Set : 0.19162981569767\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Train Epoch: 50 [0/600 (0%)]\tLoss: 1.414031 \t result: {'loss': 6.443131446838379}\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch: 50 Training Error : 0.4517 , Training Loss : 0.0273\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch:50 Expected Calibration Error on Train Set : 0.19090784539779027\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Train Epoch: 51 [0/600 (0%)]\tLoss: 1.791380 \t result: {'loss': 5.888274669647217}\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch: 51 Training Error : 0.4517 , Training Loss : 0.0271\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch:51 Expected Calibration Error on Train Set : 0.19023423676689466\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Train Epoch: 52 [0/600 (0%)]\tLoss: 1.375214 \t result: {'loss': 5.669264793395996}\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch: 52 Training Error : 0.4517 , Training Loss : 0.0264\n",
      "[01/22/2024 07:52:02 PM : DEBUG : model_trai : ] : Epoch:52 Expected Calibration Error on Train Set : 0.18972007155418397\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Train Epoch: 53 [0/600 (0%)]\tLoss: 1.489974 \t result: {'loss': 6.614628791809082}\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch: 53 Training Error : 0.4517 , Training Loss : 0.0268\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch:53 Expected Calibration Error on Train Set : 0.18917846222718554\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Train Epoch: 54 [0/600 (0%)]\tLoss: 1.444924 \t result: {'loss': 6.5469770431518555}\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch: 54 Training Error : 0.4517 , Training Loss : 0.0272\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch:54 Expected Calibration Error on Train Set : 0.18873160193363825\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Train Epoch: 55 [0/600 (0%)]\tLoss: 1.916855 \t result: {'loss': 5.679065227508545}\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch: 55 Training Error : 0.4517 , Training Loss : 0.0268\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch:55 Expected Calibration Error on Train Set : 0.18826124588648477\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Train Epoch: 56 [0/600 (0%)]\tLoss: 1.453933 \t result: {'loss': 5.755976676940918}\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch: 56 Training Error : 0.4517 , Training Loss : 0.0267\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch:56 Expected Calibration Error on Train Set : 0.18784425809979438\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Train Epoch: 57 [0/600 (0%)]\tLoss: 1.499169 \t result: {'loss': 5.79926061630249}\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch: 57 Training Error : 0.4517 , Training Loss : 0.0264\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch:57 Expected Calibration Error on Train Set : 0.1874158799648285\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Train Epoch: 58 [0/600 (0%)]\tLoss: 1.562868 \t result: {'loss': 6.221145153045654}\n",
      "[01/22/2024 07:52:03 PM : DEBUG : model_trai : ] : Epoch: 58 Training Error : 0.4517 , Training Loss : 0.0263\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch:58 Expected Calibration Error on Train Set : 0.18708693812290828\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Train Epoch: 59 [0/600 (0%)]\tLoss: 1.837834 \t result: {'loss': 6.651160717010498}\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch: 59 Training Error : 0.4517 , Training Loss : 0.0265\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch:59 Expected Calibration Error on Train Set : 0.18674757341543832\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Train Epoch: 60 [0/600 (0%)]\tLoss: 1.562613 \t result: {'loss': 6.350545406341553}\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch: 60 Training Error : 0.4517 , Training Loss : 0.0268\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch:60 Expected Calibration Error on Train Set : 0.18646844645341237\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Train Epoch: 61 [0/600 (0%)]\tLoss: 1.296706 \t result: {'loss': 6.398699760437012}\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch: 61 Training Error : 0.4517 , Training Loss : 0.0260\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch:61 Expected Calibration Error on Train Set : 0.18617020284136138\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Train Epoch: 62 [0/600 (0%)]\tLoss: 1.992600 \t result: {'loss': 5.568210601806641}\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch: 62 Training Error : 0.4517 , Training Loss : 0.0266\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch:62 Expected Calibration Error on Train Set : 0.18589679981271426\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Train Epoch: 63 [0/600 (0%)]\tLoss: 1.939655 \t result: {'loss': 5.65287446975708}\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch: 63 Training Error : 0.4517 , Training Loss : 0.0266\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Epoch:63 Expected Calibration Error on Train Set : 0.18562748273213706\n",
      "[01/22/2024 07:52:04 PM : DEBUG : model_trai : ] : Train Epoch: 64 [0/600 (0%)]\tLoss: 1.895038 \t result: {'loss': 5.659083366394043}\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch: 64 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch:64 Expected Calibration Error on Train Set : 0.18535751755038898\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Train Epoch: 65 [0/600 (0%)]\tLoss: 1.783411 \t result: {'loss': 7.278303146362305}\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch: 65 Training Error : 0.4517 , Training Loss : 0.0261\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch:65 Expected Calibration Error on Train Set : 0.18513658846418063\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Train Epoch: 66 [0/600 (0%)]\tLoss: 1.741411 \t result: {'loss': 5.925719738006592}\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch: 66 Training Error : 0.4517 , Training Loss : 0.0257\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch:66 Expected Calibration Error on Train Set : 0.18493510842323302\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Train Epoch: 67 [0/600 (0%)]\tLoss: 1.890227 \t result: {'loss': 6.02010440826416}\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch: 67 Training Error : 0.4517 , Training Loss : 0.0260\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch:67 Expected Calibration Error on Train Set : 0.18476930613319079\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Train Epoch: 68 [0/600 (0%)]\tLoss: 1.151193 \t result: {'loss': 5.840980529785156}\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch: 68 Training Error : 0.4517 , Training Loss : 0.0261\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch:68 Expected Calibration Error on Train Set : 0.18463337336977323\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Train Epoch: 69 [0/600 (0%)]\tLoss: 1.306350 \t result: {'loss': 5.305333137512207}\n",
      "[01/22/2024 07:52:05 PM : DEBUG : model_trai : ] : Epoch: 69 Training Error : 0.4517 , Training Loss : 0.0270\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch:69 Expected Calibration Error on Train Set : 0.18447885046402612\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Train Epoch: 70 [0/600 (0%)]\tLoss: 1.633487 \t result: {'loss': 6.980179309844971}\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch: 70 Training Error : 0.4517 , Training Loss : 0.0270\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch:70 Expected Calibration Error on Train Set : 0.18430036519964535\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Train Epoch: 71 [0/600 (0%)]\tLoss: 1.386422 \t result: {'loss': 6.260158538818359}\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch: 71 Training Error : 0.4517 , Training Loss : 0.0268\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch:71 Expected Calibration Error on Train Set : 0.1841171293457349\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Train Epoch: 72 [0/600 (0%)]\tLoss: 1.677868 \t result: {'loss': 6.6173930168151855}\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch: 72 Training Error : 0.4517 , Training Loss : 0.0272\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch:72 Expected Calibration Error on Train Set : 0.183948941330115\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Train Epoch: 73 [0/600 (0%)]\tLoss: 1.248175 \t result: {'loss': 6.309699058532715}\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch: 73 Training Error : 0.4517 , Training Loss : 0.0270\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch:73 Expected Calibration Error on Train Set : 0.18377880036830901\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Train Epoch: 74 [0/600 (0%)]\tLoss: 1.509003 \t result: {'loss': 5.344054698944092}\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch: 74 Training Error : 0.4517 , Training Loss : 0.0259\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Epoch:74 Expected Calibration Error on Train Set : 0.18358968476454418\n",
      "[01/22/2024 07:52:06 PM : DEBUG : model_trai : ] : Train Epoch: 75 [0/600 (0%)]\tLoss: 1.363871 \t result: {'loss': 7.10612678527832}\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch: 75 Training Error : 0.4517 , Training Loss : 0.0259\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch:75 Expected Calibration Error on Train Set : 0.18348487406969072\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Train Epoch: 76 [0/600 (0%)]\tLoss: 1.558494 \t result: {'loss': 5.397012233734131}\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch: 76 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch:76 Expected Calibration Error on Train Set : 0.18340724289417268\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Train Epoch: 77 [0/600 (0%)]\tLoss: 1.872039 \t result: {'loss': 6.814334392547607}\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch: 77 Training Error : 0.4517 , Training Loss : 0.0276\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch:77 Expected Calibration Error on Train Set : 0.18331631407141685\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Train Epoch: 78 [0/600 (0%)]\tLoss: 1.498889 \t result: {'loss': 5.7760515213012695}\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch: 78 Training Error : 0.4517 , Training Loss : 0.0269\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch:78 Expected Calibration Error on Train Set : 0.18318977812925974\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Train Epoch: 79 [0/600 (0%)]\tLoss: 1.891801 \t result: {'loss': 5.177619457244873}\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch: 79 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch:79 Expected Calibration Error on Train Set : 0.18306825717290243\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Train Epoch: 80 [0/600 (0%)]\tLoss: 1.333142 \t result: {'loss': 6.79170036315918}\n",
      "[01/22/2024 07:52:07 PM : DEBUG : model_trai : ] : Epoch: 80 Training Error : 0.4517 , Training Loss : 0.0265\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch:80 Expected Calibration Error on Train Set : 0.18300699934363365\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Train Epoch: 81 [0/600 (0%)]\tLoss: 1.560045 \t result: {'loss': 5.49660062789917}\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch: 81 Training Error : 0.4517 , Training Loss : 0.0258\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch:81 Expected Calibration Error on Train Set : 0.18292833879590034\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Train Epoch: 82 [0/600 (0%)]\tLoss: 1.440844 \t result: {'loss': 5.083775997161865}\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch: 82 Training Error : 0.4517 , Training Loss : 0.0264\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch:82 Expected Calibration Error on Train Set : 0.1828918386499087\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Train Epoch: 83 [0/600 (0%)]\tLoss: 0.983254 \t result: {'loss': 6.4868340492248535}\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch: 83 Training Error : 0.4517 , Training Loss : 0.0264\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch:83 Expected Calibration Error on Train Set : 0.18283182859420777\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Train Epoch: 84 [0/600 (0%)]\tLoss: 1.484026 \t result: {'loss': 5.490198612213135}\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch: 84 Training Error : 0.4517 , Training Loss : 0.0267\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch:84 Expected Calibration Error on Train Set : 0.18277752657731375\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Train Epoch: 85 [0/600 (0%)]\tLoss: 1.481135 \t result: {'loss': 5.657931804656982}\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch: 85 Training Error : 0.4517 , Training Loss : 0.0259\n",
      "[01/22/2024 07:52:08 PM : DEBUG : model_trai : ] : Epoch:85 Expected Calibration Error on Train Set : 0.1827283377945423\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Train Epoch: 86 [0/600 (0%)]\tLoss: 1.575259 \t result: {'loss': 6.018052577972412}\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch: 86 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch:86 Expected Calibration Error on Train Set : 0.1826919373869896\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Train Epoch: 87 [0/600 (0%)]\tLoss: 1.354723 \t result: {'loss': 6.576494216918945}\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch: 87 Training Error : 0.4517 , Training Loss : 0.0264\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch:87 Expected Calibration Error on Train Set : 0.18266271462043127\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Train Epoch: 88 [0/600 (0%)]\tLoss: 1.468713 \t result: {'loss': 6.2822723388671875}\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch: 88 Training Error : 0.4517 , Training Loss : 0.0263\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch:88 Expected Calibration Error on Train Set : 0.18263157963752746\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Train Epoch: 89 [0/600 (0%)]\tLoss: 1.578919 \t result: {'loss': 6.411378860473633}\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch: 89 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch:89 Expected Calibration Error on Train Set : 0.18260552634795507\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Train Epoch: 90 [0/600 (0%)]\tLoss: 1.292809 \t result: {'loss': 6.27862024307251}\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch: 90 Training Error : 0.4517 , Training Loss : 0.0258\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch:90 Expected Calibration Error on Train Set : 0.1825888454914093\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Train Epoch: 91 [0/600 (0%)]\tLoss: 1.323518 \t result: {'loss': 5.626782417297363}\n",
      "[01/22/2024 07:52:09 PM : DEBUG : model_trai : ] : Epoch: 91 Training Error : 0.4517 , Training Loss : 0.0268\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch:91 Expected Calibration Error on Train Set : 0.18257914781570433\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Train Epoch: 92 [0/600 (0%)]\tLoss: 1.379505 \t result: {'loss': 6.0871171951293945}\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch: 92 Training Error : 0.4517 , Training Loss : 0.0263\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch:92 Expected Calibration Error on Train Set : 0.18256478995084763\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Train Epoch: 93 [0/600 (0%)]\tLoss: 1.956794 \t result: {'loss': 6.325804710388184}\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch: 93 Training Error : 0.4517 , Training Loss : 0.0261\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch:93 Expected Calibration Error on Train Set : 0.18255279416839282\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Train Epoch: 94 [0/600 (0%)]\tLoss: 1.480192 \t result: {'loss': 6.11221170425415}\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch: 94 Training Error : 0.4517 , Training Loss : 0.0266\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch:94 Expected Calibration Error on Train Set : 0.18254530757665635\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Train Epoch: 95 [0/600 (0%)]\tLoss: 1.143841 \t result: {'loss': 5.715414047241211}\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch: 95 Training Error : 0.4517 , Training Loss : 0.0268\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch:95 Expected Calibration Error on Train Set : 0.18254091347257295\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Train Epoch: 96 [0/600 (0%)]\tLoss: 1.786737 \t result: {'loss': 6.01466178894043}\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch: 96 Training Error : 0.4517 , Training Loss : 0.0266\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Epoch:96 Expected Calibration Error on Train Set : 0.18253624657789866\n",
      "[01/22/2024 07:52:10 PM : DEBUG : model_trai : ] : Train Epoch: 97 [0/600 (0%)]\tLoss: 1.840221 \t result: {'loss': 5.685415267944336}\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Epoch: 97 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Epoch:97 Expected Calibration Error on Train Set : 0.18253392949700356\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Train Epoch: 98 [0/600 (0%)]\tLoss: 1.272960 \t result: {'loss': 6.042785167694092}\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Epoch: 98 Training Error : 0.4517 , Training Loss : 0.0263\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Epoch:98 Expected Calibration Error on Train Set : 0.18253305281201998\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Train Epoch: 99 [0/600 (0%)]\tLoss: 1.722213 \t result: {'loss': 6.174671649932861}\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Epoch: 99 Training Error : 0.4517 , Training Loss : 0.0262\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Epoch:99 Expected Calibration Error on Train Set : 0.18253284002343814\n",
      "[01/22/2024 07:52:11 PM : DEBUG : model_trai : ] : Average training loss : 0.02884778130959364\n",
      "[01/22/2024 07:52:11 PM : INFO  : auto_label : ] : xxxxxxxxxxxxxxxxxxxxx  Auto-labeling actual remaining unlabeled data  xxxxxxxxxxxxxxxxxxxxx\n",
      "[01/22/2024 07:52:11 PM : INFO  : auto_label : ] : ========================= Begin Auto-Labeling selective ==========================\n",
      "[01/22/2024 07:52:11 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 07:52:11 PM : INFO  : auto_label : ] : Number of unlabeled points : 36000\n",
      "[01/22/2024 07:52:11 PM : INFO  : data_manag : ] :  Cur calib ds size : 600\n",
      "[01/22/2024 07:52:11 PM : INFO  : auto_label : ] : Using number of validation points : 400\n",
      "[01/22/2024 07:52:11 PM : INFO  : auto_label : ] : Using Auto-Labeling Error Threshold = 0.05\n",
      "[01/22/2024 07:52:12 PM : DEBUG : auto_label : ] : Expected Calibration Error on Validation set : 0.169459697753191\n",
      "[01/22/2024 07:52:12 PM : DEBUG : auto_label : ] : Expected Calibration Error on Validation set with NO Calibration : 0.3333337400853634\n",
      "[01/22/2024 07:52:12 PM : INFO  : auto_label : ] : Determining Thresholds : Class Wise : independent\n",
      "[01/22/2024 07:52:12 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 0   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 1   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 2   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 3   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 4   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 5   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 6   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.9712975025177002 for class 7   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.9624220132827759 for class 8   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 9   \n",
      "[01/22/2024 07:52:12 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.07\n",
      "[01/22/2024 07:52:12 PM : INFO  : auto_label : ] : auto-labeling thresholds from val set: [inf, inf, inf, inf, inf, inf, inf, 0.9712975, 0.962422, inf]\n",
      "[01/22/2024 07:52:13 PM : INFO  : auto_label : ] : Num auto labeled points : 1963 \n",
      "[01/22/2024 07:52:13 PM : INFO  : auto_label : ] : Num validation pts to remove : 29\n",
      "[01/22/2024 07:52:13 PM : INFO  : auto_label : ] : ============================== Done Auto-Labeling ==============================\n",
      "[01/22/2024 07:52:13 PM : INFO  : 996596987 : ] :  Selective Auto-labeling counts: {'auto_labeled_acc': 0.8823229750382068, 'coverage_1': 0.049075, 'coverage_2': 0}\n"
     ]
    }
   ],
   "source": [
    "calib_conf = conf['calib_conf']\n",
    "conf['calib_conf']      = OmegaConf.load(f'{conf_dir}/post-hoc/scaling_conf.yaml')\n",
    "\n",
    "t_conf = conf['calib_conf']['training_conf']\n",
    "t_conf['optimizer']  = 'adam'\n",
    "t_conf['learning_rate'] = 0.5\n",
    "t_conf['batch_size'] = 128\n",
    "t_conf['weight_decay'] = 0.1\n",
    "t_conf['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": "iVBORw0KGgoAAAANSUhEUgAAAcoAAAFfCAYAAADON4wsAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABdb0lEQVR4nO3de3xT9f348VeS5tZL0kLvF+73u4DcvICKIjqVualf5wR0Op243xSdE294mcPLFNhU1DlFpw4vA91QUSyCylVuyv0ObaFX2ia9pm1yfn8cmjbQll7SnKR9Px+PPHZycpK8T5l993N7f3SKoigIIYQQokF6rQMQQgghgpkkSiGEEKIJkiiFEEKIJkiiFEIIIZogiVIIIYRogiRKIYQQogmSKIUQQogmhGkdQKB5PB5OnDhBVFQUOp1O63CEEEJoRFEUSkpKSE5ORq9vvN3Y6RLliRMnSEtL0zoMIYQQQSIzM5PU1NRGX+90iTIqKgpQfzA2m03jaIQQQmjF6XSSlpbmzQuN6XSJsra71WazSaIUQghx1mE4mcwjhBBCNEESpRBCCNEESZRCCCFEEzrdGGVzud1uqqurtQ5DNJPRaMRgMGgdhhCiA5JEeRpFUcjJyaG4uFjrUEQLRUdHk5iYKOtjhRB+JYnyNLVJMj4+nvDwcPmlGwIURaG8vJy8vDwAkpKSNI5ICNGRSKKsx+12e5Nk165dtQ5HtIDVagUgLy+P+Ph46YYVQviNTOapp3ZMMjw8XONIRGvU/rvJ2LIQwp8kUTZAultDk/y7CSHagyRKIYQQogkyRtkMV/39e/JLXAH/3rgoM//7/fkB/14hhBB1JFE2Q36JixxnpdZhCCFEyPjuQD5zP91FlwgTk/rH8etx3YkON2kdVqtI12sL6ACbJazdH60dacvJyeH3v/89vXr1wmw2k5aWxlVXXUV6ero/fwx+sXjxYqKjo7UOQwjRDjwehYeX7eRwQRmbjxXx16/2c/9HP2odVqtJi7IFoixhPDh1YLt/zzNf7MFZWdOi9xw9epTzzjuP6Ohonn/+eYYOHUp1dTVffvkls2bNYu/evS2Oo6qqCpPpzL8Aq6urMRqNLf48IUTnsP7wSTIKy33Ord6Xj7OyGpsl9H53SIuyg7jrrrvQ6XRs2rSJX/ziF/Tr14/Bgwcze/ZsNmzYAEBGRgbXXHMNkZGR2Gw2rr/+enJzc72f8fjjjzNixAjeeOMNevbsicViAdTZpIsWLeLqq68mIiKCp59+GoBPP/2UkSNHYrFY6NWrF0888QQ1NXUJvri4mDvuuIOEhAQsFgtDhgxh+fLlrF69mltuuQWHw4FOp0On0/H4448H7oclhGhX/96U4T2OMKvtsRqPwvcHCrQKqU2kRdkBFBYWsmLFCp5++mkiIiLOeD06OhqPx+NNkmvWrKGmpoZZs2Zxww03sHr1au+1Bw8e5D//+Q9Lly71WbT/+OOP88wzz7BgwQLCwsL47rvvmD59On/729+44IILOHToEL/97W8BmDt3Lh6Ph6lTp1JSUsK7775L79692b17NwaDgQkTJrBgwQIee+wx9u3bB0BkZGT7/pCEEAFxstTFl7tyAIgwGbj2nBT+teEYAKv25nHF0NCrnCWJsgM4ePAgiqIwYMCARq9JT09nx44dHDlyhLS0NADeeecdBg8ezA8//MC5554LqN2t77zzDnFxcT7v/9WvfsUtt9zifX7rrbfy4IMPMmPGDAB69erFU089xQMPPMDcuXP5+uuv2bRpE3v27KFfv37ea2rZ7XZ0Oh2JiYn++SEIIYLC/348QbVbAWBktxj6xEdiNOiodius3peHx6Og14fWmmfpeu0AFEU56zV79uwhLS3NmyQBBg0aRHR0NHv27PGe6969+xlJEmD06NE+z3/88UeefPJJIiMjvY/bb7+d7OxsysvL2b59O6mpqd4kKYToHH44VuQ9HpYWjdGgp098FAAFpVX8dNyhVWitJi3KDqBv377odLpWTdg5XUNdtw2dLy0t5YknnuDaa68941qLxeKtvSqE6Fx2ZKmJ0GjQkWhT5zkMSIhiT7YTgNX78hiRFq1VeK0iLcoOoEuXLkyZMoWXX36ZsrKyM14vLi5m4MCBZGZmkpmZ6T2/e/duiouLGTRoUIu/c+TIkezbt48+ffqc8dDr9QwbNoysrCz279/f4PtNJhNut7vF3yuECF5FZVXe2a5JdiuGU12sveLq/tCuTZihRFqULVBSWcMzX+w5+4V++J6WevnllznvvPMYM2YMTz75JMOGDaOmpoaVK1eyaNEidu/ezdChQ7nppptYsGABNTU13HXXXUycOPGMbtXmeOyxx/jZz35Gt27d+OUvf4ler+fHH39k586d/PnPf2bixIlceOGF/OIXv+DFF1+kT58+7N27F51Ox+WXX06PHj0oLS0lPT2d4cOHEx4eLsXohQhx9btVU2LqepViIkwY9DrcHoXD+Wf+MR/spEXZAgrgrKxp98fZRxzP1KtXL7Zu3cpFF13Efffdx5AhQ7j00ktJT09n0aJF6HQ6Pv30U2JiYrjwwguZPHkyvXr14oMPPmjVz2LKlCksX76cr776inPPPZdx48Yxf/58unfv7r3mP//5D+eeey433ngjgwYN4oEHHvC2IidMmMCdd97JDTfcQFxcHM8991yr4hBCBI8dWcXe49ToukSp1+noGqGuyT52shy3pzW/5bSjU5ozE6QDcTqd2O12HA4HNpvN57XKykqOHDnis4YQpNZrqGjs308IERi3v7OZlbvVtdn3Tu5HXJTZ+9q7G46x+1S367d/vIhuXbXvQWoqH9QnXa/NIMlKCCHO7qdTLUpzmJ6ukb5VveKizJCtHh8qKA2KRNlc0vUqhBCizXKdleQ61Z63lGgr+tP2h42tlzhDbZxSEqUQQog2232ibjZr/Yk8tWIj67phD+eXBiQmf5FEKYQQos0O1Ut+CVFnzhGIq5cojxRIi7LZFi1axLBhw7DZbNhsNsaPH88XX3zR6PWLFy/2FtGufcikDSGE0N7heskvtt4knlrh5jDCTWr96FDretV0Mk9qairPPPMMffv2RVEU3n77ba655hq2bdvG4MGDG3yPzWbzFtIGdWcLIYQQ2qrfnRob2fAGzbGRZjIKy8lxVlLmqvHuLBLsNI3yqquu8nn+9NNPs2jRIjZs2NBoopRC2kIIEXxqW4nhJgPhpoZTS22iBLX7dUiKPWDxtUXQjFG63W6WLFlCWVkZ48ePb/S60tJSunfvTlpaGtdccw27du1q8nNdLhdOp9PnIYQQwn9KXTXknVprXn8s8nRx9VqaoTROqXm7d8eOHYwfP57KykoiIyNZtmxZo7VH+/fvz5tvvsmwYcNwOBz89a9/ZcKECezatYvU1NQG3zNv3jyeeOKJtgX52kQozWvbZ7RGZDzcsSbw3yuEEC1wJL/p8cla9vC6RJnrrGzXmPxJ80TZv39/tm/fjsPh4OOPP2bGjBmsWbOmwWQ5fvx4n9bmhAkTGDhwIK+99hpPPfVUg58/Z84cZs+e7X3udDp9tppqltI8KDnRsvcE2MyZMykuLuaTTz7ROhS/mzRpEiNGjGDBggVahyKEaMDhgrrxyaZalDZrXcrJcUiibDaTyUSfPn0AGDVqFD/88AMLFy7ktddeO+t7jUYj55xzDgcPHmz0GrPZjNnc+D9cy+jA0niZI7+pdEKrKr5qp6qqCpPJdwDf7Xaj0+nQ64Omh18I0Q7qz2JtbCIPgN1i9B7nSIuy9TweDy5X8+qqut1uduzYwRVXXNHOUZ1iscHkNnbjNsfXc6Gy9ZubTpo0iWHDhmGxWHjjjTcwmUzceeedPP74495riouL+dOf/sQnn3yCw+GgT58+PPPMM/zsZz8D1ILmjz32GAcPHiQpKYnf//733Hfffd739+jRg9/85jccOHCATz75hGuvvZZJkyZxzz338M477/Dggw+yf/9+7/sffvhh/v3vf1NcXMyQIUN49tlnmTRpkvfz1q5dy8MPP8ymTZswm82MGTOGJUuWcO+997JmzRrWrFnDwoULAThy5Ag9evRo9c9HCOFfPktDmmhRRtVLlHnOwNfPbi1NE+WcOXOYOnUq3bp1o6SkhPfff5/Vq1fz5ZdfAjB9+nRSUlKYN28eAE8++STjxo2jT58+FBcX8/zzz3Ps2DFuu+02LW8jKL399tvMnj2bjRs3sn79embOnMl5553HpZdeisfjYerUqZSUlPDuu+/Su3dvdu/ejcGgrnHasmUL119/PY8//jg33HAD69at46677qJr167MnDnT+x1//etfeeyxx5g7dy4A3333HeXl5Tz77LO88cYbdO3alfj4eO6++252797NkiVLSE5OZtmyZVx++eXs2LGDvn37sn37di655BJuvfVWFi5cSFhYGN988w1ut5uFCxeyf/9+hgwZwpNPPglAXFxcwH+eQojG1S4N0eugSxMtSlOYHotRT2W1R1qUzZWXl8f06dPJzs7GbrczbNgwvvzySy699FIAMjIyfLrtioqKuP3228nJySEmJoZRo0axbt26Vm083NENGzbMm8D69u3LSy+9RHp6Opdeeilff/01mzZtYs+ePfTr1w9Qt+mq9eKLL3LJJZfw6KOPAtCvXz92797N888/75MoL774Yp9W5nfffUd1dTWvvPIKw4cPB9R/w7feeouMjAySk5MBuP/++1mxYgVvvfUWf/nLX3juuecYPXo0r7zyivez6i8PMplMhIeHy7IgIYKQoijeGawx4SbCzjLUYrMYqax2keOsRFGU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zTWneLkIjCVLligmk0l58803lV27dim33367Eh0dreTm5jZ4/dq1axWDwaA899xzyu7du5VHHnlEMRqNyo4dOwIcedu09L5/9atfKS+//LKybds2Zc+ePcrMmTMVu92uZGVlBTjy1mvpPdc6cuSIkpKSolxwwQXKNddcE5hg/ail9+1yuZTRo0crV1xxhfL9998rR44cUVavXq1s3749wJG3Xkvv+b333lPMZrPy3nvvKUeOHFG+/PJLJSkpSbn33nsDHHnrff7558rDDz+sLF26VAHO2PjidIcPH1bCw8OV2bNnK7t371b+/ve/KwaDQVmxYkVgAj4LSZRBZMyYMcqsWbO8z91ut5KcnKzMmzevweuvv/565corr/Q5N3bsWOWOO+5o1zj9raX3fbqamholKipKefvtt9srRL9rzT3X1NQoEyZMUN544w1lxowZIZkoW3rfixYtUnr16qVUVVUFKkS/a+k9z5o1S7n44ot9zs2ePVs577zz2jXO9tKcRPnAAw8ogwcP9jl3ww03KFOmTGnHyJpPul6DRFVVFVu2bGHy5Mnec3q9nsmTJ7N+/foG37N+/Xqf6wGmTJnS6PXBqDX3fbry8nKqq6vp0qV1e9IFWmvv+cknnyQ+Pp7f/OY3gQjT71pz3//9738ZP348s2bNIiEhgSFDhvCXv/wFt9sdqLDbpDX3PGHCBLZs2eLtnj18+DCff/55hy6qEuy/yzQvYSdUgdhyLBi15r5P96c//Ynk5OQz/kMLVq255++//55//vOfbN++PQARto/W3Pfhw4dZtWoVN910E59//jkHDx7krrvuorq6mrlz5wYi7DZpzT3/6le/oqCggPPPPx9FUaipqeHOO+/koYceCkTImmjsd5nT6aSiogKr1apRZCppUYqQ9swzz7BkyRKWLVuGxWLROpx2UVJSws0338w//vEPYmNjtQ4noDweD/Hx8bz++uuMGjWKG264gYcffphXX31V69DazerVq/nLX/7CK6+8wtatW1m6dCmfffYZTz31lNahdVrSogwSnXXLsdbcd62//vWvPPPMM3z99dcMGzasPcP0q5be86FDhzh69ChXXXWV95zH4wEgLCyMffv20bt37/YN2g9a82+dlJSE0WjEYDB4zw0cOJCcnByqqqowmUztGnNbteaeH330UW6++WZuu+02AIYOHUpZWRm//e1vefjhh9HrO177prHfZTabTfPWJEiLMmh01i3HWnPfAM899xxPPfUUK1asYPTo0YEI1W9aes8DBgxgx44dbN++3fu4+uqrueiii9i+fTtpaWmBDL/VWvNvfd5553Hw4EHvHwYA+/fvJykpKeiTJLTunsvLy89IhrV/KCgdtDR30P8u03o2kaizZMkSxWw2K4sXL1Z2796t/Pa3v1Wio6OVnJwcRVEU5eabb1YefPBB7/Vr165VwsLClL/+9a/Knj17lLlz54bs8pCW3PczzzyjmEwm5eOPP1ays7O9j5KSEq1uocVaes+nC9VZry2974yMDCUqKkq5++67lX379inLly9X4uPjlT//+c9a3UKLtfSe586dq0RFRSn//ve/lcOHDytfffWV0rt3b+X666/X6hZarKSkRNm2bZuybds2BVBefPFFZdu2bcqxY8cURVGUBx98ULn55pu919cuD/njH/+o7NmzR3n55ZdleYho3N///nelW7duislkUsaMGaNs2LDB+9rEiROVGTNm+Fz/4YcfKv369VNMJpMyePBg5bPPPgtwxP7Rkvvu3r27ApzxmDt3buADb4OW/lvXF6qJUlFaft/r1q1Txo4dq5jNZqVXr17K008/rdTU1AQ46rZpyT1XV1crjz/+uNK7d2/FYrEoaWlpyl133aUUFRUFPvBW+uabbxr8b7T2PmfMmKFMnDjxjPeMGDFCMZlMSq9evZS33nor4HE3RrbZEkIIIZogY5RCCCFEEyRRCiGEEE2QRCmEEEI0QRKlEEII0QRJlEIIIUQTJFEKIYQQTZBEKYQQQjRBEqUQQgjRBEmUQgghRBMkUQohhBBNkEQphBBCNOH/AxYHExn3QPt7AAAAAElFTkSuQmCC",
      "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": [
       "tensor([0.9842, 0.3853, 0.9810,  ..., 0.6012, 0.6837, 0.6233])"
      ]
     },
     "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_Scaling_inf_out_unlbld_2.pkl',\"wb\") as f :\n",
    "    pickle.dump(inf_out, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.18333249582722783\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "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=20)\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)\n",
    "print(bin_data['expected_calibration_error'])"
   ]
  },
  {
   "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
}
