{
 "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": [
    {
     "data": {
      "text/plain": [
       "{'device': 'cuda:0', 'random_seed': 1, 'data_conf': {'name': 'cifar10', 'dimension': 3072, 'random_state': 0, 'data_path': '../data/', 'val_fraction': 0.2, 'num_hyp_val_samples': 2000, 'num_classes': 10, 'flatten': False}, 'model_conf': {'name': 'cifar_med_net', 'num_classes': 10, 'lib': 'pytorch'}, 'training_conf': {'loss_function': 'std_cross_entropy', 'optimizer': 'sgd', 'learning_rate': 0.001, 'momentum': 0.9, 'weight_decay': 0.001, 'loss_tolerance': 1e-06, 'max_epochs': 50, 'normalize_weights': False, 'batch_size': 32, 'stopping_criterion': 'max_epochs', 'train_err_tol': -1, 'ckpt_load_path': 'None', 'ckpt_save_path': 'None', 'train_from_scratch': True, 'train_from_ckpt': False}, 'inference_conf': {'device': 'cuda:0', 'batch_size': 2048}, 'train_pts_query_conf': {'seed_train_size': 4000, 'max_num_train_pts': 4000, 'query_batch_size': 2000, 'query_strategy_name': 'margin_random_v2', 'margin_random_v2_constant': 2}, 'val_pts_query_conf': {'query_strategy_name': 'random', 'max_num_val_pts': 1000}, 'calib_conf': None, 'auto_lbl_conf': {'method_name': 'selective', 'score_type': 'confidence', 'class_wise': 'independent', 'auto_label_err_threshold': 0.05, 'C_1': 0.25, 'ucb': 'sigma'}, 'stopping_criterion': 'max_num_train_pts', 'store_model_weights_in_mem': False, 'max_query': 2000, 'margin': 'None', 'output_root': '../../outputs/test_runs/cifar10_med_net_calib/', 'eval': 'full', 'root_pfx': 'test_runs/cifar10_med_net_calib/', 'method': 'passive_learning', 'run_dir': '../../outputs/test_runs/cifar10_med_net_calib/None', 'log_file_path': '../../outputs/test_runs/cifar10_med_net_calib/None/passive_learning.log', 'out_file_path': '../../outputs/test_runs/cifar10_med_net_calib/None/passive_learning.pkl', 'conf_file_path': '../../outputs/test_runs/cifar10_med_net_calib/None/passive_learning.yaml'}"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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",
    "augment_conf(conf)\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:30:31 PM : DEBUG : data_manag : ] : torch.Size([40000, 3, 32, 32])\n",
      "50000\n",
      "50000\n",
      "[01/22/2024 06:30:31 PM : INFO  : data_manag : ] : Loaded dataset cifar10\n",
      "[01/22/2024 06:30:31 PM : INFO  : data_manag : ] : Std train size: 40000 and Std. Val. Size:8000\n",
      "[01/22/2024 06:30:31 PM : INFO  : 996596987 : ] : Loaded dataset cifar10\n",
      "[01/22/2024 06:30:31 PM : INFO  : 996596987 : ] :  std_train_size : 40000 and  std_val_size: 8000\n",
      "[01/22/2024 06:30:31 PM : DEBUG : passive_le : ] : Querying 4000 seed training points\n",
      "[01/22/2024 06:30:31 PM : DEBUG : passive_le : ] : Queried 4000 seed points for training\n",
      "[01/22/2024 06:30:31 PM : DEBUG : passive_le : ] : Validation Data Size :1000\n",
      "[01/22/2024 06:30:31 PM : DEBUG : passive_le : ] : Querying rest of the training points 0 in single batch\n",
      "[01/22/2024 06:30:31 PM : INFO  : passive_le : ] : Labeled data size for training: 4000\n",
      "[01/22/2024 06:30:31 PM : INFO  : passive_le : ] : Labeled data size for validation: 1000\n",
      "[01/22/2024 06:30:31 PM : INFO  : model_fact : ] : {'name': 'cifar_med_net', 'num_classes': 10, 'lib': 'pytorch'}\n",
      "[01/22/2024 06:30:31 PM : INFO  : passive_le : ] : --------------- Begin Model Training ------------\n",
      "[01/22/2024 06:30:31 PM : INFO  : passive_le : ] : Training conf :{'loss_function': 'std_cross_entropy', 'optimizer': 'sgd', 'learning_rate': 0.001, 'momentum': 0.9, 'weight_decay': 0.001, 'loss_tolerance': 1e-06, 'max_epochs': 50, 'normalize_weights': False, 'batch_size': 32, 'stopping_criterion': 'max_epochs', 'train_err_tol': -1, 'ckpt_load_path': 'None', 'ckpt_save_path': 'None', 'train_from_scratch': True, 'train_from_ckpt': False, 'device': 'cuda:0', 'store_embedding': False, 'save_ckpt': False, 'num_trials': 1}\n",
      "[01/22/2024 06:30:31 PM : INFO  : passive_le : ] : Model conf : {'name': 'cifar_med_net', 'num_classes': 10, 'lib': 'pytorch'}\n",
      "[01/22/2024 06:30:31 PM : INFO  : model_fact : ] : {'name': 'cifar_med_net', 'num_classes': 10, 'lib': 'pytorch'}\n",
      "[01/22/2024 06:30:31 PM : DEBUG : model_trai : ] : Training conf : {'loss_function': 'std_cross_entropy', 'optimizer': 'sgd', 'learning_rate': 0.001, 'momentum': 0.9, 'weight_decay': 0.001, 'loss_tolerance': 1e-06, 'max_epochs': 50, 'normalize_weights': False, 'batch_size': 32, 'stopping_criterion': 'max_epochs', 'train_err_tol': -1, 'ckpt_load_path': 'None', 'ckpt_save_path': 'None', 'train_from_scratch': True, 'train_from_ckpt': False, 'device': 'cuda:0', 'store_embedding': False, 'save_ckpt': False, 'num_trials': 1, 'shuffle': True, 'use_lr_schedule': True, 'nesterov': False, 'loss_tol': 1e-06, 'log_val_err': False, 'log_val_ece': False, 'log_train_ece': False, 'log_batch_loss_freq': 20, 'log_val_err_freq': 5, 'log_val_ece_freq': 5, 'verbose_logging': False, 'log_train_ece_freq': 5, 'mixup_alpha': 0, 'num_train_pts': 4000}\n",
      "[01/22/2024 06:30:31 PM : DEBUG : model_trai : ] : Using loss function : <class 'src.classifiers.torch.losses.common_losses.StdCrossEntropyLoss'>\n",
      "[01/22/2024 06:30:31 PM : DEBUG : model_trai : ] : Using stopping criterion max_epochs\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [0/4000 (0%)]\tLoss: 2.266995 \t result: {'loss': 2.2659788131713867}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [640/4000 (0%)]\tLoss: 2.250836 \t result: {'loss': 2.2953426837921143}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [1280/4000 (1%)]\tLoss: 2.311248 \t result: {'loss': 2.3536758422851562}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [1920/4000 (2%)]\tLoss: 2.319113 \t result: {'loss': 2.4289743900299072}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [2560/4000 (2%)]\tLoss: 2.111138 \t result: {'loss': 2.3173375129699707}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [3200/4000 (2%)]\tLoss: 1.987808 \t result: {'loss': 2.446133613586426}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 0 [3840/4000 (3%)]\tLoss: 1.991559 \t result: {'loss': 2.5055065155029297}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Epoch: 0 Training Error : 0.8217 , Training Loss : 0.0689\n",
      "[01/22/2024 06:30:32 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.253\n",
      "[01/22/2024 06:30:32 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Epoch:0, A new model with validation accuracy 0.253 has been found!\n",
      "[01/22/2024 06:30:32 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 1 [0/4000 (0%)]\tLoss: 2.114116 \t result: {'loss': 2.632805824279785}\n",
      "[01/22/2024 06:30:32 PM : DEBUG : model_trai : ] : Train Epoch: 1 [640/4000 (0%)]\tLoss: 2.182205 \t result: {'loss': 2.6521942615509033}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 1 [1280/4000 (1%)]\tLoss: 1.954627 \t result: {'loss': 2.502114772796631}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 1 [1920/4000 (2%)]\tLoss: 2.203092 \t result: {'loss': 2.808307647705078}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 1 [2560/4000 (2%)]\tLoss: 2.205948 \t result: {'loss': 2.8715734481811523}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 1 [3200/4000 (2%)]\tLoss: 1.783946 \t result: {'loss': 2.518064498901367}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 1 [3840/4000 (3%)]\tLoss: 1.871183 \t result: {'loss': 2.8391664028167725}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Epoch: 1 Training Error : 0.7250 , Training Loss : 0.0623\n",
      "[01/22/2024 06:30:33 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.277\n",
      "[01/22/2024 06:30:33 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.253\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Epoch:1, A new model with validation accuracy 0.277 has been found!\n",
      "[01/22/2024 06:30:33 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 2 [0/4000 (0%)]\tLoss: 1.835122 \t result: {'loss': 2.562295913696289}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 2 [640/4000 (0%)]\tLoss: 1.943731 \t result: {'loss': 2.6858177185058594}\n",
      "[01/22/2024 06:30:33 PM : DEBUG : model_trai : ] : Train Epoch: 2 [1280/4000 (1%)]\tLoss: 1.923112 \t result: {'loss': 2.761455535888672}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 2 [1920/4000 (2%)]\tLoss: 1.792447 \t result: {'loss': 2.71429181098938}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 2 [2560/4000 (2%)]\tLoss: 1.694735 \t result: {'loss': 3.5379555225372314}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 2 [3200/4000 (2%)]\tLoss: 1.629850 \t result: {'loss': 3.0295379161834717}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 2 [3840/4000 (3%)]\tLoss: 2.057062 \t result: {'loss': 2.523423194885254}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Epoch: 2 Training Error : 0.6713 , Training Loss : 0.0571\n",
      "[01/22/2024 06:30:34 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.334\n",
      "[01/22/2024 06:30:34 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.277\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Epoch:2, A new model with validation accuracy 0.334 has been found!\n",
      "[01/22/2024 06:30:34 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 3 [0/4000 (0%)]\tLoss: 1.787528 \t result: {'loss': 2.4661712646484375}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 3 [640/4000 (0%)]\tLoss: 1.612416 \t result: {'loss': 3.1691412925720215}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 3 [1280/4000 (1%)]\tLoss: 1.418731 \t result: {'loss': 3.4291326999664307}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 3 [1920/4000 (2%)]\tLoss: 1.505952 \t result: {'loss': 3.009775161743164}\n",
      "[01/22/2024 06:30:34 PM : DEBUG : model_trai : ] : Train Epoch: 3 [2560/4000 (2%)]\tLoss: 2.000186 \t result: {'loss': 3.1124355792999268}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 3 [3200/4000 (2%)]\tLoss: 1.450455 \t result: {'loss': 3.4335224628448486}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 3 [3840/4000 (3%)]\tLoss: 1.453673 \t result: {'loss': 2.756397008895874}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Epoch: 3 Training Error : 0.6270 , Training Loss : 0.0534\n",
      "[01/22/2024 06:30:35 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.356\n",
      "[01/22/2024 06:30:35 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.334\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Epoch:3, A new model with validation accuracy 0.356 has been found!\n",
      "[01/22/2024 06:30:35 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [0/4000 (0%)]\tLoss: 1.820333 \t result: {'loss': 3.3957977294921875}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [640/4000 (0%)]\tLoss: 1.638861 \t result: {'loss': 3.1227328777313232}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [1280/4000 (1%)]\tLoss: 1.580174 \t result: {'loss': 3.494835615158081}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [1920/4000 (2%)]\tLoss: 1.483383 \t result: {'loss': 3.304081439971924}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [2560/4000 (2%)]\tLoss: 1.687864 \t result: {'loss': 3.028242349624634}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [3200/4000 (2%)]\tLoss: 1.699642 \t result: {'loss': 2.8228750228881836}\n",
      "[01/22/2024 06:30:35 PM : DEBUG : model_trai : ] : Train Epoch: 4 [3840/4000 (3%)]\tLoss: 1.259962 \t result: {'loss': 3.310774087905884}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Epoch: 4 Training Error : 0.5910 , Training Loss : 0.0511\n",
      "[01/22/2024 06:30:36 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.426\n",
      "[01/22/2024 06:30:36 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.356\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Epoch:4, A new model with validation accuracy 0.426 has been found!\n",
      "[01/22/2024 06:30:36 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [0/4000 (0%)]\tLoss: 1.507592 \t result: {'loss': 3.5624051094055176}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [640/4000 (0%)]\tLoss: 1.926081 \t result: {'loss': 2.973515272140503}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [1280/4000 (1%)]\tLoss: 1.504333 \t result: {'loss': 3.856247901916504}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [1920/4000 (2%)]\tLoss: 1.768984 \t result: {'loss': 3.0350165367126465}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [2560/4000 (2%)]\tLoss: 1.566019 \t result: {'loss': 3.3376312255859375}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [3200/4000 (2%)]\tLoss: 1.306312 \t result: {'loss': 4.185874938964844}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Train Epoch: 5 [3840/4000 (3%)]\tLoss: 1.493387 \t result: {'loss': 3.5190041065216064}\n",
      "[01/22/2024 06:30:36 PM : DEBUG : model_trai : ] : Epoch: 5 Training Error : 0.5528 , Training Loss : 0.0477\n",
      "[01/22/2024 06:30:37 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.443\n",
      "[01/22/2024 06:30:37 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.426\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Epoch:5, A new model with validation accuracy 0.443 has been found!\n",
      "[01/22/2024 06:30:37 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [0/4000 (0%)]\tLoss: 1.541424 \t result: {'loss': 3.6175670623779297}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [640/4000 (0%)]\tLoss: 1.708110 \t result: {'loss': 3.484858512878418}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [1280/4000 (1%)]\tLoss: 1.529561 \t result: {'loss': 3.542285203933716}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [1920/4000 (2%)]\tLoss: 1.765023 \t result: {'loss': 3.1198110580444336}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [2560/4000 (2%)]\tLoss: 1.710144 \t result: {'loss': 4.050468444824219}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [3200/4000 (2%)]\tLoss: 1.361073 \t result: {'loss': 3.3255159854888916}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 6 [3840/4000 (3%)]\tLoss: 1.510312 \t result: {'loss': 4.356914520263672}\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Epoch: 6 Training Error : 0.5080 , Training Loss : 0.0446\n",
      "[01/22/2024 06:30:37 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.436\n",
      "[01/22/2024 06:30:37 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.443\n",
      "[01/22/2024 06:30:37 PM : DEBUG : model_trai : ] : Train Epoch: 7 [0/4000 (0%)]\tLoss: 1.410735 \t result: {'loss': 3.5217747688293457}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 7 [640/4000 (0%)]\tLoss: 1.126245 \t result: {'loss': 3.9624404907226562}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 7 [1280/4000 (1%)]\tLoss: 1.143047 \t result: {'loss': 3.0638742446899414}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 7 [1920/4000 (2%)]\tLoss: 1.445551 \t result: {'loss': 4.4179863929748535}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 7 [2560/4000 (2%)]\tLoss: 1.149706 \t result: {'loss': 4.630307674407959}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 7 [3200/4000 (2%)]\tLoss: 1.468128 \t result: {'loss': 3.671132802963257}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 7 [3840/4000 (3%)]\tLoss: 0.982178 \t result: {'loss': 3.481868028640747}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Epoch: 7 Training Error : 0.4850 , Training Loss : 0.0427\n",
      "[01/22/2024 06:30:38 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.492\n",
      "[01/22/2024 06:30:38 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.443\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Epoch:7, A new model with validation accuracy 0.492 has been found!\n",
      "[01/22/2024 06:30:38 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 8 [0/4000 (0%)]\tLoss: 0.937170 \t result: {'loss': 4.5580973625183105}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 8 [640/4000 (0%)]\tLoss: 1.249199 \t result: {'loss': 4.441433429718018}\n",
      "[01/22/2024 06:30:38 PM : DEBUG : model_trai : ] : Train Epoch: 8 [1280/4000 (1%)]\tLoss: 1.105293 \t result: {'loss': 5.009731292724609}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 8 [1920/4000 (2%)]\tLoss: 1.399525 \t result: {'loss': 4.9631781578063965}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 8 [2560/4000 (2%)]\tLoss: 1.180813 \t result: {'loss': 3.4519317150115967}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 8 [3200/4000 (2%)]\tLoss: 1.530033 \t result: {'loss': 3.7790541648864746}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 8 [3840/4000 (3%)]\tLoss: 1.323525 \t result: {'loss': 3.6556878089904785}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Epoch: 8 Training Error : 0.4423 , Training Loss : 0.0386\n",
      "[01/22/2024 06:30:39 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.507\n",
      "[01/22/2024 06:30:39 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.492\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Epoch:8, A new model with validation accuracy 0.507 has been found!\n",
      "[01/22/2024 06:30:39 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 9 [0/4000 (0%)]\tLoss: 0.968008 \t result: {'loss': 4.765826225280762}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 9 [640/4000 (0%)]\tLoss: 1.025873 \t result: {'loss': 4.716472625732422}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 9 [1280/4000 (1%)]\tLoss: 0.844297 \t result: {'loss': 5.22366189956665}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 9 [1920/4000 (2%)]\tLoss: 1.118532 \t result: {'loss': 3.9457273483276367}\n",
      "[01/22/2024 06:30:39 PM : DEBUG : model_trai : ] : Train Epoch: 9 [2560/4000 (2%)]\tLoss: 1.023721 \t result: {'loss': 5.7893548011779785}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 9 [3200/4000 (2%)]\tLoss: 0.835904 \t result: {'loss': 5.046629905700684}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 9 [3840/4000 (3%)]\tLoss: 1.312321 \t result: {'loss': 3.4506728649139404}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Epoch: 9 Training Error : 0.3970 , Training Loss : 0.0347\n",
      "[01/22/2024 06:30:40 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:40 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.507\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Epoch:9, A new model with validation accuracy 0.533 has been found!\n",
      "[01/22/2024 06:30:40 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 10 [0/4000 (0%)]\tLoss: 1.166091 \t result: {'loss': 4.262167930603027}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 10 [640/4000 (0%)]\tLoss: 1.164989 \t result: {'loss': 4.2161545753479}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 10 [1280/4000 (1%)]\tLoss: 0.862904 \t result: {'loss': 4.822907447814941}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 10 [1920/4000 (2%)]\tLoss: 1.176147 \t result: {'loss': 5.754456996917725}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 10 [2560/4000 (2%)]\tLoss: 0.997369 \t result: {'loss': 4.403327465057373}\n",
      "[01/22/2024 06:30:40 PM : DEBUG : model_trai : ] : Train Epoch: 10 [3200/4000 (2%)]\tLoss: 1.371030 \t result: {'loss': 4.671082019805908}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 10 [3840/4000 (3%)]\tLoss: 1.062208 \t result: {'loss': 5.003350257873535}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Epoch: 10 Training Error : 0.3720 , Training Loss : 0.0322\n",
      "[01/22/2024 06:30:41 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.446\n",
      "[01/22/2024 06:30:41 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [0/4000 (0%)]\tLoss: 1.068973 \t result: {'loss': 4.7180047035217285}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [640/4000 (0%)]\tLoss: 0.609154 \t result: {'loss': 4.116793155670166}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [1280/4000 (1%)]\tLoss: 1.005180 \t result: {'loss': 4.947268486022949}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [1920/4000 (2%)]\tLoss: 0.781592 \t result: {'loss': 5.668907642364502}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [2560/4000 (2%)]\tLoss: 0.999322 \t result: {'loss': 5.540768623352051}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [3200/4000 (2%)]\tLoss: 0.783280 \t result: {'loss': 4.288084030151367}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Train Epoch: 11 [3840/4000 (3%)]\tLoss: 0.988244 \t result: {'loss': 4.127115249633789}\n",
      "[01/22/2024 06:30:41 PM : DEBUG : model_trai : ] : Epoch: 11 Training Error : 0.3075 , Training Loss : 0.0270\n",
      "[01/22/2024 06:30:41 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.469\n",
      "[01/22/2024 06:30:41 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [0/4000 (0%)]\tLoss: 0.678596 \t result: {'loss': 5.866390705108643}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [640/4000 (0%)]\tLoss: 0.763541 \t result: {'loss': 6.0515289306640625}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [1280/4000 (1%)]\tLoss: 0.790678 \t result: {'loss': 6.065861225128174}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [1920/4000 (2%)]\tLoss: 0.779370 \t result: {'loss': 7.587014198303223}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [2560/4000 (2%)]\tLoss: 0.804634 \t result: {'loss': 5.437277317047119}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [3200/4000 (2%)]\tLoss: 0.800035 \t result: {'loss': 5.468532085418701}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 12 [3840/4000 (3%)]\tLoss: 0.708611 \t result: {'loss': 5.165336608886719}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Epoch: 12 Training Error : 0.2558 , Training Loss : 0.0221\n",
      "[01/22/2024 06:30:42 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.526\n",
      "[01/22/2024 06:30:42 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 13 [0/4000 (0%)]\tLoss: 0.604955 \t result: {'loss': 4.432796001434326}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 13 [640/4000 (0%)]\tLoss: 0.323636 \t result: {'loss': 7.419514179229736}\n",
      "[01/22/2024 06:30:42 PM : DEBUG : model_trai : ] : Train Epoch: 13 [1280/4000 (1%)]\tLoss: 0.545780 \t result: {'loss': 6.789948463439941}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 13 [1920/4000 (2%)]\tLoss: 0.864451 \t result: {'loss': 8.601593971252441}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 13 [2560/4000 (2%)]\tLoss: 0.602460 \t result: {'loss': 6.527948379516602}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 13 [3200/4000 (2%)]\tLoss: 0.571278 \t result: {'loss': 9.548165321350098}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 13 [3840/4000 (3%)]\tLoss: 0.588490 \t result: {'loss': 7.421359062194824}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Epoch: 13 Training Error : 0.1880 , Training Loss : 0.0164\n",
      "[01/22/2024 06:30:43 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.43\n",
      "[01/22/2024 06:30:43 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 14 [0/4000 (0%)]\tLoss: 0.387391 \t result: {'loss': 6.219780445098877}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 14 [640/4000 (0%)]\tLoss: 0.436540 \t result: {'loss': 8.09775447845459}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 14 [1280/4000 (1%)]\tLoss: 0.438451 \t result: {'loss': 9.024989128112793}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 14 [1920/4000 (2%)]\tLoss: 0.227712 \t result: {'loss': 8.661687850952148}\n",
      "[01/22/2024 06:30:43 PM : DEBUG : model_trai : ] : Train Epoch: 14 [2560/4000 (2%)]\tLoss: 0.473576 \t result: {'loss': 8.508206367492676}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 14 [3200/4000 (2%)]\tLoss: 0.340471 \t result: {'loss': 7.340090751647949}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 14 [3840/4000 (3%)]\tLoss: 0.589842 \t result: {'loss': 7.440921306610107}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Epoch: 14 Training Error : 0.1518 , Training Loss : 0.0134\n",
      "[01/22/2024 06:30:44 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.498\n",
      "[01/22/2024 06:30:44 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [0/4000 (0%)]\tLoss: 0.310761 \t result: {'loss': 6.402348518371582}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [640/4000 (0%)]\tLoss: 0.321175 \t result: {'loss': 8.651001930236816}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [1280/4000 (1%)]\tLoss: 0.363813 \t result: {'loss': 9.938785552978516}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [1920/4000 (2%)]\tLoss: 0.123889 \t result: {'loss': 9.844046592712402}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [2560/4000 (2%)]\tLoss: 0.377664 \t result: {'loss': 6.8507513999938965}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [3200/4000 (2%)]\tLoss: 0.527007 \t result: {'loss': 11.861467361450195}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Train Epoch: 15 [3840/4000 (3%)]\tLoss: 0.189569 \t result: {'loss': 9.640740394592285}\n",
      "[01/22/2024 06:30:44 PM : DEBUG : model_trai : ] : Epoch: 15 Training Error : 0.1140 , Training Loss : 0.0099\n",
      "[01/22/2024 06:30:45 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.494\n",
      "[01/22/2024 06:30:45 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [0/4000 (0%)]\tLoss: 0.127337 \t result: {'loss': 9.373333930969238}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [640/4000 (0%)]\tLoss: 0.359498 \t result: {'loss': 10.115869522094727}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [1280/4000 (1%)]\tLoss: 0.080026 \t result: {'loss': 9.623767852783203}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [1920/4000 (2%)]\tLoss: 0.169404 \t result: {'loss': 10.853800773620605}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [2560/4000 (2%)]\tLoss: 0.134990 \t result: {'loss': 12.942502975463867}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [3200/4000 (2%)]\tLoss: 0.399674 \t result: {'loss': 10.638225555419922}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 16 [3840/4000 (3%)]\tLoss: 0.219279 \t result: {'loss': 8.44209098815918}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Epoch: 16 Training Error : 0.0757 , Training Loss : 0.0071\n",
      "[01/22/2024 06:30:45 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.477\n",
      "[01/22/2024 06:30:45 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 17 [0/4000 (0%)]\tLoss: 0.347477 \t result: {'loss': 10.284001350402832}\n",
      "[01/22/2024 06:30:45 PM : DEBUG : model_trai : ] : Train Epoch: 17 [640/4000 (0%)]\tLoss: 0.433502 \t result: {'loss': 10.873226165771484}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 17 [1280/4000 (1%)]\tLoss: 0.219560 \t result: {'loss': 10.528229713439941}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 17 [1920/4000 (2%)]\tLoss: 0.113919 \t result: {'loss': 10.562655448913574}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 17 [2560/4000 (2%)]\tLoss: 0.175616 \t result: {'loss': 11.407414436340332}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 17 [3200/4000 (2%)]\tLoss: 0.175133 \t result: {'loss': 9.83854866027832}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 17 [3840/4000 (3%)]\tLoss: 0.034621 \t result: {'loss': 10.345147132873535}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Epoch: 17 Training Error : 0.0630 , Training Loss : 0.0059\n",
      "[01/22/2024 06:30:46 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.495\n",
      "[01/22/2024 06:30:46 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 18 [0/4000 (0%)]\tLoss: 0.048546 \t result: {'loss': 9.521119117736816}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 18 [640/4000 (0%)]\tLoss: 0.060804 \t result: {'loss': 11.640602111816406}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 18 [1280/4000 (1%)]\tLoss: 0.179155 \t result: {'loss': 14.505617141723633}\n",
      "[01/22/2024 06:30:46 PM : DEBUG : model_trai : ] : Train Epoch: 18 [1920/4000 (2%)]\tLoss: 0.094657 \t result: {'loss': 12.449286460876465}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 18 [2560/4000 (2%)]\tLoss: 0.186919 \t result: {'loss': 13.117039680480957}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 18 [3200/4000 (2%)]\tLoss: 0.083908 \t result: {'loss': 9.596291542053223}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 18 [3840/4000 (3%)]\tLoss: 0.350254 \t result: {'loss': 9.360718727111816}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Epoch: 18 Training Error : 0.0417 , Training Loss : 0.0038\n",
      "[01/22/2024 06:30:47 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.491\n",
      "[01/22/2024 06:30:47 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 19 [0/4000 (0%)]\tLoss: 0.136928 \t result: {'loss': 8.625758171081543}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 19 [640/4000 (0%)]\tLoss: 0.124810 \t result: {'loss': 14.927306175231934}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 19 [1280/4000 (1%)]\tLoss: 0.234872 \t result: {'loss': 11.679079055786133}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 19 [1920/4000 (2%)]\tLoss: 0.218404 \t result: {'loss': 12.365400314331055}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 19 [2560/4000 (2%)]\tLoss: 0.067793 \t result: {'loss': 16.332063674926758}\n",
      "[01/22/2024 06:30:47 PM : DEBUG : model_trai : ] : Train Epoch: 19 [3200/4000 (2%)]\tLoss: 0.014634 \t result: {'loss': 15.349316596984863}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 19 [3840/4000 (3%)]\tLoss: 0.108045 \t result: {'loss': 12.420758247375488}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Epoch: 19 Training Error : 0.0272 , Training Loss : 0.0027\n",
      "[01/22/2024 06:30:48 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.502\n",
      "[01/22/2024 06:30:48 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [0/4000 (0%)]\tLoss: 0.026248 \t result: {'loss': 12.491253852844238}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [640/4000 (0%)]\tLoss: 0.050515 \t result: {'loss': 13.31486988067627}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [1280/4000 (1%)]\tLoss: 0.049597 \t result: {'loss': 15.264969825744629}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [1920/4000 (2%)]\tLoss: 0.021000 \t result: {'loss': 16.16104507446289}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [2560/4000 (2%)]\tLoss: 0.111715 \t result: {'loss': 12.275951385498047}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [3200/4000 (2%)]\tLoss: 0.257963 \t result: {'loss': 13.43632984161377}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Train Epoch: 20 [3840/4000 (3%)]\tLoss: 0.141618 \t result: {'loss': 12.335314750671387}\n",
      "[01/22/2024 06:30:48 PM : DEBUG : model_trai : ] : Epoch: 20 Training Error : 0.0255 , Training Loss : 0.0023\n",
      "[01/22/2024 06:30:48 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.514\n",
      "[01/22/2024 06:30:48 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [0/4000 (0%)]\tLoss: 0.103062 \t result: {'loss': 14.658015251159668}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [640/4000 (0%)]\tLoss: 0.072885 \t result: {'loss': 12.374736785888672}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [1280/4000 (1%)]\tLoss: 0.055433 \t result: {'loss': 13.659451484680176}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [1920/4000 (2%)]\tLoss: 0.044417 \t result: {'loss': 13.217109680175781}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [2560/4000 (2%)]\tLoss: 0.035067 \t result: {'loss': 16.029510498046875}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [3200/4000 (2%)]\tLoss: 0.169488 \t result: {'loss': 14.346866607666016}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 21 [3840/4000 (3%)]\tLoss: 0.075227 \t result: {'loss': 11.953912734985352}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Epoch: 21 Training Error : 0.0280 , Training Loss : 0.0025\n",
      "[01/22/2024 06:30:49 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.524\n",
      "[01/22/2024 06:30:49 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 22 [0/4000 (0%)]\tLoss: 0.012278 \t result: {'loss': 14.110943794250488}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 22 [640/4000 (0%)]\tLoss: 0.021006 \t result: {'loss': 13.776439666748047}\n",
      "[01/22/2024 06:30:49 PM : DEBUG : model_trai : ] : Train Epoch: 22 [1280/4000 (1%)]\tLoss: 0.059337 \t result: {'loss': 12.852069854736328}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 22 [1920/4000 (2%)]\tLoss: 0.038754 \t result: {'loss': 14.293846130371094}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 22 [2560/4000 (2%)]\tLoss: 0.023472 \t result: {'loss': 12.084293365478516}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 22 [3200/4000 (2%)]\tLoss: 0.093508 \t result: {'loss': 14.10228443145752}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 22 [3840/4000 (3%)]\tLoss: 0.083447 \t result: {'loss': 17.127504348754883}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Epoch: 22 Training Error : 0.0202 , Training Loss : 0.0018\n",
      "[01/22/2024 06:30:50 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.476\n",
      "[01/22/2024 06:30:50 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 23 [0/4000 (0%)]\tLoss: 0.154533 \t result: {'loss': 17.606231689453125}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 23 [640/4000 (0%)]\tLoss: 0.038578 \t result: {'loss': 17.007381439208984}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 23 [1280/4000 (1%)]\tLoss: 0.018821 \t result: {'loss': 12.083301544189453}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 23 [1920/4000 (2%)]\tLoss: 0.000988 \t result: {'loss': 16.17816734313965}\n",
      "[01/22/2024 06:30:50 PM : DEBUG : model_trai : ] : Train Epoch: 23 [2560/4000 (2%)]\tLoss: 0.006924 \t result: {'loss': 17.942331314086914}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 23 [3200/4000 (2%)]\tLoss: 0.002248 \t result: {'loss': 15.855369567871094}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 23 [3840/4000 (3%)]\tLoss: 0.000771 \t result: {'loss': 17.308595657348633}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Epoch: 23 Training Error : 0.0158 , Training Loss : 0.0017\n",
      "[01/22/2024 06:30:51 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.536\n",
      "[01/22/2024 06:30:51 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.533\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Epoch:23, A new model with validation accuracy 0.536 has been found!\n",
      "[01/22/2024 06:30:51 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [0/4000 (0%)]\tLoss: 0.001508 \t result: {'loss': 19.061138153076172}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [640/4000 (0%)]\tLoss: 0.003620 \t result: {'loss': 14.3898344039917}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [1280/4000 (1%)]\tLoss: 0.024376 \t result: {'loss': 15.166601181030273}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [1920/4000 (2%)]\tLoss: 0.002629 \t result: {'loss': 16.90699577331543}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [2560/4000 (2%)]\tLoss: 0.191550 \t result: {'loss': 18.6313533782959}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [3200/4000 (2%)]\tLoss: 0.110972 \t result: {'loss': 18.261991500854492}\n",
      "[01/22/2024 06:30:51 PM : DEBUG : model_trai : ] : Train Epoch: 24 [3840/4000 (3%)]\tLoss: 0.013024 \t result: {'loss': 15.809475898742676}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Epoch: 24 Training Error : 0.0098 , Training Loss : 0.0011\n",
      "[01/22/2024 06:30:52 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.506\n",
      "[01/22/2024 06:30:52 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.536\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [0/4000 (0%)]\tLoss: 0.015090 \t result: {'loss': 14.327412605285645}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [640/4000 (0%)]\tLoss: 0.052632 \t result: {'loss': 18.164798736572266}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [1280/4000 (1%)]\tLoss: 0.077581 \t result: {'loss': 15.422235488891602}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [1920/4000 (2%)]\tLoss: 0.008497 \t result: {'loss': 14.187310218811035}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [2560/4000 (2%)]\tLoss: 0.017809 \t result: {'loss': 18.367969512939453}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [3200/4000 (2%)]\tLoss: 0.024019 \t result: {'loss': 17.43802833557129}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Train Epoch: 25 [3840/4000 (3%)]\tLoss: 0.001150 \t result: {'loss': 15.337555885314941}\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Epoch: 25 Training Error : 0.0092 , Training Loss : 0.0010\n",
      "[01/22/2024 06:30:52 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.548\n",
      "[01/22/2024 06:30:52 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.536\n",
      "[01/22/2024 06:30:52 PM : DEBUG : model_trai : ] : Epoch:25, A new model with validation accuracy 0.548 has been found!\n",
      "[01/22/2024 06:30:53 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [0/4000 (0%)]\tLoss: 0.001602 \t result: {'loss': 19.001375198364258}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [640/4000 (0%)]\tLoss: 0.002453 \t result: {'loss': 18.52579116821289}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [1280/4000 (1%)]\tLoss: 0.000875 \t result: {'loss': 18.922088623046875}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [1920/4000 (2%)]\tLoss: 0.002528 \t result: {'loss': 19.431964874267578}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [2560/4000 (2%)]\tLoss: 0.000968 \t result: {'loss': 17.903121948242188}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [3200/4000 (2%)]\tLoss: 0.000511 \t result: {'loss': 19.586009979248047}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 26 [3840/4000 (3%)]\tLoss: 0.000230 \t result: {'loss': 19.097135543823242}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Epoch: 26 Training Error : 0.0002 , Training Loss : 0.0001\n",
      "[01/22/2024 06:30:53 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.547\n",
      "[01/22/2024 06:30:53 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.548\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 27 [0/4000 (0%)]\tLoss: 0.000143 \t result: {'loss': 20.82703971862793}\n",
      "[01/22/2024 06:30:53 PM : DEBUG : model_trai : ] : Train Epoch: 27 [640/4000 (0%)]\tLoss: 0.003379 \t result: {'loss': 21.52342987060547}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 27 [1280/4000 (1%)]\tLoss: 0.000750 \t result: {'loss': 19.631664276123047}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 27 [1920/4000 (2%)]\tLoss: 0.000384 \t result: {'loss': 19.052906036376953}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 27 [2560/4000 (2%)]\tLoss: 0.000496 \t result: {'loss': 18.799596786499023}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 27 [3200/4000 (2%)]\tLoss: 0.000467 \t result: {'loss': 21.43024253845215}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 27 [3840/4000 (3%)]\tLoss: 0.000173 \t result: {'loss': 18.604021072387695}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Epoch: 27 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:54 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:54 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.548\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Epoch:27, A new model with validation accuracy 0.551 has been found!\n",
      "[01/22/2024 06:30:54 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 28 [0/4000 (0%)]\tLoss: 0.000208 \t result: {'loss': 20.120676040649414}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 28 [640/4000 (0%)]\tLoss: 0.000544 \t result: {'loss': 19.59085464477539}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 28 [1280/4000 (1%)]\tLoss: 0.000788 \t result: {'loss': 21.880090713500977}\n",
      "[01/22/2024 06:30:54 PM : DEBUG : model_trai : ] : Train Epoch: 28 [1920/4000 (2%)]\tLoss: 0.000046 \t result: {'loss': 19.48109245300293}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 28 [2560/4000 (2%)]\tLoss: 0.000459 \t result: {'loss': 16.648101806640625}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 28 [3200/4000 (2%)]\tLoss: 0.000361 \t result: {'loss': 20.785863876342773}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 28 [3840/4000 (3%)]\tLoss: 0.000188 \t result: {'loss': 20.90569496154785}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Epoch: 28 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:55 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:55 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 29 [0/4000 (0%)]\tLoss: 0.000105 \t result: {'loss': 21.10767364501953}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 29 [640/4000 (0%)]\tLoss: 0.000177 \t result: {'loss': 21.220611572265625}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 29 [1280/4000 (1%)]\tLoss: 0.000054 \t result: {'loss': 17.00261116027832}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 29 [1920/4000 (2%)]\tLoss: 0.000095 \t result: {'loss': 23.32808494567871}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 29 [2560/4000 (2%)]\tLoss: 0.000075 \t result: {'loss': 20.878734588623047}\n",
      "[01/22/2024 06:30:55 PM : DEBUG : model_trai : ] : Train Epoch: 29 [3200/4000 (2%)]\tLoss: 0.000052 \t result: {'loss': 20.224449157714844}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 29 [3840/4000 (3%)]\tLoss: 0.000259 \t result: {'loss': 23.383193969726562}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Epoch: 29 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:56 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:30:56 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [0/4000 (0%)]\tLoss: 0.000228 \t result: {'loss': 18.993879318237305}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [640/4000 (0%)]\tLoss: 0.000279 \t result: {'loss': 19.088048934936523}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [1280/4000 (1%)]\tLoss: 0.000422 \t result: {'loss': 20.74891471862793}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [1920/4000 (2%)]\tLoss: 0.000160 \t result: {'loss': 24.437997817993164}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [2560/4000 (2%)]\tLoss: 0.000141 \t result: {'loss': 22.46392059326172}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [3200/4000 (2%)]\tLoss: 0.000093 \t result: {'loss': 19.389524459838867}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Train Epoch: 30 [3840/4000 (3%)]\tLoss: 0.000395 \t result: {'loss': 23.517986297607422}\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Epoch: 30 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:56 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:30:56 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:56 PM : DEBUG : model_trai : ] : Epoch:30, A new model with validation accuracy 0.552 has been found!\n",
      "[01/22/2024 06:30:57 PM : INFO  : model_trai : ] : Saved current model checkpoint to path : None\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [0/4000 (0%)]\tLoss: 0.000040 \t result: {'loss': 24.745454788208008}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [640/4000 (0%)]\tLoss: 0.000126 \t result: {'loss': 17.640947341918945}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [1280/4000 (1%)]\tLoss: 0.000097 \t result: {'loss': 24.05219078063965}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [1920/4000 (2%)]\tLoss: 0.000051 \t result: {'loss': 21.400102615356445}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [2560/4000 (2%)]\tLoss: 0.000155 \t result: {'loss': 18.690467834472656}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [3200/4000 (2%)]\tLoss: 0.000219 \t result: {'loss': 23.76184844970703}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 31 [3840/4000 (3%)]\tLoss: 0.000253 \t result: {'loss': 21.33819007873535}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Epoch: 31 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:57 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:57 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 32 [0/4000 (0%)]\tLoss: 0.000395 \t result: {'loss': 21.78814125061035}\n",
      "[01/22/2024 06:30:57 PM : DEBUG : model_trai : ] : Train Epoch: 32 [640/4000 (0%)]\tLoss: 0.000241 \t result: {'loss': 19.543649673461914}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 32 [1280/4000 (1%)]\tLoss: 0.000088 \t result: {'loss': 24.284873962402344}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 32 [1920/4000 (2%)]\tLoss: 0.000130 \t result: {'loss': 22.902359008789062}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 32 [2560/4000 (2%)]\tLoss: 0.000143 \t result: {'loss': 24.713233947753906}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 32 [3200/4000 (2%)]\tLoss: 0.000133 \t result: {'loss': 22.1019287109375}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 32 [3840/4000 (3%)]\tLoss: 0.000194 \t result: {'loss': 21.177875518798828}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Epoch: 32 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:58 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:30:58 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 33 [0/4000 (0%)]\tLoss: 0.000099 \t result: {'loss': 22.748275756835938}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 33 [640/4000 (0%)]\tLoss: 0.000135 \t result: {'loss': 21.2845401763916}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 33 [1280/4000 (1%)]\tLoss: 0.000038 \t result: {'loss': 21.796709060668945}\n",
      "[01/22/2024 06:30:58 PM : DEBUG : model_trai : ] : Train Epoch: 33 [1920/4000 (2%)]\tLoss: 0.000226 \t result: {'loss': 17.160043716430664}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 33 [2560/4000 (2%)]\tLoss: 0.000118 \t result: {'loss': 22.099472045898438}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 33 [3200/4000 (2%)]\tLoss: 0.000236 \t result: {'loss': 17.263736724853516}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 33 [3840/4000 (3%)]\tLoss: 0.000189 \t result: {'loss': 21.05013656616211}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Epoch: 33 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:30:59 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:30:59 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [0/4000 (0%)]\tLoss: 0.000102 \t result: {'loss': 20.858489990234375}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [640/4000 (0%)]\tLoss: 0.000424 \t result: {'loss': 22.603851318359375}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [1280/4000 (1%)]\tLoss: 0.000139 \t result: {'loss': 18.863460540771484}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [1920/4000 (2%)]\tLoss: 0.000049 \t result: {'loss': 18.373249053955078}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [2560/4000 (2%)]\tLoss: 0.000232 \t result: {'loss': 19.618122100830078}\n",
      "[01/22/2024 06:30:59 PM : DEBUG : model_trai : ] : Train Epoch: 34 [3200/4000 (2%)]\tLoss: 0.000174 \t result: {'loss': 23.422651290893555}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 34 [3840/4000 (3%)]\tLoss: 0.000175 \t result: {'loss': 26.367706298828125}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Epoch: 34 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:00 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.551\n",
      "[01/22/2024 06:31:00 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [0/4000 (0%)]\tLoss: 0.000250 \t result: {'loss': 21.264310836791992}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [640/4000 (0%)]\tLoss: 0.000044 \t result: {'loss': 25.802248001098633}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [1280/4000 (1%)]\tLoss: 0.000095 \t result: {'loss': 20.052221298217773}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [1920/4000 (2%)]\tLoss: 0.000084 \t result: {'loss': 24.465805053710938}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [2560/4000 (2%)]\tLoss: 0.000217 \t result: {'loss': 18.728378295898438}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [3200/4000 (2%)]\tLoss: 0.000255 \t result: {'loss': 22.543596267700195}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Train Epoch: 35 [3840/4000 (3%)]\tLoss: 0.000202 \t result: {'loss': 19.18609619140625}\n",
      "[01/22/2024 06:31:00 PM : DEBUG : model_trai : ] : Epoch: 35 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:00 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:00 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [0/4000 (0%)]\tLoss: 0.000304 \t result: {'loss': 20.16096305847168}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [640/4000 (0%)]\tLoss: 0.000199 \t result: {'loss': 20.837814331054688}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [1280/4000 (1%)]\tLoss: 0.000116 \t result: {'loss': 20.551799774169922}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [1920/4000 (2%)]\tLoss: 0.000114 \t result: {'loss': 14.591699600219727}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [2560/4000 (2%)]\tLoss: 0.000108 \t result: {'loss': 17.483104705810547}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [3200/4000 (2%)]\tLoss: 0.000242 \t result: {'loss': 21.589818954467773}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 36 [3840/4000 (3%)]\tLoss: 0.000167 \t result: {'loss': 20.60844612121582}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Epoch: 36 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:01 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:01 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 37 [0/4000 (0%)]\tLoss: 0.000070 \t result: {'loss': 21.777793884277344}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 37 [640/4000 (0%)]\tLoss: 0.000096 \t result: {'loss': 21.435710906982422}\n",
      "[01/22/2024 06:31:01 PM : DEBUG : model_trai : ] : Train Epoch: 37 [1280/4000 (1%)]\tLoss: 0.000072 \t result: {'loss': 19.82929229736328}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 37 [1920/4000 (2%)]\tLoss: 0.000078 \t result: {'loss': 21.817707061767578}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 37 [2560/4000 (2%)]\tLoss: 0.000186 \t result: {'loss': 22.77566146850586}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 37 [3200/4000 (2%)]\tLoss: 0.000138 \t result: {'loss': 20.404098510742188}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 37 [3840/4000 (3%)]\tLoss: 0.000047 \t result: {'loss': 25.08995246887207}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Epoch: 37 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:02 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:02 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 38 [0/4000 (0%)]\tLoss: 0.000137 \t result: {'loss': 20.10886001586914}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 38 [640/4000 (0%)]\tLoss: 0.000101 \t result: {'loss': 18.30951690673828}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 38 [1280/4000 (1%)]\tLoss: 0.000121 \t result: {'loss': 19.62382698059082}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 38 [1920/4000 (2%)]\tLoss: 0.000155 \t result: {'loss': 19.086769104003906}\n",
      "[01/22/2024 06:31:02 PM : DEBUG : model_trai : ] : Train Epoch: 38 [2560/4000 (2%)]\tLoss: 0.000197 \t result: {'loss': 24.806049346923828}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 38 [3200/4000 (2%)]\tLoss: 0.000114 \t result: {'loss': 16.714984893798828}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 38 [3840/4000 (3%)]\tLoss: 0.000085 \t result: {'loss': 22.586021423339844}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Epoch: 38 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:03 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:03 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [0/4000 (0%)]\tLoss: 0.000197 \t result: {'loss': 18.029842376708984}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [640/4000 (0%)]\tLoss: 0.000132 \t result: {'loss': 18.480899810791016}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [1280/4000 (1%)]\tLoss: 0.000047 \t result: {'loss': 21.578468322753906}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [1920/4000 (2%)]\tLoss: 0.000161 \t result: {'loss': 23.306249618530273}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [2560/4000 (2%)]\tLoss: 0.000168 \t result: {'loss': 17.869436264038086}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [3200/4000 (2%)]\tLoss: 0.000246 \t result: {'loss': 20.616357803344727}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Train Epoch: 39 [3840/4000 (3%)]\tLoss: 0.000090 \t result: {'loss': 21.5340576171875}\n",
      "[01/22/2024 06:31:03 PM : DEBUG : model_trai : ] : Epoch: 39 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:04 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:04 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [0/4000 (0%)]\tLoss: 0.000153 \t result: {'loss': 20.01972198486328}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [640/4000 (0%)]\tLoss: 0.000181 \t result: {'loss': 13.779060363769531}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [1280/4000 (1%)]\tLoss: 0.000301 \t result: {'loss': 18.50310516357422}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [1920/4000 (2%)]\tLoss: 0.000230 \t result: {'loss': 19.498350143432617}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [2560/4000 (2%)]\tLoss: 0.000050 \t result: {'loss': 20.53926658630371}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [3200/4000 (2%)]\tLoss: 0.000095 \t result: {'loss': 19.93233871459961}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 40 [3840/4000 (3%)]\tLoss: 0.000093 \t result: {'loss': 21.02049446105957}\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Epoch: 40 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:04 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:04 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:04 PM : DEBUG : model_trai : ] : Train Epoch: 41 [0/4000 (0%)]\tLoss: 0.000221 \t result: {'loss': 17.16120147705078}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 41 [640/4000 (0%)]\tLoss: 0.000087 \t result: {'loss': 22.87545394897461}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 41 [1280/4000 (1%)]\tLoss: 0.000066 \t result: {'loss': 22.85460662841797}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 41 [1920/4000 (2%)]\tLoss: 0.000236 \t result: {'loss': 20.430999755859375}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 41 [2560/4000 (2%)]\tLoss: 0.000126 \t result: {'loss': 16.43301010131836}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 41 [3200/4000 (2%)]\tLoss: 0.000127 \t result: {'loss': 17.94009017944336}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 41 [3840/4000 (3%)]\tLoss: 0.000180 \t result: {'loss': 22.613950729370117}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Epoch: 41 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:05 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:05 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 42 [0/4000 (0%)]\tLoss: 0.000081 \t result: {'loss': 21.18671989440918}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 42 [640/4000 (0%)]\tLoss: 0.000131 \t result: {'loss': 22.66044044494629}\n",
      "[01/22/2024 06:31:05 PM : DEBUG : model_trai : ] : Train Epoch: 42 [1280/4000 (1%)]\tLoss: 0.000168 \t result: {'loss': 22.007762908935547}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 42 [1920/4000 (2%)]\tLoss: 0.000032 \t result: {'loss': 23.845672607421875}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 42 [2560/4000 (2%)]\tLoss: 0.000049 \t result: {'loss': 20.192720413208008}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 42 [3200/4000 (2%)]\tLoss: 0.000172 \t result: {'loss': 17.127044677734375}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 42 [3840/4000 (3%)]\tLoss: 0.000123 \t result: {'loss': 23.5059757232666}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Epoch: 42 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:06 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:06 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 43 [0/4000 (0%)]\tLoss: 0.000243 \t result: {'loss': 20.284019470214844}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 43 [640/4000 (0%)]\tLoss: 0.000114 \t result: {'loss': 20.404619216918945}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 43 [1280/4000 (1%)]\tLoss: 0.000194 \t result: {'loss': 16.58615493774414}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 43 [1920/4000 (2%)]\tLoss: 0.000198 \t result: {'loss': 21.249969482421875}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 43 [2560/4000 (2%)]\tLoss: 0.000110 \t result: {'loss': 22.793411254882812}\n",
      "[01/22/2024 06:31:06 PM : DEBUG : model_trai : ] : Train Epoch: 43 [3200/4000 (2%)]\tLoss: 0.000155 \t result: {'loss': 19.339113235473633}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 43 [3840/4000 (3%)]\tLoss: 0.000100 \t result: {'loss': 29.46660614013672}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Epoch: 43 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:07 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:07 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [0/4000 (0%)]\tLoss: 0.000034 \t result: {'loss': 19.151935577392578}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [640/4000 (0%)]\tLoss: 0.000107 \t result: {'loss': 22.735660552978516}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [1280/4000 (1%)]\tLoss: 0.000061 \t result: {'loss': 24.23573875427246}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [1920/4000 (2%)]\tLoss: 0.000134 \t result: {'loss': 19.08676528930664}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [2560/4000 (2%)]\tLoss: 0.000141 \t result: {'loss': 19.98723030090332}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [3200/4000 (2%)]\tLoss: 0.000148 \t result: {'loss': 19.17741584777832}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Train Epoch: 44 [3840/4000 (3%)]\tLoss: 0.000098 \t result: {'loss': 26.583389282226562}\n",
      "[01/22/2024 06:31:07 PM : DEBUG : model_trai : ] : Epoch: 44 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:08 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:08 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [0/4000 (0%)]\tLoss: 0.000053 \t result: {'loss': 23.756624221801758}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [640/4000 (0%)]\tLoss: 0.000092 \t result: {'loss': 23.05682373046875}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [1280/4000 (1%)]\tLoss: 0.000103 \t result: {'loss': 21.48088836669922}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [1920/4000 (2%)]\tLoss: 0.000110 \t result: {'loss': 27.409683227539062}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [2560/4000 (2%)]\tLoss: 0.000030 \t result: {'loss': 24.087724685668945}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [3200/4000 (2%)]\tLoss: 0.000153 \t result: {'loss': 20.26629638671875}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 45 [3840/4000 (3%)]\tLoss: 0.000083 \t result: {'loss': 18.216293334960938}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Epoch: 45 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:08 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:08 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 46 [0/4000 (0%)]\tLoss: 0.000109 \t result: {'loss': 19.72734832763672}\n",
      "[01/22/2024 06:31:08 PM : DEBUG : model_trai : ] : Train Epoch: 46 [640/4000 (0%)]\tLoss: 0.000067 \t result: {'loss': 21.69753646850586}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 46 [1280/4000 (1%)]\tLoss: 0.000103 \t result: {'loss': 17.034387588500977}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 46 [1920/4000 (2%)]\tLoss: 0.000054 \t result: {'loss': 20.419212341308594}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 46 [2560/4000 (2%)]\tLoss: 0.000049 \t result: {'loss': 20.6086368560791}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 46 [3200/4000 (2%)]\tLoss: 0.000061 \t result: {'loss': 20.1924991607666}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 46 [3840/4000 (3%)]\tLoss: 0.000103 \t result: {'loss': 20.070659637451172}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Epoch: 46 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:09 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.549\n",
      "[01/22/2024 06:31:09 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 47 [0/4000 (0%)]\tLoss: 0.000164 \t result: {'loss': 21.75844955444336}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 47 [640/4000 (0%)]\tLoss: 0.000063 \t result: {'loss': 22.961395263671875}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 47 [1280/4000 (1%)]\tLoss: 0.000068 \t result: {'loss': 21.945873260498047}\n",
      "[01/22/2024 06:31:09 PM : DEBUG : model_trai : ] : Train Epoch: 47 [1920/4000 (2%)]\tLoss: 0.000148 \t result: {'loss': 19.267078399658203}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 47 [2560/4000 (2%)]\tLoss: 0.000267 \t result: {'loss': 20.4921875}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 47 [3200/4000 (2%)]\tLoss: 0.000057 \t result: {'loss': 21.72235679626465}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 47 [3840/4000 (3%)]\tLoss: 0.000114 \t result: {'loss': 20.097702026367188}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Epoch: 47 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:10 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:10 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 48 [0/4000 (0%)]\tLoss: 0.000224 \t result: {'loss': 15.979266166687012}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 48 [640/4000 (0%)]\tLoss: 0.000320 \t result: {'loss': 23.968467712402344}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 48 [1280/4000 (1%)]\tLoss: 0.000150 \t result: {'loss': 19.919729232788086}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 48 [1920/4000 (2%)]\tLoss: 0.000186 \t result: {'loss': 23.000131607055664}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 48 [2560/4000 (2%)]\tLoss: 0.000097 \t result: {'loss': 23.151155471801758}\n",
      "[01/22/2024 06:31:10 PM : DEBUG : model_trai : ] : Train Epoch: 48 [3200/4000 (2%)]\tLoss: 0.000085 \t result: {'loss': 23.15167236328125}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 48 [3840/4000 (3%)]\tLoss: 0.000030 \t result: {'loss': 20.055091857910156}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Epoch: 48 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:11 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:11 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [0/4000 (0%)]\tLoss: 0.000069 \t result: {'loss': 24.64996337890625}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [640/4000 (0%)]\tLoss: 0.000067 \t result: {'loss': 20.830764770507812}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [1280/4000 (1%)]\tLoss: 0.000077 \t result: {'loss': 23.9278621673584}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [1920/4000 (2%)]\tLoss: 0.000136 \t result: {'loss': 20.138273239135742}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [2560/4000 (2%)]\tLoss: 0.000168 \t result: {'loss': 21.429943084716797}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [3200/4000 (2%)]\tLoss: 0.000041 \t result: {'loss': 19.492422103881836}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Train Epoch: 49 [3840/4000 (3%)]\tLoss: 0.000218 \t result: {'loss': 20.192058563232422}\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Epoch: 49 Training Error : 0.0000 , Training Loss : 0.0000\n",
      "[01/22/2024 06:31:11 PM : INFO  : model_trai : ] : Current Model Validation Accuracy: 0.55\n",
      "[01/22/2024 06:31:11 PM : INFO  : model_trai : ] : Best Model Validation Accuracy: 0.552\n",
      "[01/22/2024 06:31:11 PM : DEBUG : model_trai : ] : Average training loss : 0.012790608320075322\n",
      "[01/22/2024 06:31:11 PM : INFO  : model_trai : ] : Loading best model from path: None\n",
      "[01/22/2024 06:31:12 PM : INFO  : model_trai : ] : Loading best model from path: None\n",
      "[01/22/2024 06:31:12 PM : DEBUG : model_trai : ] : Validation accuracy from epoch loop : 0.552\n",
      "[01/22/2024 06:31:12 PM : DEBUG : model_trai : ] : Validation accuracy after loaded : 0.552\n",
      "[01/22/2024 06:31:12 PM : INFO  : passive_le : ] : --------------- End Model Training ------------\n",
      "[01/22/2024 06:31:12 PM : INFO  : passive_le : ] : Test error of the model : 46.11\n",
      "[01/22/2024 06:31:12 PM : INFO  : 996596987 : ] : =========================    No Post-hoc Calibration     =========================\n",
      "[01/22/2024 06:31:12 PM : INFO  : auto_label : ] : xxxxxxxxxxxxxxxxxxxxx  Auto-labeling actual remaining unlabeled data  xxxxxxxxxxxxxxxxxxxxx\n",
      "[01/22/2024 06:31:12 PM : INFO  : auto_label : ] : ========================= Begin Auto-Labeling selective ==========================\n",
      "[01/22/2024 06:31:12 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:31:12 PM : INFO  : auto_label : ] : Number of unlabeled points : 36000\n",
      "[01/22/2024 06:31:12 PM : INFO  : data_manag : ] :  Cur calib ds size : 0\n",
      "[01/22/2024 06:31:12 PM : INFO  : auto_label : ] : Using number of validation points : 1000\n",
      "[01/22/2024 06:31:12 PM : INFO  : auto_label : ] : Using Auto-Labeling Error Threshold = 0.05\n",
      "[01/22/2024 06:31:12 PM : DEBUG : auto_label : ] : Expected Calibration Error on Validation set : 0.34148314741253855\n",
      "[01/22/2024 06:31:12 PM : INFO  : auto_label : ] : Determining Thresholds : Class Wise : independent\n",
      "[01/22/2024 06:31:12 PM : DEBUG : threshold_ : ] : C_1 = 0.25 UCB = sigma\n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 0   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=0.9998781681060791 for class 1   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 2   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 3   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 4   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 5   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 6   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 7   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 8   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : auto-labeling threshold t_i=inf for class 9   \n",
      "[01/22/2024 06:31:12 PM : INFO  : threshold_ : ] : coverage while threshold estimation : 0.025\n",
      "[01/22/2024 06:31:12 PM : INFO  : auto_label : ] : auto-labeling thresholds from val set: [inf, 0.99987817, inf, inf, inf, inf, inf, inf, inf, inf]\n",
      "[01/22/2024 06:31:14 PM : INFO  : auto_label : ] : Num auto labeled points : 1179 \n",
      "[01/22/2024 06:31:14 PM : INFO  : auto_label : ] : Num validation pts to remove : 25\n",
      "[01/22/2024 06:31:14 PM : INFO  : auto_label : ] : ============================== Done Auto-Labeling ==============================\n",
      "[01/22/2024 06:31:14 PM : INFO  : 996596987 : ] :  Selective Auto-labeling counts: {'auto_labeled_acc': 0.8931297709923665, 'coverage_1': 0.029475, 'coverage_2': 0}\n"
     ]
    }
   ],
   "source": [
    "pl, calib, dm, counts = run_conf_2(conf,None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "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=(0,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=(0,1.05), fill=p['fill'],label='Incorrect',linewidth=2.0,alpha=0.4)\n",
    "\n",
    "    elif(plot_type['name']=='hist2'):\n",
    "        binwidth=0.05\n",
    "        sns.histplot(np.clip(scores[correct_idcs],0,1),ax=ax, element=\"step\", fill=True,label='Correct' , stat=\"probability\",binwidth=binwidth)\n",
    "        sns.histplot(np.clip(scores[incorrect_idcs],0,1),ax=ax, element=\"step\", fill=True,label='Incorrect', stat=\"probability\",binwidth=binwidth)\n",
    "        \n",
    "    ax.legend(loc='upper left')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "params = {'legend.fontsize': 'x-large',\n",
    "          'figure.figsize': (15, 5),\n",
    "         'axes.labelsize': 'x-large',\n",
    "         'axes.titlesize':'x-large',\n",
    "         'xtick.labelsize':'x-large',\n",
    "         'ytick.labelsize':'x-large'}\n",
    "plt.rcParams.update(params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "36000\n"
     ]
    },
    {
     "data": {
      "image/png": "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d+4cv/32m9/nA3z33Xd+na/X63E6QyM7EKI+3O3GZqOu0j+ETV5V2UX20Pg30WwD86FDh1i5ciUREREMGTKkVu/94YcfmDx5Ms888wyTJ0+mb9++DBs2jMOHD9f4XpvNRn5+vs9LNA1334L777/fU13t5nK5PJkwwKRJk1BVlccff9wnoJ0+fdozRnjSpEkBK9ujjz4KwL333svx4xXnQLdYLJ52ZYDrr7+etLQ0li5dyr/+9a8K57t7Zbu1bt2aU6dOUVxcHLAyCxGM3FXZlVVja/ul81dQsNls3HnnndhsNv7617/SqlUrv94XERHBc889xw033EDnzp0B2LFjB+np6WRkZDBixAi2bdtGZGRkldeYM2dOje2G9WLN16a/DDbW4PsD5J577uGnn35i4cKFdOvWjdGjR5OYmMjx48f58ccfmTRpkqcvwWOPPcZ3333H119/Td++fRk1ahRFRUUsWrSInJwcnnjiCQYNGhSwso0YMYK//OUvTJ8+nW7dujFq1Cg6depEYWEhhw4dYvXq1QwaNIjly5cDYDKZWLRoESNHjuSOO+7g7bffZsCAAVitVjIzM1m5ciUlJSU+1//ll1+4+uqrGTJkCGazmb59+3L99dcH7B6ECAbuYOudGXsLxYy52QVmp9PJ+PHjWbt2LbfddhuPPfaY3+9NSkpi1qxZPvuGDBnCihUrGDRoEBs3buS9997jkUceqfIa06dPZ9q0aZ7v8/PzSUlJqf2NVEmVOan9pCgKH3/8MVdddRXvvPMO//73v7HZbLRt25bBgwfzhz/8wXOuyWTihx9+4OWXX+af//wnr732GgaDgb59+/LKK69w++23B7x8Tz75JJdffjmvvvoqP//8M19//TWxsbG0b9+e++67r8KwqP79+7Nt2zb+8pe/8N1337Fu3Tqio6Pp2rVrhZ/bZ599ltzcXP7zn/+wdu1anE4nd999twRm0ay4XCqW0mBr9iMwS8bcBJxOJ+PGjWPRokXceuutfPLJJwFZScRgMHDPPfewceNG1qxZU21gNpvN1Q6fqbOopMBfsyEEoJyVrSqVlpZW7WpT3tNclnfnnXdy55131vi5YWFhPP300zz99NM1nltTeWo67jZo0KBaZeIdO3bkjTfeqPG8yMhI3nzzTd58802/ry1EqClylGXAVQVms14y5ibjcDi48847WbRoEXfc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o4QQQrRwRfWYJ9ut2WfM69evZ8SIEZ7Vo1wuF2+88QY9e/bk8OHDbNq0icjISObPnx+QwgohhGi56rMWs1uzb2M+efKkzyQj27Zt4/Tp0zz44IN06NCB/v37M3r0aH755Zd6F1QIIUTLVlTPebLLv69ZZswOh8NnHNnatWtRFIXhw4d79nXo0IETJ07U52OEEEIICuu5shT4ZszFQTpfdr0Cc4cOHdixY4fn+2XLlpGQkECvXr08+3JycoiJianPxwghhBA+bcx1zph9AnNwLv1Yr85f1113HfPnz+exxx4jLCyMH374gYkTJ/qcs2fPHplTWwghRL15tzGb6zqO2atXdpEjODPmegXmJ554giVLlvDyyy8D0L59e2bOnOk5npOTw/r165kyZUr9SimEEKLFKwpA5y/vjNnaHDt/JSUl8euvv7J06VKWLl3K77//Trt27TzHT58+zd/+9jfuueeeehe0Oh9++CGKolT70vs55i0tLa3Ka7Rp06ZB70MIIUTVfJd8rOM45hDolV3vZTXCw8O57rrrKj123nnncd5559X3I2rUr18/ZsyYUemxn376iR9//JFrrrnG7+vFxsYyderUCvujoqLqWkQhhBD1ZAlA569Q6JUdfOtd1UG/fv3o169fpccuu+wyAO677z6/rxcXF+f3yllCCCEahyUAw6WM5ZZ9DEb1Dsxnz57lgw8+YNOmTZw7dw6ns+KNKorCypUr6/tRtfbrr7+yYcMG2rdvz7XXXtvony+EECJwigKRMYfAzF/1Csy7du3iiiuu4NSpU6iqWuV5dVkzMxDeeecdAP74xz/63cYMYLPZ+OSTTzh8+DCRkZH06dOHIUOG1OoaQgghAisQGbNB79UruzlmzI899hg5OTk89dRT3HfffaSkpARN8CouLuaTTz5Br9fXuvNZdnY248eP99nXqVMnFixYUONSlzabDZvN5vk+Pz+/Vp8thBCict5tzHVd9lGnKBj1Cg6nGrTrMderV/ZPP/3Etddey4svvkhaWlrQBGWAf//73+Tm5nL11VeTkpLi9/smTpzIypUryc7OxmKx8Ouvv3L//feTlZXFNddcw/bt26t9/5w5c4iNjfW8avPZQgghquY981eYse7xxt3OHKwZc70Cs6qqjdLrui7c1dj3339/rd43Y8YMhg8fTnJyMhEREfTu3Zu33nqLadOm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DK688kpcLheTJk0iJSWlwufExcUxderUBr+fxhKI51aVDz/8kIkTJ/LMM88we/bsBruHphCo55afn8/QoUPZtm0bl156KZdffjknT57kyy+/pLi4mFdeeYVHHnmkUe+toQTqmU2aNIkFCxZgMpm48cYbSU1NJSsriyVLlmC325k6dSrz589v1HtrSEuWLGHJkiUAZGdn8/3339O5c2cGDx4MQEJCAnPnzgW0jpidOnXyPBNvtX3+TaYp/yoQgXf48GF1woQJaps2bVSj0ah27NhRfeSRR9SzZ89WOBdQy/8IuDO86l6pqamNdDeNp77PrSrNOWNW1cA9t4KCAvXpp59Wu3XrpppMJjU2Nlb93//9X/X7779v6FtodIF4Zi6XS12wYIE6dOhQNS4uTtXr9WqrVq3U4cOHq//6178a4zYa1YwZM/z+nXTw4MFqf0/V5vk3FcmYhRBCiCAivbKFEEKIICKBWQghhAgiEpiFEEKIICKBWQghhAgiEpiFEEKIICKBWQghhAgiEpiFEEKIICKBWQghhAgiEpiFEEKIICKBWQghhAgiEpiFEEKIICKBWQghhAgi/x/s4cG/USbPkgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.ticker import PercentFormatter\n",
    "\n",
    "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})\n",
    "#visualize_scores_dist(axs, inf_out, plot_type={\"name\":\"hist2\",\"fill\":True})\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": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle \n",
    "with open('../../outputs/figure-2/cifar10-med-net-std-xent_inf_out_unlbld.pkl',\"wb\") as f :\n",
    "    pickle.dump(inf_out, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "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)"
   ]
  },
  {
   "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
}
