{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'name': 'cora', 'dict_size': 1000, 'epoch': 10, 'batch_size': 64, 'eval_step': 5, 'eval_batch_size': 128, 'self_feature': 'no', 'n_theta_nonzero': 40, 'lam2': 10, 'base_k': 4, 'O_loop_cnt': 1, 'O_resample_method': 'greedy', 'O_warmup': 0, 'O_resample_step': 5, 'h_model': 'SGC', 'feature_normalize': 'row_sum'}\n"
     ]
    }
   ],
   "source": [
    "\"\"\"\n",
    "Sparse Decomposition of Message Passing based on Dictionary Learning\n",
    "\n",
    "Created by: Yaochen Hu\n",
    "Created on: May 1, 2023\n",
    "\n",
    "\"\"\"\n",
    "# pylint: disable=anomalous-backslash-in-string\n",
    "# pylint: disable=invalid-name\n",
    "# pylint: disable=import-error\n",
    "# pylint: disable=missing-function-docstring\n",
    "import os\n",
    "import sys\n",
    "sys.path.extend([\"../\"]) # pylint: disable=wrong-import-position\n",
    "import random\n",
    "from time import time\n",
    "import warnings\n",
    "import pickle\n",
    "import datetime\n",
    "import socket\n",
    "\n",
    "import shutil\n",
    "import yaml\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "from sklearn import linear_model\n",
    "\n",
    "from data_utils import *\n",
    "from graph_dict import *\n",
    "from utils import *\n",
    "from model import SAGE\n",
    "\n",
    "warnings.filterwarnings('ignore')\n",
    "os.environ[\"CURL_CA_BUNDLE\"] = \"\"\n",
    "DEVICE = 'cuda:1'\n",
    "\n",
    "%load_ext line_profiler\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "# %lprun -f\n",
    "\n",
    "# Parameter settings and data loading\n",
    "DATA_ROOT_FOLDER = \"../dataset\"\n",
    "CONF_ROOT_FOLDER = \"../config\"\n",
    "RES_ROOT_FOLDER = \"../result\"\n",
    "\n",
    "\n",
    "#############################################\n",
    "# corasgc\n",
    "# CONF_NAME = \"cora/SDMP_dict/cora_SDMP_dict_base.yml\"\n",
    "# CONF_NAME = \"cora/SDMP_dict/cora_SDMP_dict_dictsize_50.yml\"\n",
    "# CONF_NAME = \"cora/SDMP_dict/cora_SDMP_dict_SGC_test.yml\"\n",
    "CONF_NAME = \"cora/SDMP_dict/cora_SDMP_dict_SGC_test_O.yml\"\n",
    "# # pubmed\n",
    "# CONF_NAME = \"pubmed/SDMP_dict/pubmed_SDMP_dict_base.yml\"\n",
    "# CONF_NAME = \"pubmed/SDMP_dict/pubmed_SDMP_dict_SGC_dictsize_200.yml\"\n",
    "# # reddit\n",
    "# # OGBN-products\n",
    "# CONF_NAME = \"\"\n",
    "\n",
    "#######################################\n",
    "# Initialization and hyper-parameter setting\n",
    "_TIME_ZONE = 0\n",
    "TIMESTAMP = time()\n",
    "TIMESTAMP_FORMATTED = datetime.datetime.fromtimestamp(\n",
    "    int(TIMESTAMP)+_TIME_ZONE*3600).strftime('%Y%m%d-%H%M%S')\n",
    "HOST_NAME = socket.gethostname()\n",
    "\n",
    "conf_path = os.path.join(CONF_ROOT_FOLDER, CONF_NAME)\n",
    "train_conf = load_train_conf(conf_path)\n",
    "\n",
    "DATA_FOLDER = os.path.join(DATA_ROOT_FOLDER, train_conf[\"name\"])\n",
    "if not os.path.exists(DATA_FOLDER):\n",
    "    os.makedirs(DATA_FOLDER)\n",
    "\n",
    "# sys.stdout = Logger(os.path.join(RES_FOLDER, \"log.txt\"))\n",
    "\n",
    "print(train_conf)\n",
    "\n",
    "######################################\n",
    "h_model_path = os.path.join(RES_ROOT_FOLDER, train_conf[\"name\"], train_conf['h_model'], 'model_stat')\n",
    "h_conf_path = os.path.join(RES_ROOT_FOLDER, train_conf[\"name\"], train_conf['h_model'], 'train_conf.yml')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading cache from ../dataset/cora/SDMPPre with prefix SGC...\n",
      "Finished loading in 0.0 s.\n"
     ]
    }
   ],
   "source": [
    "# prepare the dataexclude\n",
    "preprocesser = SDMPDataPre(train_conf[\"name\"],\n",
    "                           h_conf_path, h_model_path, train_conf[\"h_model\"],\n",
    "                           base_k=train_conf[\"base_k\"], train_conf = train_conf,\n",
    "                           use_cache=True, cache_path=os.path.join(DATA_FOLDER, \"SDMPPre\"), device=DEVICE)\n",
    "all_h, target, A = preprocesser.all_h, preprocesser.target, preprocesser.A"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initializing the model...\n",
      "starting to fit...\n",
      "!!!!!!!!!! DEBUGGING FITTING!!!!!!!!!!\n",
      "Initializing...\n",
      "Loading Theta and O directly..\n",
      "Training started...\n",
      "    Regret: 10.6799 | Rel Regret: 0.1370 | W Rel Regret: 0.1370 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2708.000 ± 0.000\n",
      "---------------------------\n",
      "\n",
      "-----\n",
      "Epoch: 0 | Iter: 4 | Global iter: 5 Elapsed time: 0.6 | ETA: 55.2\n",
      "    Regret: 9.7296 | Rel Regret: 0.1260 | W Rel Regret: 0.1260 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2707.413 ± 0.757\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 9 | Global iter: 10 Elapsed time: 1.3 | ETA: 53.8\n",
      "    Regret: 9.3012 | Rel Regret: 0.1210 | W Rel Regret: 0.1210 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2706.817 ± 1.052\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 14 | Global iter: 15 Elapsed time: 1.9 | ETA: 52.8\n",
      "    Regret: 9.0403 | Rel Regret: 0.1180 | W Rel Regret: 0.1180 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2706.206 ± 1.332\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 19 | Global iter: 20 Elapsed time: 2.5 | ETA: 52.1\n",
      "    Regret: 8.8618 | Rel Regret: 0.1159 | W Rel Regret: 0.1159 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2705.623 ± 1.537\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 24 | Global iter: 25 Elapsed time: 3.2 | ETA: 51.3\n",
      "    Regret: 8.7315 | Rel Regret: 0.1144 | W Rel Regret: 0.1144 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2705.062 ± 1.728\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 29 | Global iter: 30 Elapsed time: 4.0 | ETA: 52.7\n",
      "    Regret: 8.6324 | Rel Regret: 0.1133 | W Rel Regret: 0.1133 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2704.465 ± 1.890\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 34 | Global iter: 35 Elapsed time: 4.8 | ETA: 54.3\n",
      "    Regret: 8.5546 | Rel Regret: 0.1124 | W Rel Regret: 0.1124 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2703.877 ± 2.057\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. -----\n",
      "Epoch: 0 | Iter: 39 | Global iter: 40 Elapsed time: 5.7 | ETA: 55.2\n",
      "    Regret: 8.4918 | Rel Regret: 0.1117 | W Rel Regret: 0.1117 || Theta col nonzeros: 19.954 ± 12.363 | O row nonzeros: 2703.260 ± 2.186\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1. Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 1 | Global iter: 45 Elapsed time: 6.7 | ETA: 57.2\n",
      "    Regret: 4.7134 | Rel Regret: 0.0870 | W Rel Regret: 0.0870 || Theta col nonzeros: 19.182 ± 12.445 | O row nonzeros: 2703.011 ± 2.630\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.2\n",
      " | O pre 0.0 | O update 0.1. Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 6 | Global iter: 50 Elapsed time: 7.4 | ETA: 56.4\n",
      "    Regret: 4.4552 | Rel Regret: 0.0860 | W Rel Regret: 0.0860 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2605.668 ± 17.825\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.1\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 64\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 11 | Global iter: 55 Elapsed time: 8.1 | ETA: 55.1\n",
      "    Regret: 4.4513 | Rel Regret: 0.0858 | W Rel Regret: 0.0858 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2508.725 ± 30.071\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 3\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 16 | Global iter: 60 Elapsed time: 8.8 | ETA: 54.2\n",
      "    Regret: 4.4484 | Rel Regret: 0.0857 | W Rel Regret: 0.0857 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2412.228 ± 42.736\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 21 | Global iter: 65 Elapsed time: 9.7 | ETA: 54.4\n",
      "    Regret: 4.4461 | Rel Regret: 0.0856 | W Rel Regret: 0.0856 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2315.762 ± 55.208\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 26 | Global iter: 70 Elapsed time: 10.6 | ETA: 54.4\n",
      "    Regret: 4.4443 | Rel Regret: 0.0855 | W Rel Regret: 0.0855 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2220.363 ± 68.204\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 31 | Global iter: 75 Elapsed time: 11.5 | ETA: 54.3\n",
      "    Regret: 4.4427 | Rel Regret: 0.0855 | W Rel Regret: 0.0855 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2126.755 ± 80.296\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 36 | Global iter: 80 Elapsed time: 12.3 | ETA: 54.0\n",
      "    Regret: 4.4414 | Rel Regret: 0.0854 | W Rel Regret: 0.0854 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 2034.981 ± 92.563\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 1 | Iter: 41 | Global iter: 85 Elapsed time: 13.1 | ETA: 53.3\n",
      "    Regret: 4.4404 | Rel Regret: 0.0854 | W Rel Regret: 0.0854 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1944.413 ± 104.339\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 3 | Global iter: 90 Elapsed time: 14.0 | ETA: 52.8\n",
      "    Regret: 4.4394 | Rel Regret: 0.0853 | W Rel Regret: 0.0853 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1855.820 ± 116.114\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 8 | Global iter: 95 Elapsed time: 14.9 | ETA: 52.4\n",
      "    Regret: 4.4387 | Rel Regret: 0.0853 | W Rel Regret: 0.0853 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1769.431 ± 127.582\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 13 | Global iter: 100 Elapsed time: 15.7 | ETA: 52.0\n",
      "    Regret: 4.4380 | Rel Regret: 0.0853 | W Rel Regret: 0.0853 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1685.435 ± 138.380\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 18 | Global iter: 105 Elapsed time: 16.6 | ETA: 51.5\n",
      "    Regret: 4.4375 | Rel Regret: 0.0853 | W Rel Regret: 0.0853 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1603.987 ± 148.944\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 23 | Global iter: 110 Elapsed time: 17.6 | ETA: 51.1\n",
      "    Regret: 4.4370 | Rel Regret: 0.0853 | W Rel Regret: 0.0853 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1524.931 ± 159.696\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 28 | Global iter: 115 Elapsed time: 18.4 | ETA: 50.3\n",
      "    Regret: 4.4366 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1448.247 ± 169.996\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 33 | Global iter: 120 Elapsed time: 19.2 | ETA: 49.7\n",
      "    Regret: 4.4363 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1374.818 ± 179.703\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 2 | Iter: 38 | Global iter: 125 Elapsed time: 20.1 | ETA: 49.1\n",
      "    Regret: 4.4360 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1304.226 ± 188.729\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 0 | Global iter: 130 Elapsed time: 20.9 | ETA: 48.3\n",
      "    Regret: 4.4358 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1236.619 ± 197.960\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 5 | Global iter: 135 Elapsed time: 21.6 | ETA: 47.2\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1171.723 ± 206.466\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 10 | Global iter: 140 Elapsed time: 22.3 | ETA: 46.1\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1109.777 ± 214.960\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 15 | Global iter: 145 Elapsed time: 23.1 | ETA: 45.4\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 1050.947 ± 222.837\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 20 | Global iter: 150 Elapsed time: 24.0 | ETA: 44.8\n",
      "    Regret: 4.4353 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 995.144 ± 230.272\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 25 | Global iter: 155 Elapsed time: 24.9 | ETA: 44.1\n",
      "    Regret: 4.4352 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 942.408 ± 237.581\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 30 | Global iter: 160 Elapsed time: 25.8 | ETA: 43.5\n",
      "    Regret: 4.4352 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 892.205 ± 244.426\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 35 | Global iter: 165 Elapsed time: 26.7 | ETA: 42.9\n",
      "    Regret: 4.4351 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 845.080 ± 250.520\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 3 | Iter: 40 | Global iter: 170 Elapsed time: 27.6 | ETA: 42.2\n",
      "    Regret: 4.4351 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 801.140 ± 256.266\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 2 | Global iter: 175 Elapsed time: 28.4 | ETA: 41.4\n",
      "    Regret: 4.4351 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 760.125 ± 261.551\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 7 | Global iter: 180 Elapsed time: 29.3 | ETA: 40.7\n",
      "    Regret: 4.4351 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 721.703 ± 266.353\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 12 | Global iter: 185 Elapsed time: 30.3 | ETA: 40.1\n",
      "    Regret: 4.4351 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 685.967 ± 271.044\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 17 | Global iter: 190 Elapsed time: 31.1 | ETA: 39.2\n",
      "    Regret: 4.4352 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 652.812 ± 275.394\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 22 | Global iter: 195 Elapsed time: 31.8 | ETA: 38.3\n",
      "    Regret: 4.4352 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 622.218 ± 279.352\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 27 | Global iter: 200 Elapsed time: 32.6 | ETA: 37.4\n",
      "    Regret: 4.4352 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 594.022 ± 283.063\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 32 | Global iter: 205 Elapsed time: 33.3 | ETA: 36.6\n",
      "    Regret: 4.4353 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 568.004 ± 286.443\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 37 | Global iter: 210 Elapsed time: 34.1 | ETA: 35.7\n",
      "    Regret: 4.4353 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 543.988 ± 289.532\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 4 | Iter: 42 | Global iter: 215 Elapsed time: 34.8 | ETA: 34.8\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 522.092 ± 292.346\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 4 | Global iter: 220 Elapsed time: 35.6 | ETA: 34.0\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 501.688 ± 295.063\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 9 | Global iter: 225 Elapsed time: 36.3 | ETA: 33.1\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 483.511 ± 297.086\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 14 | Global iter: 230 Elapsed time: 37.1 | ETA: 32.3\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 467.026 ± 299.160\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 19 | Global iter: 235 Elapsed time: 37.8 | ETA: 31.4\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 451.978 ± 301.067\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 24 | Global iter: 240 Elapsed time: 38.6 | ETA: 30.6\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 438.478 ± 302.783\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 29 | Global iter: 245 Elapsed time: 39.4 | ETA: 29.7\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 426.078 ± 304.298\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 34 | Global iter: 250 Elapsed time: 40.1 | ETA: 28.9\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 414.905 ± 305.604\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 5 | Iter: 39 | Global iter: 255 Elapsed time: 40.9 | ETA: 28.0\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 405.152 ± 306.688\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 1 | Global iter: 260 Elapsed time: 41.7 | ETA: 27.3\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 396.017 ± 307.577\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 6 | Global iter: 265 Elapsed time: 42.6 | ETA: 26.6\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 387.866 ± 308.603\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 11 | Global iter: 270 Elapsed time: 43.5 | ETA: 25.8\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 380.643 ± 309.454\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 16 | Global iter: 275 Elapsed time: 44.4 | ETA: 25.0\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 374.523 ± 310.040\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 21 | Global iter: 280 Elapsed time: 45.3 | ETA: 24.3\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 369.082 ± 310.612\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 26 | Global iter: 285 Elapsed time: 46.2 | ETA: 23.5\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 364.162 ± 311.156\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 31 | Global iter: 290 Elapsed time: 47.1 | ETA: 22.7\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 359.709 ± 311.642\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 36 | Global iter: 295 Elapsed time: 47.9 | ETA: 21.9\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 355.895 ± 312.012\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 6 | Iter: 41 | Global iter: 300 Elapsed time: 48.8 | ETA: 21.2\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 352.608 ± 312.363\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 3 | Global iter: 305 Elapsed time: 49.7 | ETA: 20.4\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 349.759 ± 312.656\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 8 | Global iter: 310 Elapsed time: 50.6 | ETA: 19.6\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 347.131 ± 312.883\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 13 | Global iter: 315 Elapsed time: 51.2 | ETA: 18.7\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 344.984 ± 313.107\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 18 | Global iter: 320 Elapsed time: 51.9 | ETA: 17.8\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 343.041 ± 313.268\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 23 | Global iter: 325 Elapsed time: 52.8 | ETA: 17.1\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 341.351 ± 313.341\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 28 | Global iter: 330 Elapsed time: 53.7 | ETA: 16.3\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 339.833 ± 313.398\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 33 | Global iter: 335 Elapsed time: 54.5 | ETA: 15.5\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 338.502 ± 313.438\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 7 | Iter: 38 | Global iter: 340 Elapsed time: 55.4 | ETA: 14.7\n",
      "    Regret: 4.4357 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 337.367 ± 313.499\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 0 | Global iter: 345 Elapsed time: 56.3 | ETA: 13.9\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 336.388 ± 313.577\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 5 | Global iter: 350 Elapsed time: 57.1 | ETA: 13.0\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 335.588 ± 313.532\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 10 | Global iter: 355 Elapsed time: 57.8 | ETA: 12.2\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 334.872 ± 313.498\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 15 | Global iter: 360 Elapsed time: 58.7 | ETA: 11.4\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 334.283 ± 313.445\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 20 | Global iter: 365 Elapsed time: 59.5 | ETA: 10.6\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 333.766 ± 313.425\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 25 | Global iter: 370 Elapsed time: 60.4 | ETA: 9.8\n",
      "    Regret: 4.4356 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 333.326 ± 313.331\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 30 | Global iter: 375 Elapsed time: 61.3 | ETA: 9.0\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 332.965 ± 313.268\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 35 | Global iter: 380 Elapsed time: 62.0 | ETA: 8.2\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 332.607 ± 313.215\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.1 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 8 | Iter: 40 | Global iter: 385 Elapsed time: 62.7 | ETA: 7.3\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 332.293 ± 313.167\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 2 | Global iter: 390 Elapsed time: 63.6 | ETA: 6.5\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 332.033 ± 313.120\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 7 | Global iter: 395 Elapsed time: 64.5 | ETA: 5.7\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 331.827 ± 313.064\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 12 | Global iter: 400 Elapsed time: 65.4 | ETA: 4.9\n",
      "    Regret: 4.4355 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 331.629 ± 312.988\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 17 | Global iter: 405 Elapsed time: 66.3 | ETA: 4.1\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 331.450 ± 312.933\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 22 | Global iter: 410 Elapsed time: 67.2 | ETA: 3.3\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 331.299 ± 312.862\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 27 | Global iter: 415 Elapsed time: 68.0 | ETA: 2.5\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 331.143 ± 312.786\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 32 | Global iter: 420 Elapsed time: 68.9 | ETA: 1.6\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 331.020 ± 312.693\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 37 | Global iter: 425 Elapsed time: 69.8 | ETA: 0.8\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 330.909 ± 312.600\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "Resampling O with greedy...\n",
      "-----\n",
      "Epoch: 9 | Iter: 42 | Global iter: 430 Elapsed time: 70.7 | ETA: 0.0\n",
      "    Regret: 4.4354 | Rel Regret: 0.0852 | W Rel Regret: 0.0852 || Theta col nonzeros: 19.145 ± 12.449 | O row nonzeros: 330.821 ± 312.519\n",
      "    Times: Theta all 0.0 | Theta pre 0.0 | Theta lasso 0.0 | O all 0.2 | O resample 0.0\n",
      " | O pre 0.0 | O update 0.1.  | O resample execute pre 0.0 | O update 0.0. | O resampled count 0\n",
      "---------------------------\n",
      "\n",
      "Started post processing...\n",
      "Post precessing... Recomputing Theta...\n",
      "0.977 finished in 32.4 s. ETA: 0.0 ss\n",
      "Training finished in 103.1 s.\n",
      "    Regret: 4.3760 | Rel Regret: 0.0888 | W Rel Regret: 0.0888 || Theta col nonzeros: 21.579 ± 13.293 | O row nonzeros: 330.821 ± 312.519\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<graph_dict.SDMP at 0x7fe04d4bb610>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "if train_conf['self_feature'] == \"exclude\":\n",
    "    print(\"Projecting the data to remove self component...\")\n",
    "    pre_computer = preSDMP(all_h, target, device=DEVICE)\n",
    "    Omega = pre_computer.get_filtered()\n",
    "else:\n",
    "    Omega = target\n",
    "H = all_h\n",
    "\n",
    "print(\"Initializing the model...\")\n",
    "test = SDMP_dict(H,\n",
    "                 Omega,\n",
    "                 A,\n",
    "                 train_conf[\"dict_size\"],\n",
    "                 epoch=train_conf[\"epoch\"],\n",
    "                 batch_size=train_conf[\"batch_size\"],\n",
    "                 eval_step=train_conf[\"eval_step\"],\n",
    "                 eval_batch_size=train_conf[\"eval_batch_size\"],\n",
    "                 n_theta_nonzero=train_conf[\"n_theta_nonzero\"],\n",
    "                 lam2=train_conf[\"lam2\"],\n",
    "                 O_loop_cnt=train_conf[\"O_loop_cnt\"],\n",
    "                 O_resample_method=train_conf[\"O_resample_method\"],\n",
    "                 O_warmup=train_conf[\"O_warmup\"], \n",
    "                 O_resample_step=train_conf[\"O_resample_step\"],\n",
    "                 HHT=None,\n",
    "                 HHTHHT=None,\n",
    "                 HOmegaT=None,\n",
    "                 F_HHT=None,\n",
    "                 ori_target_square_norm=np.linalg.norm(target, axis=1) ** 2,\n",
    "                 device=DEVICE,\n",
    "                 verbose=True)\n",
    "\n",
    "print(\"starting to fit...\")\n",
    "test.fit_debug()\n",
    "# test.fit()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# test.save(\"../result/test_proximal\")\n",
    "# export_train_conf(os.path.join(\"../result/test_proximal/conf.yml\"), train_conf)\n",
    "test.save(\"../result/test_bcd\")\n",
    "export_train_conf(os.path.join(\"../result/test_bcd/conf.yml\"), train_conf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# save for quick debugging the O phase\n",
    "prefix = \"densetheta\"\n",
    "\n",
    "np.save(\"res/test/theta_\"+prefix, test.Theta)\n",
    "np.save(\"res/test/O_\"+prefix, test.O)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test the correctness of the SGC targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(\"Initializing the model...\")\n",
    "test = SparseDictionaryLearning(A,\n",
    "                                train_conf[\"dict_size\"],\n",
    "                                AF=target,\n",
    "                                F=all_h,\n",
    "                                weighted=True,\n",
    "                                epoch=train_conf[\"epoch\"],\n",
    "                                batch_size=train_conf[\"batch_size\"],\n",
    "                                eval_step=train_conf[\"eval_step\"],\n",
    "                                eval_batch_size=train_conf[\"eval_batch_size\"],\n",
    "                                a_method='max_a_nonzero',\n",
    "                                lam=3.0e-3,\n",
    "                                n_a_nonzero=40,\n",
    "                                shuffle=True,\n",
    "                                num_worker=1,\n",
    "                                O_Q_ST_accurate=True,\n",
    "                                O_loop_cnt=1,\n",
    "                                O_init_method='random_select',\n",
    "                                O_resample_method='greedy',\n",
    "                                O_resample_warmup=5,\n",
    "                                O_resample_step=5,\n",
    "                                O_is_sparsify=False,\n",
    "                                device=DEVICE,\n",
    "                                verbose=True)\n",
    "print(\"starting to fit...\")\n",
    "test.fit()\n",
    "\n",
    "print(\"Sparsifying O...\")\n",
    "test.post_update(O_is_sparsify=True, O_sparsify_conf= {\"max_nonzero\": 1000, \"signal_ratio\": 0.8})\n",
    "test.eval_and_log()\n",
    "test._display_stat()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test the performance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test = SparseDictionaryLearning(A,\n",
    "                                train_conf[\"dict_size\"],\n",
    "                                AF=AF,\n",
    "                                F=features,\n",
    "                                weighted=train_conf[\"weighted\"],\n",
    "                                epoch=train_conf[\"epoch\"],\n",
    "                                batch_size=train_conf[\"batch_size\"],\n",
    "                                eval_step=train_conf[\"eval_step\"],\n",
    "                                eval_batch_size=train_conf[\"eval_batch_size\"],\n",
    "                                a_method=train_conf[\"a_method\"],\n",
    "                                lam=train_conf[\"lam\"],\n",
    "                                n_a_nonzero=train_conf[\"n_a_nonzero\"],\n",
    "                                shuffle=train_conf[\"shuffle\"],\n",
    "                                num_worker=1,\n",
    "                                O_Q_ST_accurate=train_conf[\"O_Q_ST_accurate\"],\n",
    "                                O_loop_cnt=train_conf[\"O_loop_cnt\"],\n",
    "                                O_init_method=train_conf[\"O_init_method\"],\n",
    "                                O_resample_method=train_conf[\"O_resample_method\"],\n",
    "                                O_resample_warmup=train_conf[\"O_resample_warmup\"],\n",
    "                                O_thresh=train_conf[\"O_thresh\"],\n",
    "                                O_is_sparsify=False,\n",
    "                                device=DEVICE,\n",
    "                                verbose=True)\n",
    "test.load(\"../result/test\")\n",
    "test.post_update(O_is_sparsify=True, O_sparsify_conf=train_conf[\"O_sparsify_conf\"])\n",
    "test.eval_and_log()\n",
    "test._display_stat()\n",
    "test.save(\"../result/test_1\")\n",
    "export_train_conf(os.path.join(\"../result/test_1/conf.yml\"), train_conf)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# visualize the results for one test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## plot the loss\n",
    "import matplotlib.pyplot as plt\n",
    "PARAMS = {\n",
    "    'figure.figsize': [10, 6],\n",
    "    # 'figure.dpi': 300,\n",
    "    'font.family': 'serif',\n",
    "    'font.monospace': 'Courier Mono', # Ubuntu Mono\n",
    "    'axes.labelsize': 28,\n",
    "    'axes.titlesize': 28,\n",
    "    'font.size': 28,\n",
    "    'legend.fontsize': 28,\n",
    "    'xtick.labelsize': 28,\n",
    "    'ytick.labelsize': 28,\n",
    "    'figure.titlesize': 28,\n",
    "    'text.usetex': True,\n",
    "    'lines.linewidth': 1.5,\n",
    "    # 'axes.prop_cycle': cycler(color=COLOR_MAP)\n",
    "    }\n",
    "\n",
    "plt.rcParams.update(PARAMS)\n",
    "\n",
    "f, (a1, a2) = plt.subplots(2, 1, gridspec_kw={'height_ratios': [1, 1]}, figsize = (10, 10))\n",
    "\n",
    "a1.plot(test.log['weighted_rel_regret'], linewidth=4)\n",
    "# a1.set_xlabel(\"Batch\")\n",
    "a1.set_ylabel(\"Normalized regret\")\n",
    "# a1.set_xticklabels([0]+ind, rotation=90)\n",
    "# a1.set_yticklabels([0]+ind, rotation=0)\n",
    "\n",
    "a2.plot([i[0] for i in test.log['O_row_nonzero_stat']], linewidth=4)\n",
    "a2.set_xlabel(\"Batch\")\n",
    "a2.set_ylabel(\"O non zero cnt\")\n",
    "\n",
    "plt.savefig('res/figs/cora_proximal_NR_O_training.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnMAAAFXCAYAAADJZcizAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3dX5BUx50v+G9WdTcUCKkaWnNDtEECri8KebHVgP+tXq5tNMSswnf6yiDCO/NqeJoI+87l387stTyjCUDsvXbEPIFfx+FAIC3rCe0EBkn3PigsWUBLJuwVMwvI4JZ3TANtA2r6T1XuwzlZfepU5vlX519WfT8RHUj199TJc/L8TuYvM4WUEkRERERkp0rRG0BEREREyTGYIyIiIrIYgzkiIiIiizGYIyIiIrIYgzkiIiIiizGYIyIiIrLYQNEbQETlIoRYD2APgDqAKwBWuf89DeCYlPJqgZuXmBDiLID1AFYC+JqU8mKe7+8n3FdE+WIwR0QtQohjcC7Ce/xBmxvkHRNCXJRS7i9kAyNwf8M2AFuklNPqcSnls0KIfQCOJPncbt/fT7iviPLFblYighCiLoS4AGCllPJZXeublPKqlPJZAJvdlpfcCSF2u0FlkG1YbBXyO9flJnT7/n7CfUWUEwZzRAQAJwHUpZQ7I7x2J4CtQoiTGW+TTj3sBVLKDQA2GLqDpzWPxdHt+/sJ9xVRThjMEfU5IcRuOK1ZkbpO3a7L/QB2CCG2ZbltGs9GeZGteX1EREkwmCOiIwCmpZSnor5BSnnc895cuN2reQePRESlxwEQRH1MCLEZTtdl5EDO4yKc/Ln1WbeECSHqAArJ08uD28K5HsBtFVS7ZbMVTvkc9w7mICLyYjBH1N92uf8mCcbOA9gMp7XseMhrVUB2EouDE3ZKKc95nj8GJ3hZD+CQlPJl9/HdcPL0lJNCiNvqf9xBGeozCp0Sw/2NB+FM6dLK71O/xfD6NwAcA/AKnFzEC3AGD5yVUh73jM6NFHC7o0hV4FeHM7XMWQCb/dvhtnbuR3t+2xVPy6v3tTvg7FtgcbqaI0kDeTdY3YXFfbUBwEnvMUFE0TCYI+pv6uJ8JcF7VQCwIcqLpZTTQoidAHZD0z0rpdzjtlCd9T1+HMBxz3M7TQFEkVNiuNt3BE4QOe15fIcbZO7UtK69AeC8J3g6J4Q4BOCHAA4Bzn6JsQ1noZ9W5iycllTvYzvc7d3pDXrdkc1HvNPPuPv0uO93bQZwRQixM04Xvfve3e52bvF+L4AL7neH3hwQ0SLmzBH1t9DRoQFuuf+GTRXS4gYDxpaXlFplcm/Z8XQDf8sfsLmBzlk4rZLe92yG07LpHxV8Dk657I65DZvd79MFuvt9r13vfu8RTevlCwB2q89zHYEvQHbfd8r/eMTtPIb21lbvwJpj7v4koogYzBH1N293XFyr3H/LNnK0iNyyHwK4GtCtexzANrc1TNnq/nvb+0JPMPj5BNuxTTcPn2a7jriPB7WAefejqYyvIkYw7/ohgIuGuQxVC1+sQJao3zGYI+pv6oK6KvBVeuoifivwVf1hB4JbHKfhBEe7PA/fNrxciRUkuwHbRThdn8fc7l1v3p63dW4zfN2untcdl1IOe4MtKeUGQ3dvkrLfDCff0mQaEbvuicjBnDmi/nYWwD4km/JDdcMlGQnbMzwtYWEtgrexuM+AxeBvKzyBlefzkoze/RqcVrfd7h+EEBcB7Pd1Ya9Hgu5oNy9QDTi5gojz/nner37/ejdvTmc/ytfaS1RqDOaI+piU8pwQYhrOFCP1qNNfuAHHejhdi4VeeONsd5m4A0JehhO8eLs7jwA4lSR/0N0PewCowSRqxOhZIcR+32hW3XJnWu5nnXS385Da327LX5wbAVVOVznIgSg97GYlItX9FidPSXW5RVo1ImOF5ld5gtmw3LH10Hdt7ne7RfcJIY4AeC/ismpthBDbvIMWpJTnpJQvuyNG96N9oMLFCNvb+lw4rYSHpJT7uwmcPfsqciBJROEYzBH1ObeF5ByAg1FGEbqtcvvgtB4l6WI1BgO65H2NMo50PIf2LtQ2niDL33Val1KeklLucQMvf+tZXLt0D7qfOe3Zv+cA1IP2t2ewxn7PZ/i15ba5U5iEOYWAfeV+Dlf6IIqBwRwRAc40EVfROU2GzkkA55K0HrmCEv/VRVw3IKOjVccNRsqQX7UHTh6YKUjZBWcEp79rcavuxV0IaqW8rVrG3MEQV2FoWXUDORV0B+3jJNv/LTj7aofuSQZyRPExmCMiSCmn3e64q0KIC7oWGyHEZnd1gvPeVReSfBec1pm2YNA3kEA3vcZVON2D3vfpRpGqljtdV17Qc1Fo3+9u2044q1O0bbsbnGyD7/d6nj/m7lv1F3eqD//ndbSOuYGTvxV1J4AX/AMRVD6kJ2fvGDSBqvu+/e5/q+e8ra6mfTUNZ+DED/2Bm/vdm7kKBFE8QkpZ9DYQUYl4llmqY3FliA1wLtTH0hjw4HbnqhyuK+5n35ZSnhJC3HEfvwrfKEzPkmBX3fdd9D2vlvNSrUkXVQui77lpONNj6FZlMG1z6PvdYGQPFqfsWAXgVsByXuthXn1DNwo1aPu2wSmzi3CC3GksBlRXdV3imnIAgGl/C6JnSbWLWFx+65SU8qpazQFOa60K7qLsK+MxEOX3EtEiBnNERAVwW8uehW99UzfIWQ8noN4HJ6DrJo+OiHocgzkiopy5LXIXpJTDIa/bBuCslFLks2VEZCPmzBER5W8bgldBALC4Vi3XKiWiIAzmiIjydw4RRoK6LXMXbZwUmYjyw2COiChnbo7ct0wjh4FWIHcEhlGwREQKc+aIiAriGf0KtC9avwFOTh2XvCKiUH0ZzI2MjMgnnnii6M0gIiIiCnXhwoUpKeWjpucH8tyYsnjiiSdw/nxo7jERERFR4YQQvw56njlzRERERBZjMEdERERkMQZzRERERBZjMEdERERkMQZzRERERBZjMEdERERkMQZzRERERBZjMEdERERksb6cNJioDE5PTOLomcv4eHoGq+s17N2+EeNjoz3zfURElA8Gc0QFOD0xiYOvXcLMfAMAMDk9g4OvXQKATAKsvL+PiIjyw25WogIcPXO5FVgpM/MNHD1zuSe+j4iI8sNgjqgAH0/PxHrctu8jIqL8sJuVSiWvvK6i88dW12uY1ARSq+u1nvg+IiLKD1vmqDRUXtfk9AwkFvO6Tk9MWvk9QfZu34jaYLXtsdpgFXu3b+yJ7yMiovwwmKPSyCuvqwz5Y+Njozj0/CYMVZ1TcLRew6HnN2XWOpj39xERUX7YzUqlkVdeV1nyx8bHRvHjn18HAJzY8+We+z4iIsoHW+aoNEz5W2nndeX1PURERHlgMEelkVdeF/PHiIiol7CblUpD5W/tO/ULzDWaGM1olGle30NERJQHBnNUKnnldTF/jIiIegW7WYmIiIgsxpY5IiLLFD3pNRWL5U9+DOaIiCyiJr1WcyWqSa8B8ILeB1j+pMNuViIii5Rh0msqDsufdBjMERFZpCyTXlMxWP6kU4puViHEPgBXpZSnQl5XB3DQ/d9bAFYBuCKlPJ7xJvYFG/IwbNhGoiytrtcwqblwc9Lr/sDyJ51CgzkhxHoARwDsALAz5LV1ABcA7JRSXvQ8vk8IcVJKGfh+CmZDHoYN2xiFNyAdrFawZpiVcNp6Oejfu31j23kAcNLrfsLyJ51CulmFELuFEGcB7AFwIuLbfgjglDeQAwAp5csANgshdqe8mX3FhjwMG7YxjApIJ6dnIAHMNZq4dus+Tk9MFr1pPcO/j1XQ3yv7eHxsFIee34ShqlN9j9ZrOPT8pp4JVikYy590CmmZc7tFjwOt1rlA7mt2ANhieMkpAPvVZ1J8NuRh2LCNYXQBaVM6j7MyTkdQ0N8r+5iTXvc3lj/52TIAYgcA+FvlPN4DsD5KYEh6Niw+b8M2humFgLTsuI+JqN/YEsw9C2A64Pmr7r/bctiWnmTD4vM2bGOYXghIy477mMhOpycm8czhN7HuwOt45vCbPZMakQdbgrmVAG4HPK8CvQ05bEtPsiEPw4ZtDKMLSCsCkQJSVnTR9ELQT2SzJHVVr+e6Zq0UU5NEUC96A8okyUi9KO+xIQ/Dhm0Movb5vlO/wFyjiSF3NGuU8ktrJO/U3Vk8c/jNnhzpCXTu49Ee/I1EZZW0ruqHXNcs2RLMhbXMKcagzx3tuhsA1q5dm9Jm5S/JidIrU3r0Cm9AGlVaFd3U3Vlcu3UfTen8f68eC7YH/ZSvXp7KJm9J6yrmunbHlm7Wrkkpj0spt0optz766KNFb05iSabn6IUpPfpdWhXdjTszrUBO4bFA/Yzde+lKWld1k+vKFJTeC+aCBkn0hCQnCu947JdWUv9co6l9nMcC9Sve7KYraV2VNNeVwbjDlmDuNpyuVut1eweR5ETh6D676I6RtJL61eARPx4L1K94s5uupHVV0gFuDMYdtgRzVxE8CELNL/deDtuSWBp3EElOFI7us4fpGAGQykjeNcM1VET7YzwWqJ/xZjdd3cw6MD42irG1dXxx3Uq8feCrkd7DYNxhywCIiwC2CSHqUkpdV6oK5s7luE2xpZHEnmSkHkf32SPoGHn7wFe7TuofWbEEgJM7Z8OxwMR0yhrXOo0u6vmY5wCk1fUaJjWBW78F47YEc8cA7IMTtOlWgdgC4Koh0CuNtO4g4p4o6gRUU2GkcUHkRTYbedxljqxY0grqyjzSk6OwKQ+82Y2mrOejLhgXAL7ypL0DHZOwoptVSnkVzvqrewwveQHO2qylVkRzvrfbDnAS4LtNDmXCaXaiHCNqnrheH7nFXBjKS5LuvX5T1vNxfGwU39jSXl4SwKsXJo11Yy+Ofi1DMKdy4cLWVf0WnK7Wzd4HhRBHAJyTUp7KYuPSVETuWhYnYFlP6l4QdoyoeeL6IZBmLgxReZT5fHzrw5sdj5muSb3aGFFIMCeE2CaEOCuEuALggvvwESHEFffx3f73uF2oWwDsEkIcEULsE0IcA3BFSrkzx81PrIjlqLI4Act8Utsu7Bjpp3nimJhOVB5lPh/jXJN6tTGikJw5KeU5JBis4AZ0pe9ODZL3zPRZJIcy4TRbQcdIP80TZ0pM/8qTj/b0cmRUDr2aF5z0d+U5UCTukoNxrkm92hhRhm5WylAWXbuc6qQ4/TRPnK6V8htbRvHqhcme6yKhcunVrrhufldePUtJUkn2bt8YecqlMrcwdoPBXI/zn4BD1UrXJ2AR3cXk6Ld54vyJ6W99eLMnu0ioXHq1K67b35XHQJEkqSTjY6NYt2o5VNUYdE3q1cYIW6YmoS6obrtf/fYPeOqxh1M5AbmQeTFsmycubb3aRULl0qvHmQ2/K2kqyciKJfjdvVk89djDgdekXp2KhsEckWVsmScuC8zXpDykeZyVKffOhvNnqFrRBnRpbmMvNkawm5WIrFFUF0kvzktFZmkdZ2XLvTNNpFumCXb7LZUkLQzmiMgaReRrlu2CTNlL6zgrW+6dbj62oMeLMLJiCdatWs6c7JjYzUpEVsm7iySNNZXJPmkcZ2XLUSvb9pj0cypJUmyZIyIKYMsFkMqnbNNglG17KD0M5ihXzD0i2/ACSEmVbRqMrzz5KHzpaMxH6xEM5ig3zD0iG5Xtgkz2KNOcnKcnJvHqhUl4p3ATAL6xZZTpAj2AOXOUG+YekY16dV6qqMo0tUYR4i4t5VeWaTB09a9EuQY/UHIM5ig3phyjyemZtspy6UCllfwKdF5M/M8TZa0sF+S8qdZ0FQSo1nQAfRHQqaWl1IoENv9+5n72NgZzlBvThJUCaD0+OT3TNseQ7mLin4OIiLLR763ppqWl/vKVD/CdE+9b1VJpw4TBZVb2FmrmzFFudLlHAoCvrkRTOpUooL+YeJ8nouz0e2uOaWmphpTW5f0y9zM5G/K9GcxRbnTJwP5ATlGVqOmiYapkiSg9/T6SV9VVQYqcBDgOf/0rAE7GG1HZJn/WYTBHuRofG8XY2jq+uG4l3j7wVYwaLgqqwjFdNKJUskTUnX5vzdEtLaVjS0ulqn+rAnho6QADuYhsaKHmFTEDnEstOt3FoiKcSjTK80SUnbSm1rC1TvQvLVUV+siuX1oq+5UNLdQcAJGyfh/9FZdu2gfvaNWw54koW92O5LW9TvQuLfXNL6xt+y1Af7VU9qu92zeWvtzZMpcyG/rWy8bf9eoP1EzP23q3T9RPeqlOLNMkwEVSc+/1S91rQ7mzZS5lNvSt94Kpu7NW3+0T9YteqxP7dc5BpZfm3ouj7OXOlrmU2dC33gtu3Jnpmbt9ol7GOrG3mObeY91bLAZzKev30V95MU1NYuvdfhnY1G09dXcWE9enrdjWfsc6sbew7i0ndrOmrN/XcczLULWirVR4t5+MTUnqpycm+7Kbx1asE3sL695yYstcBvwJ+6y00rdmuMa7/RTZlKR+9MxldvNYhnVi79DNvce6t3gM5shKIyuWlH50kU1sSlK3aVuJeo1/7j3WveXAblayVtlHF9nEpkW4bdpWol7knXsv6dyDZV603kZsmSMiq5LU927fyG4eIkvZsGi9jRjMEZEVk2Iq42OjWLdqOVQ8V+ZtJaJ2NuXn2oTdrFQKU3dncePODNYdeB2D1QrXXs2Jv7tjzXANIyuWlL7bemTFEvzu3iyeeuzhtm31/p6g44jdPETFYM5rNtgyR4VTU03MNZqQcOYxunbrPpvdM6ZW0fB2d1y7dR9Td2eL3rRE/N03puOI3TxExeEk0tlgMEeF00010ZRgs3vGdKtoNKXzuI103Te644jdPETFsSk/1ybsZqXCsdm9GKaZ3E2Pl13U44jHG1FxOIl0NhjMUeE41UQxTDO5q0EQtol6HBV1vDFPj8jBaaXSZ2etTT1FN9VERYDN7l2Iss6qbhWNioC1g0903Te646iIbh7m6RFRlhjMUeH8U00MVStYt2o5Wy0Siho46FbRWLdqeWsyUNv4p1cxHUdFTMPCPD0iyhK7WakUvFNNUHeCAodP+Vrd/N0du479LLftzIL390R9XR7dPMzTI6IsMZiziH8OrXptAM8cfpM5ONQmKHDwB3Nlpo73yekZDFUrOD0xae3xzbxQomx46wkBWDu1UrfYzWoJ3Rxav7s3xxwc6tAL8zh5j3fAOd5tPr45HQNR+vz1hAT6do5SBnOW0HWd+TEHh4DeCBx6LcfMpuXSiGwRdW7JfsBuVktEza1hDg4FzeMUJZ+sDHoxx4zTMRClqxfriaQYzFnClHOjex2R7YEDc8yIKAzriUXsZrWEruvMz7auNCKTXugqJqJsRZ1bsh+wZc4S/q6zIXc06/TMApdEoZ6jO96ZY0ZEXv56QgB9O0cpgzmLBOU82diVRhREHe+/+u0f8NRjD/dlBU1Ewbz1BABrJz3vFrtZiYiIiCzGYI6IiIjIYgzmiIiIiCzGYI6IiIjIYhwAQUSF8647bMM6w7ZtLxH1NgZzRFQotb6iWpZHrTNcVkHby4COiIrAblYiKpRt67Datr1E1PsYzBFRoWxbX9G27SWi3sdgjogKZVpHsazrK9q2vUTU+xjMEVGhbFuH1bbtJaLex2COiAo1PjaKQ89vwlDVqY5G67VSr8Nq2/YSUe/jaFYiKpx33WEb1hm2bXuJqLexZY6IiIjIYgzmiIiIiCzGblYiIqIS0604QuTFljkiIqKSUiuOTE7PQGJxxZGpu7NFbxqVCIM5stLU3Vk8c/hNvHvtNiauT+P0xGTRm0RElDrTiiM37nCSalrEblayztTdWVy7dR9N6fz/XKPJtTGJqCeZVhaZazRz3hIqMwZzZJ0bd2ZagZyi1sZkMGevqbuzuHFnBusOvM68ICLX6noNk5qATs1zmNTcQgPPHH6zLQ+P9ae92M1K1jHdkfrvYE9PTOKZw29i3YHX8czhN63qip26O4uJ69NWbnsSpycmce3Wfcw1mswLog42n8vdMq04smY4+fJxTQnMLsi2PLxvn3gfY3/z077at72ELXNknaFqRRvQedfGVEnDKtdEBQdAfl2xuhFoUb5bBTaq9dG77WnxtoINVitdXRjScPTMZW1r6407M1gyyHvOflaGc7lI6jfuO/ULzDWaGHXrEjVptU5Y3SMN77vzyXxf7dtewmCOrLNmuNYW7ACda2Oakobz6ort5gJkCmyOnrmMT6UQdOlyDq/dul/oHXlQXhCDufQlvdEoQt7nsnffVAQghMBCU2KoWsHpiclC9pNuxRFTMNdt8Gvat2q/TE7PYMi9ARxZsSTxb6J0MZijQGWs9FUFcuPODOYaTQxVKx1rY5qCA9PjaevmAhS07bpgLm4Z6XIOmxKpBYtJZJUXlKcyniuKd9seqQ3i/twC5hvOQVCGlq6gfZfnuTx1d7YtEGpIANLZT96BVmnJ4phJI/jVpax494u6AaTyYDBXYkVPFJnkDi+vC9rIiiUYWbEEv/rtH/DUYw93fIcpOPB2xWapmwtQnG0PKiOToJzDooK5vds34j+98n5Ha+vqR5bid/fyzZtLcgyXpSvQVGd4t216Zr7jfUUOIArbd3mey+oG0STNFvKsjpkodY+AuasV6Ny3ugCxKcHpUUqEwVxJ+Cvhrzz5KF69MNlxoq9+ZGmkpm3/5y0diN/CEfcOrywXNMAJDrzbAnR2xeqkFYx2cwEyBTa6PJmgMjJdcKLkHOZtfGwUf//Gv+Dq1H1IoC0vKM9gLklwDKTfFZhmQLl0sNKxbTpxWrq6PU/auzIFGrI9tPDuu6TnchJRpvtI66Ynq+7jKHVPRQADVYGFhkTDF9UNVgQ+mVtoG1Ued3qU0xOTmLg+jblGE88cfjOXVuq5hQbmFiTevXY78Dv93cVFdZ2nzZ4+jB6mm+H7R+9cTzxRpO7zrt26j7mF8ArdK27rUlDllLfxsVEcen5Tq5tutF7r6Ir1M820niSXzDQCLcoFaHxsFOtWLYdw/z9o25O0AK4ZrqEiOh//ZG6h0EmYR1YswdCAwFC1go+nZ3D0zOVUR7P6R0TqPjvOMewdcay7eAKd5RBllHLS49C07Xc+6WyJ0/EH8979NXF9urW/uj1P/O/3B3KK2ndJzuWkonTrp3XTk1X3cdS6Z2igiq1PrMSGkeWt312vDQLCGQjhLdv6skHtd+n2lypfFeh1U49GNXV3FrMLstXaaPpO77EHLHad98IIXrbMZUitUhB296qrhE1N4HONJiauTwcmn5qaxOcWghrWO8VtXSoiT21uodG6OPr3sS5pOIjpYvjtE+/j6JnLkVtHvLlJ840mFpqy1dIU9QI0smIJfjP9CaQUrcBGx1RGEsC712637jzV71N3oyPLh3Dz3hwkgKpwjg910Y86CXMarZjeu+T2rXcq5IoABquayDMmXauVLqA1HauT0zNYOlBpnXP+Eccm/hHW/lHKe09+gO/94y8x/cl8ax+ajsMXf/LLwP3bzXnmv9ibcqRUeXXToqR7v45333nP5W9+YS2OnrmM75x4P/VUjjXDNXz8+wfG7VP76e/f+JeOORHjbkN92aA20PYGTt5zLOqoc9PoV9P2qZQVAPjNnZmObviZ+QaWDFRQG6y27ZeKgHZ7ihh8pmvk0H1nkm1LUgZFYDCXEf+IwcnpGXznxPs4/+vbHa+NWwl7k0/9Ad3piUljK0G8UC5aV+XU3Vk8/b2favNwlNX1WiYnhLob81781T5+aXxT7M8LKoegLmNvQOLNRZmemUdFABtGluON//zvO14bNCJM99sOvnYJK5ZUMT2z0Br48cLnP9XWHe8312hi78kPAIFWwvtco4mp+3MYGhB4es0wJq5Po+HrLgnrTn/xJ79sK/MkXer+gEEnyU2ITljOjyqXoG/yJnzrRhz7CTj7RXX56N4z35StC7rah6b9MT0zH9glZArs67VBzC402z53sCIgAeONhml/qXNYx/u4/6ZGuK09pi5+PwHgK08+2vG4f4BCt6kcunrp0PObWoFQVaCtG3JmvoHvnHi/7ThRc7T91f95CX/3H9tbDL3ne1UAY3/z01bgPmsoZ9VQGRRQj4+NaifZTnojq5jK9vcz8/j+rqdb+yWo7irkpj7i3KNxty2sDMo06InBXEZ0IwYlgB+9cx3rR5a3nQSmSjgoSbUpgStT93Fl6n5b60tQfk/c9o2wO7ypu7O4MhU8oqk2WMVXnnw08IRISnc3pvbx1sdXxv5sUzkougDHf7L7y8sfMEQdEWa60/ReYOcaTbx6YRLf2DKKf3jHPOfUvCbq8AZJUSpCU8Dq375vn3gff/nKB2hIiaqbC6X+9R8/UVtoooZyQYFyUM5P2M2Iosoy6IZJ8e6jsCDNa2a+0dpfOkEtCLqbLwAQAvjGllH8+N3rrcDkoaUDWLlsCCMrlmgv9kEXvbAWe/9x7t23c41maPI9sHge/8M711vHDaAfoBC39VwJOh/H1tZbr3v/xh33xmpx23TuzzWw99QHANC60PtHxnoDd5PpmXk8c/hNfDK3oA2oX/zJL7U3U3tPLn53UqbWwtX1WitAVIPOTOL06Oh6r5Iw3SRUhMATB15vnVPCcPAJAe31KOimBkCqNxbdYjCXEdMFUsKpkLzBnKkF7BtbRvHKe78JvZNV3WJBic5Ru6t0d3uqYvNX+mH5e3X3jlwXaKgTopuDPmgfJ/ls08XQ6+PpmdDkbdN2xhkRFnXdxZn5Bt768Gak1/pJIDAnzXRxDrsQq/3h/9df2XV7p+7tYvdPt+G9MJ+emAwspyiBXOs7VUungcoh0gUcQUGaV9BrgvaZOt7/8pX321qT7nwyjxM/v9Hx2HRALl3QBVl3nniT5sPOCYnOG1XdNdYfDK9+ZGngeRH3Yhp0ofYOcJiN0TI835CtuifqzYpOWLCn/e6mDO2KDzJ1dxb3Hixon9O1kppEHbCi672KOsjP3yJWrw3gd/fmOl7nr4NMh2VTQnvsBKVdfPvE+x2PFzkqnAMgMhIUN6m8N5UEDUCb4PvS+CaMra1HSsoNS3Ret2o5hgaqxucB/ZJK3znxPq7dvGf8HUFmF5qB29TtxTxovyT5bH+itc4jtUHsPfVBaPK2fzuDWnPmGs2O5PwBXfayKJoAACAASURBVEKXwcduS1RcAuaAXACtyrebi5KfdzBBN4nkqhtaHavTM/OtQE5pSuCjW/dx8LVLkcopKl1LJ+DsszXDNeN5EXUbRus1DBsSziUQuJzV+NgoqpXOY0G3zRLAr29/ov0cXRJ9RaDV8uU9T/xJ81F+pwTa6ruwd8zMN0J7AdTrog64CrpQv3vtNt776Lax7ovyuXnNaekV58bE78adGeOx/eqFyciDBNTxoRvAdXpiEk9/76d44sDruDLVmXMaZZCfbgDO1P25wGtuFLpjJ0kdVUS5A2yZy4wQwnwbgMVASN2NHHreCdym7s7iwUIT33G7DZYOVEKTcsOM1p3uprApHnQ5PRLA7+7N4ea92235Hnu3bwzNfwnb3m5Hha0ZrhkreNOcbP7pWvx3gKorYerubMc+rw1WMd9odgQNYeYaTnmaVEVnc30cFSGMd6YmAsDQgMDsgrl1E3ACh7jbE0ZVdlFaQhU1wlbd8Uad36ohw4/DqMK6ByWcHNawucqCPk+1YJz/9W1j13lYC0bUVl3AyZlTF2lv193wssG2ngHVba3LydIlzYcZrddarV8n9nw51eMs6sU0LK2iKRHrnPJ+bpTPz1pQTp1OnPn11GerqUe+8uSjeOvDm23dpQ8tdcKLtw98FYBT/+49+YExYIyyHYC5RRUIP0fD+FNL7s/qWyqDFDXFE4O5jCyEZUd7qBNl6UClo9m5IpxWtbC8KEB/IKu7af/8ZPpRhGYS6EjUjhtA6LbLxJ9L4Q28vBWJjq5JXzeaEXDyDnVzEo2sWIIv/9tVrX1eFQKb1z6Ct690DmAx8ZZH0NHQbcDRkDJ2OVSEMzWBlE3tfqwNVjoSvdOiBsS8+JNfRv7d/hG2cQKWtITti9F6DVN3Z9FoRts2/+cNLxvEd7/+GZz/9W38KORcD2qpijrIQNl70slx9FZZdz6Zx4n3bmC4NtgacKPyBf0BQdyWCN2cibq5FZN6pDYYaRaBODcTcahBL/65Qrs1VK2gKWXgtUW16OpGTn/7xPv43j/+EiuXDaEpgXsPFloj3tcM10KPGzW/3iezC7ji6Y6dnJ5puzap60NTNtt6g46euRwayClBMzYEHW9p1FdPHHg98Xuzmv8wCiFT7H6wxdatW+X58+cz/Y5/+7/937ECOgFgMOBkGqyK2C1CAxWBlcsGMThQbSWurx9Zjr/42qdTqcTiXjR02+UN1tRUHPpEVieo/YuvfTqw0vcmS8cJVgWAP/vSWmx9fGVrwEe3d3lpqbqBV9oXnRVLB/BHDy2JNMVGWlQu6Imf34hcsXuN1mt4+8BX8e/+6p8KCehMBqsCX3hiOFawn4aKAP7bC0+3BStfeOls4pusKFTQ6W2Zi9MC9YNdzvbuOvYzAMCn/81D+PG7N1LpCh+siLaR2+qxwarAJ/PNtu0fHxvFX5++FHqTnJQ61tP4/KFqpdVzE9RLo35bnLoPcI6j5UNV3JttGOu8em0Qdx/Md0wyHETVq299eDNBj4NT56uZAJQsegvSEHf6qbiEEBeklFuNzzOYS9/piUltcmSQem2wq3wHnapwghHvNbMinDvXqBOJhkka0CUJlJycCH1ytQDwhXUrcWLPlyNNeWGSJGjOww880wKkRQX3AForL0Qx6gbfUbsTvVTLQdDx558OwksAuHb4OXzt//jvkXKo8jJYAeYLii1VgAsg0+DESy21NrJiCT79bx7Cj965Hvn4+ejwcwCAXcd+hms376UaeFYEIt2YpF0Pmoym1NU6UBF4fOWy1v4OKmP/fHBp0AXJefEHSUmur2GiDk4y8U4/lZWwYI7drBlIsuLB/bkFDFRErNY8AFgyIIyjrXTnnXdy2G6p5vkkF9Ukp43ze/Tv9I7M7CZhP63KKupFJSo13UeaJJy509atWt7Kb7lrGM2mqCTjqGWucpLVlkc99kzBfkUIrDvwOgarldZkx2UIvYsK5IDFbr08WytUN+9Ht+7jvY9ud5TB8qEq7s91noP+gTpptyBGPefSrAeDqMFJ3d6ELTQlrkzdx7Vb9/HP/3o38LVpB3Kj9Ro+mVvIZX/p6EYph6Skx7JhZDmudnFjWBWd870WgaNZM5BkNMt8Q6LRlNpZ6U0E0plQNYnaYLWV07DBbd0p2pWp+3jqf/+nUjTBp91tmXYgp8RdLLsh4w3QkEgWbA0NiI7RlM73O0v2zDWaaEjndWU5/opU1DHfkPpjXRfIAfoVA3rZ6not1d+cVxDqtXf7xsICOUXNJfj0936Kvac+SC2QA5z6L+qgBd3lWQiR6rKDSTGYy0DS0Sz+LtEgAk7rTxGhnIAzCSngJKqWqbvrkyKbSLowWBGxJ3WOqjZYDQx4VKtB3LV7s6D2wdBAFYeeD1/FY3ZBxgpGqXhqGp53r+WbX5i3warA3u0bMbJiCZYMZHd+Z0kAgfMq5k03BVG35hpN7N2+0elKDlAVi2kpXgtN2ZoEv0gM5jKwd/vGWC1sSRWV2iXhTAR8Zep+qZLQszRar+HPv7S267mMdAYqAkd3fk5bUaQhbI6uqnACuTiTo6ZtoCKwZEC0zpu5hejzhfXLMdgLPrp1vzVPY68bqIhWt+DQQBVDA+UN50xbJmGeV7HXHN35OWP9XhHAE6uclZt0L/GuClEUBnMZGB8bxbpV2Xb9lPX0Cgt24kyGWyZ37s/iH965nkkA3Sx4EFJTxpvlPk0CzqjaLY8Pt6YxUNvTDxf8ftOQxSTRF2FmvoknDryOievTmFtoFJYSE0V5tywfKidv6xMr3VH+Q23PjywfauXFmfZVUZMFKxwAkRE1Se+9Bwt9daKE1dNxB3iURZbdt02JzOZ0i6Ko71UTF/vZeYSka8PI8lKlL1BybDkuP5WTN1StoNFs4r4vBW7q/hxWLJ1ttczp6qiiJgtWGMxlrBIwzUIvCppWgsz6dZfNLUjMLiz0fP5UXN2MriOiZEyBd1M6A+xMN1je5Q+LYl0wJ4SoAzjo/u8tAKsAXJFSHi9uq0gJW8aMSOFRYsZ9Q2WW54TqZZm8PUgZts+qYM4N5C4A2CmlvOh5fJ8Q4qSUcmdxW5ctGw5oge66UW34jWQHthCT7QSAh5YOhM79WIQ8e5wk7Lg2/OUrzqjfrFaACGPbAIgfAjjlDeQAQEr5MoDNQojdxWxWtky5RWXT7clm6dgIKqFlSwasnAqCCFBrJ/MIBpx1otO6NlSFM+AqCw0pcfC1S4VNUWJNMCeEWA9gB4AThpecArA/vy0KNnXXGfyQxt2LRLaTAwuYh6bnqSHDR8N2qwy/k7J3N+HAo6pwVlWhfFXF4l+/E0BrNoR7BbXKBZVD3kU0M9+0ppV9Zj76lEppsyaYgxPIwd8q5/EegPVu0Feo0xOTuHYr+lqXUWR5LEs4d4JlqEjjnLRRt9d7oXho6UApfieVkzr+eIwUq193v/rdV6buY3ZBFta1OFDVT3KsJqsvO9MmNmT4koXdKmqKEpuCuWcBTAc8f9X9d1sO2xLo6JnLqS/nRO3KVJ+sWDrA1pweMrsge/r8teFIddd17ztRlr/LY7+oeSdVt6T6syGQA4oNOIuaosSmARArAQTNX6ACvQ05bEugyekZ7PnF/4X1vy92eQ/SyCKT1r+aPBF1RbjnVJED48uwDWUghECrjbDP94XJ1UdGceyzfwqguClKbArm6t282R0csRsA1q5dm8oG6ZyemAy8c6oIUfiM/37Vimi1RAgUvyJBJAIQWOwKiLLNqlISQrTFXzLgvWHlJdT6uCFfL9ztlZCBF4eKCH9N1tS25n0cCOEs59UoSbNYpLIvwaamfcy0ykHK3C7eQizWmgJAxW1aaUY4FtI+Tivutni3IetzoSzHkpFm25Jey6LWhd3w1vFAftc0geJGs9oUzIW1zCnaoM+dh+44AGzdujWzkj165jIk0IrSFQHg+7ueBgD8p1feD+zGEQD+7Etr8Q/vXDe+ZsmAgJQi1uzitcEqvrFlFK+89xvMNZoYqlbw8o7PAgD2nfoF5hpNjNZr+GRuAXc+mY/8uTrDywbx3GcfM/4GAScvI8rSPrVBZ9F1dZLsOvYz/Oq3f8BTjz2ME3u+DAB45vCbgcs/DVUrGFtb73jfrmM/C5yw9qPDz+GJA68HPr/pxTPGlT5G6zW8feCrbY+tO/C68Rr50eHnQn9LVQjnQqtREcD/+sW1ePXCJGbmG8bPCPLR4ecAODcmB1+7pP2c0XqtdQdqek0cqnxO7PkyTk9M4uiZy5GX8/rBrqfx459fx9TdWXz8+weB2yIAXIuwj4eqFfzz3/2J8XXect117GcAgBN7vmx8fdW98CWd0kHt76NnLuPj6Rmsdv8/6MLh3Y9D1Qpe+PynQo8Lbzn4/fXpS/jRO9c7jt2ojd2611WFM/L4qccebj2m++4gY3/z067rK6CznvEKOheSUseiElTPdCuozgh/b+cxWxHAf3vh6cCVa36w6+lIgY23Pv/mF9Zi76kPjNcFAafxodGUqBh+k+4YDjvf01JkPG5TzpwVTMmPEk7EHpZPpwK5l8Y3YXjZoPF1swsSc41mRytgbbCKP//SWoy6/fZV9y5ztF7Doec34aXxTRhbW8eKpQMYW+vEvQdfu9QKCienZ3DvwQIGfRnggxURuD3Od1cwVHUOqWVDA9j6+ErjayWAXZ9fg3ot+DOBaCOE9m7fiNpg1fh8UNBraklVv8W0nuyoJzciznp9ppwK9X1BCbS1wWpgpbxu1XK8NL4Jh57fhNqg/vT+o4eGjGXp/U3jY6M49Pym1mND1Qp+sOtpfHT4Obx94KsYHxtte03SNBUBYM1w+/e+feCrbdtiMlqvtS4YIyuWtG2vjtr3QcdLRSxuj+51tcGqsSvF9Pr/+sLncO3wc9j6xMrY6xOr71P75Zpn/wdRr//iupUYW1vHWx/eDAxGaoPVtnLwe2l8E76/6+lWWY/Wa9gwshyD1WiXEd1Rm0Yj7He//pmO+koAofVVvTbY9ltMgRzQeS74S3CwIrDMcL6ZxMmtGq3XQn+PyWBV4JtfXNORRxb1KNTFVWphedNvqNcGE7VQjY+N4uiOz7WuW36D1Qq2PD6Ma4efw3994XPac013DO/dvrHrXMMo18AodVZWejGYCxokkTnTwa0KOehCPVqv4fu7nsZL45sAOJVUGDWhonq/CtjePvBVfHT4OVw59L+0XXz9jp653FHBzzcllg8NtFV0R3d+DhP/5Y/xA7d10a8inAmDvUHhwdcuBV643vrwJt7/7h9jw8jy0NGDYSOEVGVrqgSqApi4Po27DxYwcX26bS6goQHRUdGpC/pfn76knQjZv3yLafN1x4MpkFCVkOkYqgoRGKwMVSutxaDHx0bx//ztn+DPv7S2Y59Mzyzguc8+1rENFdGZ7+EPCHTHkDfI2DCyPHbysQRa2+0VFqDrgiq1Lbrt8L7ef3H23vSsW7W8bT96g9W4F/2haqXj9Y+vXGbcR6P1WutmLMr3xRFW9xx6fpO2HLy8Zb13+0bcuDPT1dqjabRkqABA7bOhagXrR5aH1p8v/ofPJAqOPzr8XEdQe3Tn5/Crv/0T/GDX0x11WVUg0g3BkCEoVq3Az332scDtM9n1+TV4aXwT1q1ajqFqpbXNf/altYHnV5iPp2e052hFOPs2qfGxUWO3qPdYU+ea2m9Bx/D42GisY03VB+rfoWqldQ384rqV2DCyPNZNXh5s6ma9DaertdT2bt/Y0RzvLeTV9Vpot40yPjaK7/3jL0O7EKTh/VGYKvjfz8zj/e/+ccfj42Oj+Ps3/gUf3brfumNTdyv+7ZyZbwQGaeq7R1YswciKJTix58v4d3/1T9qLQ5S7WFUZ67qxmxJouJ8712ji4GuXADjzAc65UwCorojReg1LB5wK4keGbuKKaM+NcALCirHcddupuswGqxUIIVuVkOkY8l7Udc+vfmRpx3e9NL4JWx9f2fb6uUYTr16YxDe2jOKtD2+2tmHNcK3roEH9hgcLzcjdGvXaICauT2Ou0cQzh99stUL591NFOLkwjaYM7Wb0boepW9L7HV6q2zTsdSbq9epz/O9V23bjzgzmG83Wvn/jP//7yN+RRJS658c/N6d2eKluxzQWkVc3WGuGa6HBpIm3jLz73VR/VkV3uU2mY2J8bLTV5a8C3aZE27lmOnbXDNdw7db9trrLW4e89eFN7bYsduHrux3V+7z1rLL18ZWtrviqcPIEvV2ctcEq5htN7Q3tak+ruLcuS6MeMR2r/uuJ2t/AYve86RgeNXymTlPKVrqJ7jweWbEEf/G1T8dKe8iaTcHcVQBBc8ip597LYVuM/Ae3v5D3bt/YEWwERfTf/fpnIuVqJJ3bxnTSBAVPukphnSHfoyGdbkpTZeB1emISjWbnxSHOHY8KNtWFcnW9hn/9w4OO75+Zb+Dga7/AzPzi9zWkbH3Xj39+HRPXp413c/6uh6GBKv72T/+nyCe3/+Lzq9/+oe05wHwMmZ43VWK61teZ+Qbe+vBmR95XGtSxsevYzzB1dxbXb3+C+YD+tPtzC60LiGrRBRb3kf8i7c+pOj0x2REMerejjLznUJr7PkjYjWYcumPKb8DNbRqsVlCvDeDubMP4nrlGE9du6Rcx74ap/nzCnZQ3C1N3Z9uCMgng1QuToS2s/hshf6uuqY5vSolrh58z1sFB1wb/jcc3v7C2Lc/y0POb8Pdv/EvHAvPeVnzdORqV99xVPSbjY6PYu30j9p78oKPeaEpn/yahO/5N+Z5RGw+KDN78bArmLgLYJoSoSyl1XakqmDuX4zZpBRWyLtgIu+gD3tYJ/d1X0rlt0qrgTUHhkHun5k9M93fpTd2dxcHXLnUEScPLBvHdr38m1knjDzZNicXeQG7xMSc/71PDtcBWB12XSJond9hn6Z43BXOmyjyPyS3VHeyLP/klpmfaW0hUMrM/2VmVQZR96W8hUsHg6keWJm7l6VVhNwlxBB07Q25L89NrhvHNL6zFvlO/wO/uzaFeG8TSwYqxp6Epnclyva2z3QprBc/CjTszHT0DUY9pf4DvfX3YjXeSG3M/9X1qQNzRM5exdKDSGnDnbUnutnz85663x8TUqirh7N8kdMf/V558tGNQUNHdpUnZFMwdA7APTtCmWwViC4CrhkCvVHQtW0G8F+7TE5OxWvaifDbQfQWvCwoHK07z/5Wp+20VuVquxvsdptybZUMDXVcaQ9VKrO6gj6dn8KnhWuD7ghLFyyaNSr4b/sDT2xJpmo09aqBpanW8cWeGwZxGWjccQV22nxqu4Ve//UPrBk2dQ9Mz86gNVjG8bDAwdcTfOtutoFbwLJjqjG5vnsJuvNO4MdfdHFWEM4hCjRBNqyXZdO6qoHfacIwE1eW6Vvqw1ApvV7Mux9UW1gyAkFJehbP+6h7DS15AidZmzcr42GhHImu3B1/cUXKmz/Amitdrg4A7KAJwKvIH80380UNDABbvwNVAhKwqQMAJvOIk5asgZ81wrSPJVcAZDWpToKBLUhYAvvLko8VskIcp6TtqoGk6PtLI5eoF6uL27rXbbedbt6KM8r1xZ0Z7sY4yjUiRa1x2q9tj2iRsME7cwTo6ugCrKbNZGzysxyBs1L+fqZU+7JiPMsjLBja1zAHAtwBcEEJs9q7RKoQ4AuCclPJUcZuWn7gte3nx3vU8c/jNjm61mfn2nBlvl5ipFSyN1iNdLsryJVXtRUUFOWouPtWiOP3JfGhuWhKmnJE0jY+N4vyvb7fNEabyeLY+vrLQykvXBR+nNSGoe7/fmS5uQPctXkEt+ur86DagLmqNy26FDWTQ8bcoLR2oGEdlxk2/iCNoaq20hfUY6PLLvdMGAe377fxHdzpSkOKkbNjOqhrP7ULdAmCXEOKIEGKfEOIYgCtSyp0Fbx55RK2IVZeYrhUszdyFkRVL2u6+vvv1z2hbq/7nDSvx6oXJtq6hB/NNfH/X04lbLU1MOSNptZ54vfXhzY4KuQytH9654ZK0JphaiGzqBs9KUDeWTtxWPFOL/tTdWdwLWMy8XhuMNCVG2mkA6vfppidK08iKJVi3annbnHRBx7Qu6L52637iRP9umPZ5FkudhrXu6nqhvNMG+febaf5NW28K4rIqmAOcgE5Kud/9e1lKucdd3YFKJE5FPNdoRr6op1Uh67okvr/raXx0S981lEXQE/di240iB0GE6aab39S1ZFM3eFbilHnSLird51y7dd/YklMbrOLF//CZtjKris5gIe0k9DxvnAAnoFMT1Uo457rpu0xdm0kT/bthmjduaCD9cM577gL6ORlHVizB2Np6q27wntdRRlQDxS18nzfbulnJEnGGgQPAu9du4zd3ZgIHX4SNfopL1yXxnRPva1+bRdCTZ4BV9CCILMUZ2dtP4pR5WDJ6VEEr3IzW9VPsqClsguYE7FZavy8qNfhD7YqgLu4y5X3qus+XDlTwu3vZtBKGzckYJEo9aevI1CSsa5kjO+haTP7sS2sDByKEtQbk0ZJlCm6yCHry/K64y1KR/eKUeVo3FqbXCyCw1VWlQXQzCCvJdmXVMm0a/KGrq+Im+mfN31Je1lbuoJVy4qZsmFIMshpAlAW2zFFmdC0mP/t/b7Xm2NPNmRd0t5xHhZzmxKpl+q405xgjO8Qp87RabsvaApz3dsUZna+rB/yJ/mURNvVHnqKslBOFKcXg/K9vt+VPl30OSwZzlCvvSNy4M5bnUSHnGfR4vyuPOY7KNGP53EIDcwuydcdra2BZpoubTtQyT+vGIu4KN3nJ88YJMM9tqaurTF2bZQsY/PMGpj0fYFxp1dWmHp8fv3tD29hwZep+6pNbp4HBHBUmbnCWV4WcZ9Cjm3Hd+3gvmro7i1nPvFVRLgplDJriTv3h/Q1qZZSySOvCOD4Wb4WbvOR94xR3yh3dxNplo5vYveipP9Koq02NB6bRsUrRwawfgzkqTNzgLO8KOQ9ZzgVWVrpRekEXhbLuozhJ9brBO9du3cdfn75UmiA1rZuYss+DmSTZPi61jJ26SfMP/rBRlhO7F8nUqFA1LJ3pVXQw68UBEDmzKaEya0lmLO+V2bqVPKcnKYu4F4Wy7qM4OZym6Sd+9M71rqcDoXIaHxvF2No6vrhuZSaDOvLgnQrKpOh8yG6ZBgp984trIs2HWJZgli1zOSprC0ORypTHVYQyz//WjaBu0birfZR1H8VJE4g6s36Z7vSpv/mvVzplyIfsVlCKgVq39ePpGe2APaA8wSyDuRzlPdcRlV9ZR/91IyxRes1wDVem7re9J+iiUNZ9FCdNwPQbdIoOUokA86S8VSHQlLI0+ZBpMDUqeB9XwW1eg2jiYjdrjsrawhAHu4nT1Yvzv4XNsTWyYgmWDIi2ZXqCutfLuo/ipAnofoNJ0UEqJeevH4tYkistputSU8rM5gMssyRpQXliy1yOytrCEBW7idPXi/O/RcmJGxqo4qnHHo6UJF/mfRQ1TcD/GwarFdRrA7g72yjtnT7Fo6sfgyZJL7u8rldRR6qXYUR7mdOCGMzlKO+5jtLGbuJslLmCSCJuTlwUvbCPvL9Bjaj85hfWljJIpfjKtMZqGvK4XkVtIGBDQjgGczkqcwtDFL3QTUzZizvHVj/rhSCVHGVaYzUNeUwFFbWBgA0J4RjM5czmytv2bmLKh5pjy9abFqIkTPVjUWuspiHrufmiNhCwISGcvUcZ5a6siehRcfBGfvyLdTOQo16nqx/LusZqWZgaAvyPR31dP2MwR5GVfTRPENN0GQzoiCgNuvpx3arlpVtjtUyiNhDY3pCQB3azUiy2dhOXcV1BIuotNqyxWiZR88htzzfPA4M56gtZrSt4emIS9x4sQAKFr61JRGSbONP7sG41Yzcr9QVTEnI3ORdquLxa4IVdt0REVAQGc9QX1gzXUs+5KOsC8ERE1F8YzFFfGFmxJPXBGxwu3y7qaOGpu7O492CBo4qJiFLCnDnqG2nnXHDevUVxZnK/dut+R9e0/3VERBQdW+aIEuJw+UVRu5yPnrmMpkTo64iIKDq2zBElpFqS9p36BeYaTYz28XB5zuRORFQctswRdWF8bBRja+v44rqVfb3SAWdyJ4CrrBAVhcEcEXUtzkzuFYHQ15F9THmTDOiIssdgjoi6FnWpt/GxUaxbtRxD1Yp1S8JRME7VQ1Qc5swRUSqijhYeWbEEIyuW4MSeL+ewVZQX5kMSFYctc0RE1DXmQxIVh8EcERF1jVP1EBWH3axERNQ11cV+9MxlfDw9g9V9PFUPUd4YzBERUSrSXmWFiKJhNysRBeLcYURE5cZgjnoKA490ce6wZHgcElGeGMxRzzAFHlN3ZwveMntx7rD4GAATUd4YzFHPMAUeN+5wnqukOHdYfAyAibrH1u14GMxRzzAFGKqFhOLj3GHxMQAm6g5bt+NjMEc9wxRgDFV5mCfFucPiYwBM1B22bsfHqxz1DFPgsWaYF9Gkoq65SosYABN1h63b8XGeOeoZpklLf/zz6wVvmd04d1g8nDyXqDur6zVMagI3tm6bMZijnqILPBjMUd4YABMlt3f7Rhx87VJbVytbt4MxmCMiIqLSYOt2fAzmiIiIqFTYuh0PB0AQERERWYzBHBEREZHFGMwR9QDOlk5E1L8YzBFZjrOlExH1NwZzRJbjbOlERP2NwRyR5ThbOhFRf2MwR2Q5rgVKRNTfGMwRWY5rgRIR9TdOGkxkOc6WTkTU3xjMEfUAzpZORNS/2M1KREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHRiCmcwAADPVJREFUREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZDEGc0REREQWYzBHREREZLGBojcAAIQQRwC8J6U8FfG1AHALwAYAF6SUx7PcPiIiIqKyKqxlTgixXgixQwhxAcC+iO+5AOCslHK/lPJlKeUeABuEEMcy3VgiIiKikiokmBNC7AZwBMBKAN+K+J5jAM5LKc95H5dS7gfwghBiW+obSkRERFRyhXSzut2ixwGnhS7s9UKIOoDdALYYXvIKgP0AzhmeJyIiIupJtgyAeMH996rh+QsAtrlBHxEREVHfsCWYexYApJTThudVkMeuViIiIuortgRz62FulQOA257XEREREfUNW4K5sO5T1WK3wfQCIcRuIcR5IcT5mzdvprdlRERERAWyJZhb2e0HSCmPSym3Sim3Pvroo2lsExEREVHhbAnmog5s6DroIyIiIrKJLcGcaeCD3+3wlxARERH1jtB55rqd7iNgBGocUYO0NL6LiIiIyBqBwZy7DmqkpbYCPmM4hYBuGsEjVVXAeavL7yEiIiKySmA3q7sGqujyL43WsqsIzptTgd7FFL6LiIiIyBq25My9BwR2+a4EAP+6rURERES9zpZg7pT771bD88+CrXJERETUh8oQzIUOsJBSXgVwHMAew0t2ANif5kYRERER2aAMwZyaGy5sKa79ADYL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",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## initialize and load data\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# the utility of O\n",
    "ul = np.sum(np.abs(test.Theta), axis=1)\n",
    "\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "ax = fig.add_subplot(111)\n",
    "plt.stem(np.log(ul+1.0e-5))\n",
    "plt.title('O util log scale')\n",
    "plt.show()\n",
    "\n",
    "# the nonzeros distribution\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "ax = fig.add_subplot(111)\n",
    "plt.hist(np.sum(test.Theta!=0, axis=0))\n",
    "plt.title('Theta nonzeros hist')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "test1 = np.linalg.norm(test.a, axis=0)\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "ax = fig.add_subplot(111)\n",
    "plt.plot(test1)\n",
    "plt.title('dict wise signal norm')\n",
    "plt.show()\n",
    "\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "ax = fig.add_subplot(111)\n",
    "\n",
    "plt.hist(test1)\n",
    "plt.title('dict wise signal norm hist')\n",
    "plt.show()\n",
    "\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "ax = fig.add_subplot(111)\n",
    "\n",
    "plt.plot(test.per_sample_regret)\n",
    "plt.title('per sample regret')\n",
    "plt.show()\n",
    "\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "ax = fig.add_subplot(111)\n",
    "\n",
    "plt.hist(test.per_sample_regret)\n",
    "plt.title('per sample regret hist')\n",
    "plt.show()\n",
    "\n",
    "print(f\"max regret pos {np.argmax(test.per_sample_regret)}\")\n",
    "print(f\"min regret pos {np.argmin(test.per_sample_regret)}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gnn",
   "language": "python",
   "name": "gnn"
  },
  "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.7.13"
  },
  "toc-autonumbering": false,
  "toc-showmarkdowntxt": true
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
