{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import copy\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from torchvision import datasets, transforms\n",
    "import time\n",
    "import random\n",
    "import pickle\n",
    "import pickle5\n",
    "\n",
    "%matplotlib inline\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.lines as lines\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "from pyhessian.hessian import hessian # Hessian computation\n",
    "\n",
    "from sharpness import calculate_loss_on_data, calculateNeuronwiseHessians_fc_layer\n",
    "from scale_invariant_flatness_measure_master.quotient_manifold_tangent_vector_pytorch2 import QuotientManifoldTangentVector, riemannian_hess_quadratic_form, riemannian_power_method\n",
    "from utils import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "os.environ[\"CUDA_DEVICE_ORDER\"] = \"PCI_BUS_ID\"\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def FisherRaoNorm2(model, X):\n",
    "    m = torch.nn.Softmax(dim=1)\n",
    "    output = model(X)\n",
    "    p = m(output)\n",
    "    return (5 + 1)**2 * (p*((output * p).sum(1).unsqueeze(-1) - output)**2).sum(1).mean().item()\n",
    "\n",
    "def FisherRaoNorm2_emp(model, X, y):\n",
    "    m = torch.nn.Softmax(dim=1)\n",
    "    output = model(X)\n",
    "    return (5 + 1)**2 * (((output * m(output)).sum(1) - output[range(len(output)), y])**2).mean().item()\n",
    "\n",
    "def calculate_relative_flatness(model, x_train, y_train,  \n",
    "                                feature_layer_id, alpha, element_loss, avg_loss,\n",
    "                                eps=1e-6):\n",
    "\n",
    "    # normalization of feature layer\n",
    "    activation = model.feature_layer(x_train).data.cpu().numpy()\n",
    "    #activation = model[:feature_layer_num+1](x_train).data.cpu().numpy()\n",
    "    activation = np.squeeze(activation)\n",
    "    sigma = np.std(activation, axis=0)\n",
    "\n",
    "    j = 0\n",
    "    for p in model.parameters():\n",
    "        if feature_layer_id - 2 == j or feature_layer_id - 1 == j:\n",
    "            for i, sigma_i in enumerate(sigma):\n",
    "                if sigma_i != 0.0:\n",
    "                    p.data[i] = p.data[i] / sigma_i\n",
    "        if feature_layer_id == j:\n",
    "            for i, sigma_i in enumerate(sigma):\n",
    "                p.data[:,i] = p.data[:,i] * sigma_i\n",
    "            feature_layer = p\n",
    "        j += 1\n",
    "        \n",
    "    train_output, train_loss_overall = calculate_loss_on_data(model, element_loss, \n",
    "                                                              x_train, y_train)\n",
    "    train_loss = avg_loss(train_output, y_train)\n",
    "\n",
    "    trace_nm, maxeigen_nm = calculateNeuronwiseHessians_fc_layer(feature_layer, train_loss, \n",
    "                                                                 alpha, normalize = False)\n",
    "    return train_output, train_loss, trace_nm, maxeigen_nm"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Load CIFAR data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "50000\n"
     ]
    }
   ],
   "source": [
    "dataset = 'cifar10'\n",
    "model_name = 'lenet'\n",
    "batch_size = 50000\n",
    "test_batch_size = 10000\n",
    "data_aug = False\n",
    "cutout = False\n",
    "use_hess_loader = True\n",
    "hess_batch_size = 1024\n",
    "num_classes = 10\n",
    "train_loader, test_loader = get_data(dataset=dataset,\n",
    "                                         train_bs=batch_size,\n",
    "                                         test_bs=test_batch_size,\n",
    "                                         data_augmentation=data_aug,\n",
    "                                         normalization=True,\n",
    "                                         shuffle=True,\n",
    "                                         cutout=cutout,\n",
    "                                         model = model_name\n",
    "                                        )    \n",
    "print(len(train_loader.dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LeNet5(\n",
      "  (conv1): Conv2d(3, 6, kernel_size=(5, 5), stride=(1, 1))\n",
      "  (pool): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)\n",
      "  (conv2): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))\n",
      "  (fc1): Linear(in_features=400, out_features=120, bias=True)\n",
      "  (fc2): Linear(in_features=120, out_features=84, bias=True)\n",
      "  (fc3): Linear(in_features=84, out_features=10, bias=True)\n",
      ")\n",
      "# params: 62006\n"
     ]
    }
   ],
   "source": [
    "model = get_model(model_name,\n",
    "                  dataset=dataset,\n",
    "                  num_classes=num_classes\n",
    "                 )\n",
    "model = model.cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([10, 84])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "i = 0\n",
    "for p in model.parameters():\n",
    "    if i == 8:\n",
    "        feature_layer = p\n",
    "    i += 1\n",
    "feature_layer.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load trained models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n"
     ]
    }
   ],
   "source": [
    "loss_val = 0.1\n",
    "file_list = []\n",
    "bs_list = []\n",
    "lr_list = []\n",
    "save_folder = \"./trained_model_cor_exp_CIFAR10/\"\n",
    "files = list(os.listdir(save_folder))\n",
    "files = [os.path.join(save_folder, f) for f in files] \n",
    "files.sort(key=lambda x: os.path.getmtime(x))\n",
    "for filename in files:\n",
    "    if len(filename.split('lenet')) > 1 and len(filename.split('labelsmoothing')) == 1:\n",
    "        if filename.endswith(\".pth\") and len(filename.split('loss'+str(loss_val)))>1: \n",
    "             file_list.append(filename)\n",
    "             lr_list.append(float(filename.split('lr')[1].split('_')[0]))\n",
    "             bs_list.append(int(filename.split('bs')[1].split('_')[0]))\n",
    "print(len(file_list))\n",
    "file_list_red = []\n",
    "bs_list_red = []\n",
    "lr_list_red = []\n",
    "startidx = 0\n",
    "endidx = len(file_list)\n",
    "for i in range(startidx, endidx):\n",
    "    file_list_red.append(file_list[i])\n",
    "    bs_list_red.append(bs_list[i])\n",
    "    lr_list_red.append(lr_list[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = torch.nn.CrossEntropyLoss()\n",
    "criterion_alldata = torch.nn.CrossEntropyLoss(reduction = 'none')\n",
    "\n",
    "inputs, labels = iter(train_loader).next()\n",
    "X = inputs.cuda()\n",
    "y = labels.cuda()\n",
    "X_np = X.cpu().numpy()\n",
    "y_np = y.cpu().numpy()\n",
    "inputs, labels = iter(test_loader).next()\n",
    "X_test = inputs.cuda()\n",
    "y_test = labels.cuda()\n",
    "X_test_np = X_test.cpu().numpy()\n",
    "y_test_np = y_test.cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# change keys for models\n",
    "def remove_module_in_keys(state_dict):\n",
    "    for key in list(state_dict.keys()):\n",
    "        if 'module.' in key:\n",
    "            state_dict[key.replace('module.', '')] = state_dict.pop(key)\n",
    "    state_dict.keys()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Calculate sharpness values"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### NOTE: Precomputed sharpness values for some trained models are saved in 'numerics_other_measures_lenet_*.pickle' in 'trained_model_cor_exp_CIFAR10' folder"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------- filename = ./trained_model_cor_exp_CIFAR10/cifar10_lenet_SGD_baseline_lr0.0001_mom0.9_wd0.0005_bs1024_seed1_20220413164644_loss0.1.pth ---------\n",
      "time for loss and acc:  18.617642164230347\n",
      "Fisher-Rao norm 2 (assumption): 9.565756\n",
      "Fisher-Rao norm 2 (emp): 3.296245\n",
      "Fisher-Rao norm elapsed time:  0.06187748908996582\n",
      "Rangamani et al. measure: 1505044.949280\n",
      "Rangamani et al. measure elapsed time:  687.954639673233\n",
      "Fisher-Rao norm 2 (assumption): 7.631615\n",
      "Fisher-Rao norm 2 (emp): 1735.211426\n",
      "Fisher-Rao norm elapsed time:  0.013159990310668945\n",
      "Rangamani et al. measure: 1675895.163770\n",
      "Rangamani et al. measure elapsed time:  142.34826183319092\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 5481.723445\n",
      "Petzka et al. measure (max eigval): 3736.948029\n",
      "Petzka et al. measure elapsed time:  2.5642058849334717\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 5965.887707\n",
      "Petzka et al. measure (max eigval): 4101.713730\n",
      "Petzka et al. measure elapsed time:  2.4640729427337646\n"
     ]
    }
   ],
   "source": [
    "train_loss_list = []\n",
    "test_loss_list = []\n",
    "train_acc_list = []\n",
    "test_acc_list = []\n",
    "\n",
    "FRnorm_list = []\n",
    "FRnorm_emp_list = []\n",
    "Rang_list = []\n",
    "Petzka_tr_list = []\n",
    "Petzka_max_list = []\n",
    "\n",
    "test_FRnorm_list = []\n",
    "test_FRnorm_emp_list = []\n",
    "test_Rang_list = []\n",
    "test_Petzka_tr_list = []\n",
    "test_Petzka_max_list = []\n",
    "\n",
    "for i in range(startidx, endidx):\n",
    "    filename = file_list[i]\n",
    "    print('--------- filename = {:s} ---------'.format(filename))\n",
    "\n",
    "    state_dict = torch.load(filename)\n",
    "    remove_module_in_keys(state_dict)\n",
    "\n",
    "    model.load_state_dict(state_dict)\n",
    "    model.eval()\n",
    "\n",
    "    start_time = time.time()\n",
    "    avg_loss, cur_acc = test(model, train_loader, criterion)\n",
    "    train_loss_list.append(avg_loss)\n",
    "    train_acc_list.append(cur_acc)\n",
    "\n",
    "    avg_loss, cur_acc = test(model, test_loader, criterion)\n",
    "    test_loss_list.append(avg_loss)\n",
    "    test_acc_list.append(cur_acc)\n",
    "    print('time for loss and acc: ', time.time() - start_time)\n",
    "    \n",
    "    # Fisher-Rao norm (under the assumption of homogeneity condition)\n",
    "    start = time.time()\n",
    "    frnorm2 = FisherRaoNorm2(model, X)\n",
    "    frnorm2_emp = FisherRaoNorm2_emp(model, X, y)\n",
    "    print('Fisher-Rao norm 2 (assumption): {:f}'.format(frnorm2))\n",
    "    print('Fisher-Rao norm 2 (emp): {:f}'.format(frnorm2_emp))\n",
    "    print(\"Fisher-Rao norm elapsed time: \", time.time() - start)\n",
    "    FRnorm_list.append(frnorm2)\n",
    "    FRnorm_emp_list.append(frnorm2_emp)\n",
    "    \n",
    "    \n",
    "    # Rangamani et al.'s measure\n",
    "    start = time.time()\n",
    "    W_tr = [np.copy(var.cpu().data.numpy()) for var in model.get_weight_tensors()]\n",
    "    \n",
    "    layer_sizes = [w.shape for w in W_tr]\n",
    "    v_init = [np.random.normal(size=layer_sizes[i]) for i in range(len(layer_sizes))]\n",
    "    \n",
    "    W_trans = QuotientManifoldTangentVector(layer_sizes)\n",
    "    W_trans.set_vector(W_tr)\n",
    "    \n",
    "    v_res_tr, errs_tr = riemannian_power_method(v_init, 1000, model, criterion, \n",
    "                                            W_trans, X_np, y_np, \n",
    "                                            tol=1e-8)\n",
    "    sp_norm_tr = riemannian_hess_quadratic_form(v_res_tr, model, criterion, \n",
    "                                            W_trans, X_np, y_np)\n",
    "    print('Rangamani et al. measure: {:f}'.format(sp_norm_tr))\n",
    "    print(\"Rangamani et al. measure elapsed time: \", time.time() - start)\n",
    "    Rang_list.append(sp_norm_tr)\n",
    "    \n",
    "    \n",
    "    ###### measures for test data ######\n",
    "    \n",
    "    # Fisher-Rao norm (under the assumption of homogeneity condition)\n",
    "    start = time.time()\n",
    "    frnorm2 = FisherRaoNorm2(model, X_test)\n",
    "    frnorm2_emp = FisherRaoNorm2_emp(model, X_test, y_test)\n",
    "    print('Fisher-Rao norm 2 (assumption): {:f}'.format(frnorm2))\n",
    "    print('Fisher-Rao norm 2 (emp): {:f}'.format(frnorm2_emp))\n",
    "    print(\"Fisher-Rao norm elapsed time: \", time.time() - start)\n",
    "    test_FRnorm_list.append(frnorm2)\n",
    "    test_FRnorm_emp_list.append(frnorm2_emp)\n",
    "    \n",
    "    # Rangamani et al.'s measure\n",
    "    start = time.time()\n",
    "    W_tr = [np.copy(var.cpu().data.numpy()) for var in model.get_weight_tensors()]\n",
    "    \n",
    "    layer_sizes = [w.shape for w in W_tr]\n",
    "    v_init = [np.random.normal(size=layer_sizes[i]) for i in range(len(layer_sizes))]\n",
    "    \n",
    "    W_trans = QuotientManifoldTangentVector(layer_sizes)\n",
    "    W_trans.set_vector(W_tr)\n",
    "    \n",
    "    v_res_tr, errs_tr = riemannian_power_method(v_init, 1000, model, criterion, \n",
    "                                            W_trans, X_test_np, y_test_np, \n",
    "                                            tol=1e-8)\n",
    "    sp_norm_tr = riemannian_hess_quadratic_form(v_res_tr, model, criterion, \n",
    "                                            W_trans, X_test_np, y_test_np)\n",
    "    print('Rangamani et al. measure: {:f}'.format(sp_norm_tr))\n",
    "    print(\"Rangamani et al. measure elapsed time: \", time.time() - start)\n",
    "    test_Rang_list.append(sp_norm_tr)\n",
    "    \n",
    "    \n",
    "    # Petzka et al.'s measure (for a specific layer and assume all layers have bias parameters)\n",
    "    # this method modifies parameter value hence should be calculated at the end\n",
    "    start = time.time()\n",
    "    feature_layer_id = 8  # 'fc3.weight'\n",
    "    #feature_layer_num = 1\n",
    "    alpha = 0\n",
    "    \n",
    "    train_output, train_loss, trace_nm, maxeigen_nm = calculate_relative_flatness(model, X, y, \n",
    "                                feature_layer_id, alpha, \n",
    "                                criterion_alldata, criterion,\n",
    "                                eps=1e-6)\n",
    "    print('Petzka et al. measure (trace): {:f}'.format(trace_nm))\n",
    "    print('Petzka et al. measure (max eigval): {:f}'.format(maxeigen_nm))\n",
    "    print(\"Petzka et al. measure elapsed time: \", time.time() - start)\n",
    "    Petzka_tr_list.append(trace_nm)\n",
    "    Petzka_max_list.append(maxeigen_nm)\n",
    "        \n",
    "    \n",
    "    ###### measures for test data ######\n",
    "    # Petzka et al.'s measure (for a specific layer and assume all layers have bias parameters)\n",
    "    # this method modifies parameter value hence should be calculated at the end\n",
    "    start = time.time()\n",
    "    feature_layer_id = 8  # 'fc3.weight'\n",
    "    #feature_layer_num = 1\n",
    "    alpha = 0\n",
    "    \n",
    "    test_output, test_loss, trace_nm, maxeigen_nm = calculate_relative_flatness(model, X_test, y_test, \n",
    "                                feature_layer_id, alpha, \n",
    "                                criterion_alldata, criterion,\n",
    "                                eps=1e-6)\n",
    "    print('Petzka et al. measure (trace): {:f}'.format(trace_nm))\n",
    "    print('Petzka et al. measure (max eigval): {:f}'.format(maxeigen_nm))\n",
    "    print(\"Petzka et al. measure elapsed time: \", time.time() - start)\n",
    "    test_Petzka_tr_list.append(trace_nm)\n",
    "    test_Petzka_max_list.append(maxeigen_nm)\n",
    "    \n",
    "res = {\n",
    "        'train_loss_list': train_loss_list,\n",
    "        'test_loss_list': test_loss_list,\n",
    "        'train_acc_list': train_acc_list,\n",
    "        'test_acc_list': test_acc_list,\n",
    "        \n",
    "        'file_list_red': file_list_red,\n",
    "        'bs_list_red': bs_list_red,\n",
    "        'lr_list_red': lr_list_red,\n",
    "        \n",
    "        'FRnorm_list': FRnorm_list,\n",
    "        'FRnorm_emp_list': FRnorm_emp_list,\n",
    "        'test_FRnorm_list': test_FRnorm_list,\n",
    "        'test_FRnorm_emp_list': test_FRnorm_emp_list,\n",
    "\n",
    "        'Rang_list': Rang_list,\n",
    "        'Petzka_tr_list': Petzka_tr_list,\n",
    "        'Petzka_max_list': Petzka_max_list,\n",
    "    \n",
    "        'test_Rang_list': test_Rang_list,\n",
    "        'test_Petzka_tr_list': test_Petzka_tr_list,\n",
    "        'test_Petzka_max_list': test_Petzka_max_list,\n",
    "    }\n",
    "filename = save_folder+'numerics_other_measures_lenet_'+str(startidx)+'_'+str(endidx)+'.pickle'\n",
    "with open(filename, 'wb') as handle:\n",
    "    pickle.dump(res, handle, protocol=pickle.HIGHEST_PROTOCOL)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Load precomputed results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "filenames = []\n",
    "\n",
    "filenames.append('./trained_model_cor_exp_CIFAR10/numerics_other_measures_lenet_0_15.pickle')\n",
    "filenames.append('./trained_model_cor_exp_CIFAR10/numerics_other_measures_lenet_15_30.pickle')\n",
    "filenames.append('./trained_model_cor_exp_CIFAR10/numerics_other_measures_lenet_30_44.pickle')\n",
    "filenames.append('./trained_model_cor_exp_CIFAR10/numerics_other_measures_lenet_44_58.pickle')\n",
    "\n",
    "file_list = []\n",
    "bs_list = []\n",
    "lr_list = []\n",
    "\n",
    "train_loss_list = []\n",
    "test_loss_list = []\n",
    "train_acc_list = []\n",
    "test_acc_list = []\n",
    "\n",
    "FRnorm_list = []\n",
    "FRnorm_emp_list = []\n",
    "Rang_list = []\n",
    "Petzka_tr_list = []\n",
    "Petzka_max_list = []\n",
    "\n",
    "test_FRnorm_list = []\n",
    "test_FRnorm_emp_list = []\n",
    "test_Rang_list = []\n",
    "test_Petzka_tr_list = []\n",
    "test_Petzka_max_list = []\n",
    "\n",
    "for filename in filenames:\n",
    "    try:\n",
    "        with open(filename, 'rb') as handle:\n",
    "            res = pickle.load(handle)\n",
    "    except ValueError:\n",
    "        with open(filename, 'rb') as handle:\n",
    "            res = pickle5.load(handle)    \n",
    "    \n",
    "    file_list += res['file_list_red']\n",
    "    bs_list += res['bs_list_red']\n",
    "    lr_list += res['lr_list_red']\n",
    "\n",
    "    train_loss_list += res['train_loss_list']\n",
    "    test_loss_list += res['test_loss_list']\n",
    "    train_acc_list += res['train_acc_list']\n",
    "    test_acc_list += res['test_acc_list']\n",
    "    \n",
    "    FRnorm_list += res['FRnorm_list']\n",
    "    FRnorm_emp_list += res['FRnorm_emp_list']\n",
    "    Rang_list += res['Rang_list']\n",
    "    Petzka_tr_list += res['Petzka_tr_list']\n",
    "    Petzka_max_list += res['Petzka_max_list']\n",
    "    \n",
    "    test_FRnorm_list += res['test_FRnorm_list']\n",
    "    test_FRnorm_emp_list += res['test_FRnorm_emp_list']\n",
    "    test_Rang_list += res['test_Rang_list']\n",
    "    test_Petzka_tr_list += res['test_Petzka_tr_list']\n",
    "    test_Petzka_max_list += res['test_Petzka_max_list']\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "#### Scatter plots for generalization gap vs. sharpness measures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "g_gap2 = np.array(test_loss_list) - np.array(train_loss_list)\n",
    "idx = np.array(lr_list) >= 0.001"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.23315323004267638\n",
      "0.5376296643691112\n",
      "0.5554384582428564\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAacAAAEWCAYAAADCeVhIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAwwklEQVR4nO3de3gkVZ3/8fcnAwyGWRAHvDCYDt7v4jIg6KrcvIC66npbCSgiRrkpiLpquApRd1cRRbxEXFAmKKCIN9yfoIKgIgwKoiIokIwOiDOsXMNwmXx/f5zqoaanOulOOulK+vN6nno6fepU9amqmf52nXPqHEUEZmZmZdLV7gKYmZnVcnAyM7PScXAyM7PScXAyM7PScXAyM7PS2ajdBZgvttpqq+jt7W13MczM5pSrrrpqdURsXZvu4NQivb29LF++vN3FMDObUySNFqW7Ws/MzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMrE2Gh4fp7e2lq6uL3t5ehoeH212k0nBXcjOzNhgeHqa/v5+xsTEARkdH6e/vB6Cvr6+dRSsF3zmZmbXBwMDAusBUNTY2xsDAQJtKVC4OTmZmbbBixYqm0juNg5OZWRv09PQ0ld5pHJzMzNpgcHCQ7u7u9dK6u7sZHBxsU4nKxcHJzKwN+vr6GBoaolKpIIlKpcLQ0JA7Q2QUEe0uw7ywdOnS8MCvZmbNkXRVRCytTfedk5mZlY6Dk5mZlY6Dk5mZlY6Dk5mZlY6Dk5mZlY6Dk5mZlY6Dk5mZlY6Dk5mZlY6Dk5mZNW2m56LyfE5mZtaU2ZiLyndOZmbWlNmYi6qtwUnSUyR9VNLlklZJulvS1ZIGJG1Wk/c4SVFneX/BvrskHSHpj5LWSPqLpE/V7jeXf29Jv5B0r6T/k3SupO1m6tjNzOaq2ZiLqt3VegcAhwDfBYaBB4HdgBOBN0naOSLuq9nmCGB1TdpVBfv+NPAe4NvAp4CnZ++fJ2nPiBivZpT0b8A3gWuADwBbAIcDP5e0NCJumc5BmpnNJz09PYyOjhamt0q7g9M3gY9HxJ25tC9K+hMwALwD+FzNNudHxMhEO5X0TOAw4LyIeH0u/Wbgs8C/A2dlaRsDpwB/AV4UEfdk6T8kBb3jgP4pHp+Z2bwzODi4XpsTtH4uqrZW60XE8prAVHV29vqsou0kbS5posD6FkDAyTXpXwbGgH1zaS8BtgFOqwamrGxXAxcDb84CmJmZMTtzUZW1Q8S22ettBet+C9wJrMnaiPYqyLMjMA5ckU+MiDXA1dn6fF6AXxbs53Jgc+ApDZfczKwD9PX1MTIywvj4OCMjIy2fJLF0wUnSAuBo4CGyqrfMHcAQqbruNcCHgQrwA0n71+xmG2B1RNxf8BErga0kbZLLW00vyguwpE5Z+yUtl7R81apVEx2WmZk1od1tTkVOBnYBPhIR11cTI+Lk2oyS/gf4HfBpSd/MVct1A0WBCWBNLs8D2St18ufzbiAihkgBk6VLl3pKYTOzFinVnZOkE4BDgaGI+Phk+SPiduCLwCOBF+RWjQEL62y2aS5P/rUof21eMzObBaUJTpKOA44CTgfe3cSmI9nrVrm0W0hVd0UBZwmpyu+BXN5qelFeKK7yMzOzGVKK4JQFpmOBrwIHRkQzVWRPzl7znSeuJB3bTjWfsymwPbC8Ji+kqsRaOwN3ATc0UR4zM5umtgcnSceQAtOZwAH5h2NzeTaStEVB+uOBg4DbgV/kVp0NBOlB2rx3ktqP8iMUXgLcChwoaVFu388FdgXOjYgHmz4wMzObsrZ2iJB0CHA8sAK4CNhHUj7LbRFxIbAIuFnS+cB1wD+ApwIHZuvekh9JIiKulXQqcKik84ALeHiEiEvI9QKMiAclvZcU0C6V9GVS9/EjgFWkwGlmZrOo3b31qs8Y9ZCq9GpdAlwI3Ad8C3g+8FpSQFpNCmj/FRFXFGx7OKk9qh94ZZb/FOCY2ruziDhX0n2kNq9Pknru/Rj4j4hwe5OZ2SxTc807Vs/SpUtj+fLlk2c0M7N1JF0VEUtr09ve5mRmZlbLwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzErHwcnMzEqnJcFJ0mJJx0g6uhX7M7PONjw8TG9vL11dXfT29jI8PNzuItks26hF+9kKOA4I4IQW7dPMOtDw8DD9/f2MjY0BMDo6Sn9/PwB9fX3tLJrNIkXE9HcibQ68DiAivjrtHc5BS5cujeXLl7e7GGZzXm9vL6OjoxukVyoVRkZGZr9ANqMkXRURS2vTW3LnFBF3AR0ZlMystVasWNFUus1P7hBhZqXS09PTVLrNTw5OZlYqg4ODdHd3r5fW3d3N4OBgm0pk7VA3OEkal7S2yeWhZj5c0lMkfVTS5ZJWSbpb0tWSBiRtVpD/qZLOl/QPSfdKulTS7nX2vYWkUyStlLRG0u8lHSRJBXm7JB0h6Y9Z3r9I+lRRGcxsZvX19TE0NESlUkESlUqFoaEhd4boMHU7REg6g9T7rikR8faGP1z6BHAI8F3gcuBBYDfgTcBvgZ0j4r4s7xOBK4CHgJOBO4F3As8C9oqIi3L73QS4DHgecApwHbAXqdPG8RFxXE05PgO8B/g28EPg6cBhwKXAnhExPtmxuEOEmVnz6nWIaElvvamStBT4U0TcWZN+IjAAHBYRn8vSzgFeD+wQEVdnaYuA3wNrgKdFdjCSDgZOBd4TEafk9vst4NXAkyNiNEt7JnAt8O2IeH0u72HAZ4G+iDhrsmNxcDIza1694NTWNqeIWF4bmDJnZ6/PAsiq1/4VuLgamLLt7wFOA54C7Jjbfh9gDPhyzX5PBjYG3pxLewugbF3el7N97Nvo8ZiZWWuUtUPEttnrbdnrc4CFwC8L8l6eve4Iqf0I+GfgNxGxpibvFaSqynwg2xEYz9atk217dU1eMzObBU0FJ0kvlPT9rPPCQ9PtEFHnMxYAR5PalqrVadtkrysLNqmmLcletwQeUZQ3Iu4HVufyVve9OltXtO+tsjasorL2S1ouafmqVavqH5SZWQEP01Rfw8FJ0ouBnwLPB36VbftT4EpStdjvgDNbUKaTgV2AYyLi+iyt2q+0KICsqckzUd5q/nw/1e5J8ub3uZ6IGIqIpRGxdOutt66zCzOzDVWHaRodHSUi1g3T5ACVNHPnNADcCjwD2D9L+1hE7Ay8AtiO1P4zZZJOAA4FhiLi47lVY9nrwoLNNq3JM1Heav6x3PuxSfLm92lm1hIDAwPrxg+sGhsbY2BgoE0lKpdmgtNOwGkRsYrURrNu+4j4EemuacqDvko6DjgKOB14d83qW7LXJWyomlatxvsHcF9RXkkLSYPU5qv8biFV3RUFqCWkKr8HGjgEM7OGeZimiTUTnBby8Jd6tRrsn3LrrwZ2mEohssB0LGl8vgNjw/7t12afuUvB5jtnr8sBsmeSfg08ryDg7ESqgsz3+b6SdB52qinTpsD2NXnNzFrCwzRNrJngdCtZL7qIuBe4g6yrd2ZbUieGpkg6hhSYzgQOKHrgNesy/j1gV0nPzW27CDgQ+BPr97b7OqmdqL9mV4dnZTw7l3Y2qQff4TV535ntwxXAZtZyHqZpYs2MSn4l8MLc+x8BR0gaJQW5Q0kdJRom6RDgeGAFcBGwT83oQrdFxIXZ3x8G9gB+JOnTwF2kALIEeGXN3daXgbcDJ0nqJY0QsTdphIgTI2KkmjEirpV0KnCopPOAC0gjRLwHuISHewyambVMdTimgYEBVqxYQU9PD4ODgx6mqSoiGlqAl5LuIh6RvX8CqZpvPFtuAZ7V6P6yfZxBumupt1xck//pwHdId21jpCGK9qyz70cCn8vKdT/wB1IAVUHeBcCRwPVZ3pXAScCiRo9lhx12CLMyW7ZsWVQqlZAUlUolli1b1u4ilZbP1ewBlkfBd+q0hi/KRm7YA1gLXBbFoz10BA9fZGVWO7sspCokD6i6IZ+r2VXKsfXmEwcnKzPPLts4n6vZVcqx9cxsdrjbcuN8rsrBwcmsA7jbcuN8rsrBwcmsA7jbcuN8rsrBwcmsA3h22cb5XJWDO0S0iDtEmJk1b9odIiS9NXugtd76XklvnWL5zMzM1mmmWu904AUTrH9+lsfMzGxamglOmmT9xjw8WrmZmdmUNdshorCBStIjgVeSBoc1MzOblgmDk6Rjq1OwkwLTsoKp2dcCtwNvAr4xC2U2M7N5brJRya8Gvkaq0nsrcClwU02eAO4BLidNVWFmZjYtEwaniPgOaRRwJFVI0038eDYKZmZmnavh+ZwiYreZLIiZmVlVUx0iJC3InndaJulCSc/L0rfM0pfMTDHNzKyTNHznJKmbNPvtC4B7SVOYb5mtvgv4BPA/wFEtLqOZmXWYZu6cjgOWkqY6fwK5554iYi1wHvDyVhbOzMw6UzPB6Y3AUNZJouhh2z8Dva0olJmZdbZmgtM2wDUTrB8D/ml6xTEzM2suON0OTNTh4ZnALdMrjpmZWXPB6cfA27OOEeuRtB1wAPC/rSqYmU1ueHiY3t5eurq66O3tZXh4uN1FMmuJZoLT8aTeeVcCB5FGhniFpI8DvwbuBz7e8hKaWaHh4WH6+/sZHR0lIhgdHaW/v79ugHIgs7mkqckGJe1A6i7+7JpVvwP2i4iJ2qTmNU82aLOtt7eX0dHRDdIrlQojIyPrpVUD2djY2Lq07u5uz/BqbTftyQYBIuKqiHgu8BzgzcC/AztExHOmEpgkfVjSuZJukhSSRibIe0aWp2h5Q0H+hZI+KulmSfdLulHSUZI2rrP/t0r6jaT7JN0m6TRJWzd7TGazZcWKFQ2nDwwMrBeYAMbGxhgYGJiRsplNV8MP4eZFxO9Id0vT9THg/0jVgo9scJv9CtKuKEg7G3gN6U7vl8AuwAnAk4D98xklHQGcBFwCvBfYFngfsIuknSLi3gbLZjZrenp6Cu+cenp6NkhrJpCZlcGUglMLPTEibgKQ9Dtg0WQbRMSyyfJI2psUmE6KiCOz5NMk3QG8T9JQRPwiy7sVcCKpLW2P7IFiJF0JfJcUrD7W7IGZzbTBwcHCqrrBwcEN8jYTyMzKoNnJBluqGpiaoWRzSROVfZ/s9eSa9Or7fXNpryUNxXRKNTBlZfseaXqQfF6z0ujr62NoaIhKpYIkKpVK3TakwcFBurvX72hbL5CZlUFbg9MU3Zkt92WDzz6/IM+OwMqI+Es+MXt/S7Y+nxdS1V+ty4GnSZr0js6sHfr6+hgZGWF8fJyRkZG6nRuaCWRmZdDuar1m/A34NHAVaeDZ5wKHA5dK2jsiLsrl3Qb4Q539rCS1KeXzVtOL8irLc0PtSkn9QD+4esTKr6+vz8HI5ow5E5wi4kM1SedLOos0W+8XgCfn1nWTnrsqsiZbn89LnfxravLUlmkIGILUlbxe2c3MrDlzsVpvnYj4E3AO8CRJT8mtGgMW1tls02x9Pi918m9ak8fMzGZB03dOkhYATyONFrFBcIuIn7WgXM0YyV634uGqt1uoPw7gEtavwrsll/7ngryBxww0M5tVTQUnSf8BfAjYfIJsC6ZVouZVq/Nuy6VdCfRJeny+U4Skx5Paj75bk7ef9BxUbXDaGbg+Iu5peanNzKyuhqv1JL2DNHbe1aTZbkXqmv3fpAdpl5MGf205SZtJ2rQg/Xmkeaaui4gbc6u+nr0eXrNJ9X1+ULHvAPcBh2Z3hdV9v5o0qaIHIDObZR4H0IiIhhZS8PlF9vdi0oSDu2fvH0e6czmg0f1l2+1HCnRHZdv/I/d+v1y+7YFbSR0f3ge8C/g8qcPCGPAvBfv+HqlK7jTgHdlrAGcW5D0yW/dT0l3U8cA9wHXAokaOZYcddggza8yyZcuiUqmEpKhUKrFs2bL11nV3d0f2fzKA6O7uXi+PzR/A8iiKD0WJhRlT9+0jsr8flQWnl+bWnwBc0+j+sm0uzv8DrFkuzuV7LHAm8EfgLuBBYAXwVeBpdfa9KWnkhxFST7ybgKOBjevk3580meIa4O+kYY8e3eixODiZNWay4FOpVAq/EyqVSnsLbjOiXnBqeFRySXcB74+IIUkLSVVh+0TEN7L17yCNslDY7Xq+86jkZo2ZbDT1rq4uir6XJDE+Pj4bRbRZ1IpRyVcA2wFExP3AX4AX5dbvSGp7MjOra7JBaOs90O4H3TtLM8HpZ8Arc+/PBd4l6X8knQEcCFzQwrKZ2Tw0WfDxOIAGzQWnzwCnSnpE9v5YUjB6G6ljw4XAh1tbPDObbyYLPh4H0KDJmXALdyBtAayNDn8WyG1OZo0bHh5mYGCAFStW0NPTw+DgoINPh6rX5tRMh4i3RMTXJ8lzakQcMsUyzmkOTmZmzWtFh4jTJe02wQd8Bnj3VApnZmaW10xw+n/AtyU9p3aFpE8Ch5GeKzIzM5uWZoLTm0lzJP1Q0rruNpI+Thq14RMRcWyLy2dmZh2o4eAUEWuAVwF3A/8r6VGSjgf+AzgpIj4yQ2U0M7MO09So5BHxf5JeAfyCNNTPNsDnIuL9M1E4MzPrTE1PNhgRI8BepGkzvhQR72l1oczMrLPVvXOSNE4acLFuFtIIEe/KpUVEzJmp383MrJwmCiRfY+LgZGZmNiPqBqeI2H8Wy2HWVh6xwKxcXAVnHW94eJj+/n7GxsYAGB0dpb+/H8AByqxNmpmmfVzSLZJ2rLO+T9La1hXNbHYMDAysC0xVY2NjDAwMtKlEZtZsb73FwMWS3jAThTFrh8nmFzKz2ddscPoAcBXwDUl+6NbmBU9uZ1Y+zQan1cAewNeBEyWdLsntVjanlW1yu+HhYXp7e+nq6qK3t5fh4eG2lMOsnabyEO6DEbEfcDxposELJW3Z8pKZzZIyTW5X7ZwxOjpKRKzrnOEAZZ2mmfmcxoF9I+KsXFofcBqwAvgGcFRELJiJgpad53OyVujt7WV0dHSD9EqlwsjIyOwXyGyGtWI+pw1ExDDwUuBRwFHT2ZdZpxseHi4MTODOGdZ5mglOXwVurE2MiMuAnYHlpDsoM2tStTqvHnfOsE7TzJQZb4+IX9VZd2NEPD8itmu2AJI+LOlcSTdJCkkjk+R/vqSLJN0t6S5J/ytp+zp5t5H0NUmrJN0nabmkN9bJu1DSRyXdLOl+STdKOkrSxs0ek1mzip61qmpn5wyzdmnmIdy1kt4ywfo3S3poCmX4GLA76a7sH5OUYWfgEmA74BjgWODJwKWSnl2T91HAZcC/AV8A3gvcA5wj6e0Fuz8bOBr4CXAIcDFwAvDlKRyTWVMmqrZrV+cMs3Zqphu4smWq6+t5YkTcBCDpd8CiCfJ+FngAeHFErMy2OQe4DvgU8LJc3g+Rgti/RsT3srxfAX4JfFLSuRFxT5a+N/Aa0qSJR2bbnybpDuB9koYi4hdTODazhvT09NTtCOHAZJ1oWh0iavSQZsltSjUwTUbSk4AdgXOrgSnbfiVwLrCnpMfmNtkHuLEamLK8a4FTSB049q7JC3ByzcdW3+/bSBnNpqpsz1qZtduEd06SXkO6o6jql7RnQdZHAXuSqtFmSnVMv18WrLscOADYAfiBpMcBS4Cih0Muz+3vnNzfKyPiL/mMEfEXSbfkPttsRlTvjjwyulkyWbXe9sD+2d8BvDhbat1Dmrr90FYVrMA22evKgnXVtCVTyFvN/4c6n7sS2LZohaR+oB/cm8qmr6+vz8HILDNhtV5EHB8RXRHRRWpP2rf6vmbZPCJeFhF/nsGyVus87i9Yt6YmTzN5q38X5a3m7y5aERFDEbE0IpZuvfXWdTY3m18OPvhgNtpoIySx0UYbcfDBB7e7SDYPNdMhYjtg1UwVpAHVfrYLC9ZtWpOnmbzVv4vyVvMX9/E16zAHH3wwX/jCF9a9X7t27br3n//859tVLJuHmnnOaTQixiRtJmnPbP6mx8xk4Wrckr0uKVhXTVs5hbzV/EV5q/mLqgfNOs7Q0FBT6WZT1VRvPUkHkb6ofwR8DXhmlv5oSWskvbP1RVznyux1l4J1O5PaxK4CiIhbs3LuXCcvpBEt8vteIunx+YzZ+21q8pp1rLVri+cTrZduNlXNPIT7euBU4KfAgeSeaYqIvwP/C7y2xeVbJ2vPWg68UVK1wwPZ328EfhIRf8tt8nXgiZJencu7ADgMuAO4oCYvwOE1H1t97yGhzYAFC4rHda6XbjZVzdw5fQD4aUS8DvhOwfrlwLOaLYCk/bJhgo4Ctga2qL6XtF9N9veS2oYulXS4pMOBS7PjOLIm7yeAUeAsScdnPesuInULf39ErHsmKyJ+AHyf9MDtaZLeIek04H3Asmz8QLOOV2/8v4nGBbSHea6uJkREQwtwL3Bo9vdiYBzYPbf+HcB9je4vt93FpCq5ouXigvy7AD8mdV+/G/h/wD/X2fcS4EzSJIlrgF8Db66Td1PgRGCE1HPvJtJwRhs3chw77LBDmHWCgw46KBYsWBBALFiwIA466KB2F2lOWLZsWXR3d6/3Hdfd3R3Lli1rd9HaClgeBd+pzczndBdpvqbPSlpM6rm3Z0T8JFt/NPDeiNiq4cg4j3g+JzObiOfqKtaK+ZyuAV5eZ+ddpHafK4vWm9nDXLXTmeoN7uu5uoo1E5w+B+wl6QTScEUAXZKeShrb7pmkgVnNrA5Pw9656o0i49FlijXznNPZpOktBkijgEPqofcH4HXA8RHxw5aX0GweKZq3aWxsjIGBgTaVyGaLB/dtTjMjRBARR0k6D+gDnkbqTv4n4MyIcIOL2SRctdO5PLhvcxrqECFpa+AJwOqI2GCqdnOHCGuMG8XN1jelDhGSuiR9EbiVNOr4DZIuy4KVmTXJVTtmjZmszelQ0pQQfwPOA64FXgB8aYbLZTYv9fX1MTQ0RKVSQRKVSsXTsJsVmCw4vZXU+eHpEfHGiNge+ArwakmPnOGymc1LfX19jIyMMD4+zsjIiAPTDHGX/bltsuD0VOCMyA31Q5rmfAHwlBkrlZk1xF/Axdxlf+6bLDhtxsPTT1TdkltnZm3iL+D63GV/7mvkOafa7nzV96rNaGazx1/A9bnL/tzXyHNOe0t6bO59NylAvVHS9jV5IyI+3arC2dwxPDzs5zdmmb+A6+vp6Snssu/RGOaORoLTPtlS610FaQE4OHWYavVS9Vd8tXoJcICaQf4Crm9wcHC9f5PgLvtzzYQP4Up6SbM7jIhLplWiOaqTH8L1g6XtUfujANIXsLumJ76bnxvqPYTb1NxLXjyfUxFJhfNxSWp30ea9ZcuWRaVSCUlRqVTm/NxA8+14bHJMdz4nm5jvnHznZNPjO8HO1Ir5nMwKeUgeawX3PrQ8ByebNg/J03qd+HCtex9anqv1WqSTq/WstTq1esvVw53J1Xpmc0SnVm+5etjyHJzMSqZTq7dcPWx5rtZrEVfrWau4ess6iav1zOaIMlRvdWKHDCuXORWcJEWd5Z6CvE+VdL6kf0i6V9Klknavs98tJJ0iaaWkNZJ+L+kgSR7c1mbERF/+7a7eatVo5w5wNi1FT+aWdSGNPPAzYN+a5c01+Z4I3A7cBnwYOBj4DfAgsGdN3k2AK7J1JwHvJM36G8BxjZatk0eIKJsyjDIwURmWLVsW3d3d642m0d3dXZrRECqVSuGIH5VKpeF9zPYxluGa29RQZ4SItgecZpbsH/kZDeQ7B1gLbJ9LWwSMAteTtbVl6Qdn+z2sZh/fAh4AKo2UzcGpHMrwxT9ZGVrx5T+TWjEc1WweYxmuuU3dvApO2d3Oojp5NgPWAD8uWHd0to+dcmmXAfcCm9bkfVGW94ONlM3BqRzK8MU/WRnKPhZhK87hbB5jo+X13VU51QtOc6rNKfMGYAy4W9Lfs7aiLXLrnwMsBH5ZsO3l2euOAJK6gH8GfhMRa2ryXkH6R75jKwtvM6sM3bAnK0O9KS3KMtVFKzpkzOYxNnLNPWvw3DPXgtMVwHGkAPU24CfAocClkhZlebbJXlcWbF9NW5K9bgk8oihvRNwPrM7l3YCkfknLJS1ftWpVc0diM6IMX/yTlaEMvfEm0ooOGbN5jI1c8059sHlOK7qdmksL8BHSHc5A9n6/7P0BBXmfkK07OXv/+Oz91+rsewVwdSPlcLVeOZSh/aGRMnRCFdNsHWMj57vsVamdjPnQ5lR4ALAxcD/wi+z967N/eAcV5H1Gtu5j2fvF2fuz6+z779X9TrY4OJVHGb74y1CGTjLZ+S5DW6QVm7fBKR0bNwM3ZH/vkv3DO7Eg30uzdYdk77tI7VeXFeRdCIwD5zZSBgen5vkL3GZLGe6orVi94DTX2pw2IGlTYFvSM00A15LupHYpyL5z9rocICLGgV8Dz5O0sCbvToCqea213EBts6ndDzZb8+ZMcJK0uM6qE4CNgO8BRMQ92d+7SnpubvtFwIHAn0gdK6q+DnQD/TX7PRx4CDi7BcW3Gm6gnlkenWFDfX19jIyMMD4+zsjIiANTyW3U7gI04ShJOwM/JXVUWATsDewG/Ao4JZf3w8AewI8kfRq4izTywxLgldmtZNWXgbcDJ0nqBa7L9vs6UtXgyAweU8cqQ5fv+ap2PqjqXSngL2SbM+bMqOSSXkMazeFZpI4Ma0l3QecAJ0XNc0qSng58AngJ6aHdX5OGI7qoYN+PBE4E/i3b943A54FTo8ET5FHJm+ORt2eOz63NJfVGJZ8zwansHJya06mzvc6Grq4uiv5fS2J8fLwNJTKrz1NmWKm4gXrmzPaDyG7fspng4GRt02wDtb8EGzObozO416XNmKL+5V6aX/yc08zycyrNma1nyPxwa+t12vN/zOeHcMuwODjNrE7+Eizzl5WHBWqtTvwRVi84uVrP5oRO7Xpe9mqzZtu3XDU7MT//l1MUsbz4zqlsOvXOqezH3cwv/cnylvkOcbZ04p0ortZzcJrLOrG6I2JufFk1GlQmCrSden1rlf3HyExwcHJwmvM68Zd1u76smj3XjeSfKNB24pdykU4M0g5ODk42B7Xjy6rZz5wofz5oLViwoG4Amgt3iLOl036EOTg5ONkcNdtfVs3exdTLv3jx4g2CVu1SDWK+c+pc9YLTXBr41awj9fX1zerIGc32jKyXfvvttxemL1iwgPHxcXp6ehgcHFx3bEXDWZVl6nqbfQ5OZraenp6ewoFjJ+o2XpS/nvHx8Q3G+KsGqIGBAVasWLFB4LLO4+ecSs7Phdhsa3b4o3r5Fy8unoKtXpDzfEu2nqK6Pi/ta3PKty8sXrw4Nt5441lvDO+kxtipmu/nqRW99Tqx55k1D3eIKH9wKvrPXLTMVCNxmb9M8o3m1V5f7QoKZT5PZTPfg7hNX73g5PmcWqQV8znVmySu1kzNy1PWSeqK5n6qasccUGU9T2ZzkedzKqHa9qRGG5Vnal6eso5fVzTeWFU7xh0r63kym08cnNqkaEBPSZNuN5Pda6czSd1MdtyY7Et/toPCbE/mZ9aRiur6vMx8m1O9hw5rn5TfZJNNYvHixbNSZz/VtpSZboOpd66Y4Ta4etzmZNY6uENEuYJTveFaql+27WpAnkoD9kw/3T9RR5F2BQU39Ju1Rr3g5A4RLdJsh4j51Kje1dVF0b+jVnbcGB4eZmBggNHRURYsWMDatWupVCp+UNNsjnOHiJJp9kHHMpuNNpjqA5oRwUMPPURE+EFNs3nMwalN+vr6GBoaolKpIIlKpTLrXaJbZT4FWjMrB1frZSR1Ae8F3gX0AquAc4BjIuLeybZvxXNOc1m12s3joplZM+pV6zk4ZSR9BngP8G3gh8DTgcOAS4E9I2LCxpNOD05mZlNRLzh5VHJA0jNJgei8iHh9Lv1m4LPAvwNntal4ZmYdx21OyVsAASfXpH8ZGAP2ne0CmZl1MgenZEdgHLginxgRa4Crs/VmZjZLHJySbYDVEXF/wbqVwFaSNqldIalf0nJJy1etWjXjhTQz6xQOTkk3UBSYANbk8qwnIoYiYmlELN16661nrHBmZp3GHSKSMeDRddZtmstT11VXXbVaUr1hxbcCVk+xbDazfG3Ky9emnFp9XSpFiQ5OyS3AMyQtLKjaW0Kq8ntgoh1ERN1bJ0nLi7pKWvv52pSXr005zdZ1cbVeciXpXOyUT5S0KbA94AeYzMxmkYNTcjZplOvDa9LfSWprat3kRGZmNilX6wERca2kU4FDJZ0HXEAaIeI9wCVM/wHcoWlubzPH16a8fG3KaVaui4cvykhaQLpz6ieNrbeadEd1TETc076SmZl1HgcnMzMrHbc5mZlZ6Tg4mZlZ6Tg4NUnSUyR9VNLlklZJulvS1ZIGJG3W4D4ulhR1Fj/XMUXTvTaSdp3gulSXF87Gscw3Lfp/s7Gkj0i6TtL9km6X9C1JT5vp8s9Xkp4qaTg7p3dKGpP0R0knSXpcg/t4k6TTJV0j6cHs/0nvtMvmNqfmSPoEcAjwXeBy4EFgN+BNwG+BnSPivkn2cTHwTOCIgtUXRMT/tbLMnWK610bSY4CXFqxaSOqhtBrYNiIebHHR570WXBsBPwD2As4HLgS2Bg4GNgFeGBF/mMFDmJck7QEMkK7JX4GHgGcDbwfuAraPiL9Pso+LgecD1wCPBJ4KbBcRI9MqXER4aWIBlgJbFKSfSHpW6tAG9nExMNLuY5lvSyuuTZ39viXb/r/bfYxzdZnutQFem+X7Uk36E0hDi13U7mOcTwvwxux8f7CBvD3ARtnfn8u2651uGVyt16SIWB4RdxasOjt7fVaj+5LUJWnz7FehTVMrr02NA7PX06a4fcdrwbXZLXs9vWa/N5Fmq95DUs/0Smk51XFCt5wsY0SsiIiHWl0AB6fW2TZ7va3B/EuAe4A7gXsknee68xnT7LVZR9J2pC/GyyLi+paWyqDxa7Mwey0agLma9vyWlKgDSdpU0laStpX0MuBL2aoL2lUmjxDRAtkDvEeT6msbGU3iZuDnpLr2taT/VIeSfv39S0RcO1Nl7TRTuDa1DiDNkuy7phZr8tr8PnvdnfT/prqPbh4OSo9vdRk7yIHAKbn3I8C+EXFpe4rj4NQqJwO7AB9p5Nd1RLy9Jumbkr5Laos6ieJGeZuak2ni2uRlX577kxqGz215yexkGr82y4CjgI9Kuhe4iDR1w/HZKxTMuWYNOx/4I7AIeB7wrzx8Xtuj3Q1vc30BTqCgoXaK+/op6VfkI9p9XPNhme61AfbOtv9iu49lvi1TuTakXmS/ybarLhfn9vWedh/XfFmA55AmYP1wk9u5Q0QZSDqO9GvudODdLdjlCLCABhohbWItujbvyF5dpddCU702EXFtRDwPeDLwEuDJEbErD7dH/bG1Je1cEfFb0g+Bg9tVBlfrTVH2H+xY4KvAgZH9bJimJ5PunPyc0zS04tpIejTwauCaiPB8Xi3SimsTEX8G/pxL2otU9frzVpTR1nkE8Kh2fbjvnKZA0jGk/2BnAgdExHidfI+T9LSs0baatkXWllGb95XAC4ELI2LNDBV93pvOtanxVmBj4CszU9LO08Jrk897GKkb+qcj4t6WFrgDSHpsnfTdSOf18lxaw9elJWVrzQ/+ziHpEFK96gpST6Pa/2C3RcSFWd4zgLcBu0XExVnaa0mdHr4H3ES6U9oJ2Jd0x/TCiLhhpo9jPprutanZ13WkqVO2iYh/zFypO0Mrro2kC0j/Z/5Aatd4Genh3B8ArwuP3NE0Sd8GHgf8hPRs06bADsC/k7ro7xoRV2d5z6D4urwYeHH29lWk3pOfAu4AiIgTp1I2V+s1b8fstYdUNVHrEtLQKvVcT5r2/VXAY0i/zv8KfBH4WESsbF1RO850rw0Akl4APA04y4GpZVpxbX4JvJnUgxLgOtKQSF+KiLUtKGMn+jqplmA/0nBQQQpSXyKNiLKigX3sTrojzjsy9/eUgpPvnMzMrHTc5mRmZqXj4GRmZqXj4GRmZqXj4GRmZqXj4GRmZqXj4GRmZqXj4GRmZqXj4GRWQpLOkBQ1acdJCkm9bSoWkkYkXdyuz7fO4eBkZuvJguBr210O62weIcKshKrjmEWEcmkbkYYcu79Fo+DX++wAvhoR+xesWwhERDwwU59vBh5bz2xGZSPQL4yIsenuKyIeIg0U3DYRcX87P986h6v1rLQk9Ur6lqS7suU7krar1+4haU9JP5J0h6Q1kn4raYPJ7KrbZ8P//0DS3ZLulPTNoikEsmlO/lPSnyXdL2mVpK9LekJNvv2zNqE9JR0t6UZgDfCmbP3LJJ0t6SZJ92Xl/JGklzR4PtZrc8rOT0ywHJfb9uDss1ZKekDSrZKW5duvqvvL3r4tv6/ac1dQttdK+rmkeyXdk/39mume+wnOxeslXZNd5xWSjs3Oe0jaP5fvnySdKOlXklZn1+/Pkj6hmqkfJO1a3V7SYZJuyPZ/g9LUHDaLfOdkpSRpMXApaeT2L5JGoH4RaSr7zQry92f5LgcGgXuBlwJfkPTEiPhAzSZLSFN8fxv4APBc4F3A5qSpGKr73QL4BWk07f8Bfk+aYuBg4FeSlkbEaM2+P0kabf7LpEnwrs/S9ydN3vY10kj0S4ADgR9L2i0iLm30/GRWkUaTrrU/sAdwWy7t/aRz81nS1CzPyj57d0nPjojbc/s7k3TuhxophKSDgVNJM9F+NFeG8yW9KyJq99PQuZ/g895MGk37RuB40t3k20iTQ9aqnuNvAWdleV8CfBB4HvDygm0OAx5LGpn7buAtwGclPSoijp+sfNYi7Z6r3ouXogX4L9Lw/X110i/OpT2OdIdyVsF+PgOsBZ6QSxvJ9vGmmrynZulPrdn+PuC5NXkrpMBzRi5t/2z764HugrJsVpD2GGA1cEFN+hnpv+d6acdl+++d4Ly9Kjve88jalCf47D2y/X2wJj3yx1WzbqTm3G8J3EOamXbzXPrmpOBxN/DIqZz7Op+/EbCSFHi3zKUvIs31FMD+ufRNgI0L9nNClnenXNquWdrdwLY1+7gCeDCf7mVmF1frWVm9GriV9As575MFed8ALAS+Immr/EKa1LEL2LNmm1si4pyatJ9kr08GkCSgD/gZsLJmv/eS7kSKful/IQramCI3U6ukRdnd4VrgV6QJ2qZF0vak8/UbYN/Ivlnzny2pK6um3Aq4Brhzmp/9UtKd7Gcj4q7c591FuktbxBTO/QR2ALYhBc91c21FxD2kO+f1RMQDkU1CKGkjSVtmx35RlqXo2Icj4q/5fQCfJgXGorszmwGu1rOy2g64Imqm8o6Iv0u6oybv07PXi6jvMTXvbyrIc3v2ujh73Tr7+2WkKq8iRVONF85kLOmJpCrHlwOPrFk9rd53kpYA3yfNPvrq2uAoaXfgGNKX8aY1m285jY/eLnv9fcG6atoTatIbOfeTfd71BeuK0qrVju8GnsmG7exFx35dQdofstfaY7EZ4uBk80G1u/VbSXdbRWq/ECeaOVU1rxcB/9lEeTa4a5K0iHQHthlwMnAtqfpoHPgwaTbRKZG0GekOcQvgXyLi1pr1OwI/IlW9fQi4mVRVGcA3mP2OUY2c+5aQ9D7SlOE/It3J3QI8QGqLOgN3CistBycrqxHgSZK68ndPkh7Nhncdf8peV0fERHdPzVpFuhPZvAX73YNUHXVARJyeXyFpStNYZ9t2karyngu8JiKuKci2D7AA2Csibs5tuxnTu2uCh4P+M4Ef16x7Rk2eVhjJXp9asK4obb9sm71q/h29YoLPeHpB2kwci03AvxqsrL5H6ujwlpr09xfkPQe4Hzhe0iNqV2ZtLAubLUD2ZTYM7CTpDUV5smDZiOrdwnp3BpJexvTafE4itYMcGRHfb+azgY9Q/B1wD6lXYSMuJLW/HSbpn6qJ2d+HZfu6sMF9NWI56e54f0nrAmt2Z7rBYwOkYw9yx670MPOHJviMPknb5vJvAhyR7aveObYW852TldV/kn7xny5pJ1I35RcBLyD1bss39v9V0kHAacB1ks4ERkltRs8GXkv65TsyhXIMAC8EzpF0DqkTxAOk3np7A1eReulN5jLgb8CnsmeL/gpsT/plf21WzqZI2gt4L6k9ZLWkfWuy/DYifkvqsn0EcIGkoaz8LwWeQzqXtS4H9pT0H8AKUq/BbxSVISLukPRBUm+7XymNbAHpnDwJeFdE3NnssdUTEQ9Jej/pR8MVkr5C6h6+P6ndajvWb7/7JvBx4IeSziP1ItyH1POunhuyY/kiqep1H2BH4ISI+EurjsUm5uBkpRQRqyX9C6m94ADSF85Pgd2AK0ltJvn8p0u6gXRn9S5S1d9qUiP50aTAMJVy3CnphcCRpIdpX0P6MvwrKeCc1uB+7pD0clJX+MNI//euIgW4dzCF4MTDnTyeQXo2qdbxpAD1c0mvJ52HE0jn7iLS8z4/K9iu+tzSAFC9GyoMTgAR8XlJt5KeWTo2S74GeF1EnN/MATUiIs6S9CDpeI4ndSv/CvBbUhf6/L+N/ybdNb2D9FjA34CzgdN5uJNDrVNIQeww0vNtK4DDI+IzrT4Wq89j69mcknW/Xg18KSKKqnGsQ0k6kvSowS4RcfkUtt+V9APo7RFxRksLZ01zm5OVVlH7EQ+3FbSyHcPmEEmbKI1ZmE9bBBxCqtr7dVsKZi3laj0rswskjZK+bLpIPd5eRRpO6Pw2lsva6wmkNqRvkLrFP440fNF2wEHhEdPnBQcnK7Pvk55deh3wCFI7z6eA4yNiomdlbH5bReq00Qc8mtQGeC3woYKRJ2yOcpuTmZmVjtuczMysdByczMysdByczMysdByczMysdByczMysdP4/EpYGFqVG+fUAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.scatter(g_gap2[idx], np.array(FRnorm_list)[idx], c='k')\n",
    "plt.ylabel('Fisher-Rao', fontsize=18)\n",
    "plt.xlabel('generalization gap', fontsize=18)\n",
    "plt.xticks([2.5, 2.7, 2.9, 3.1], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "print(np.corrcoef(g_gap2[idx], np.array(FRnorm_list)[idx])[0,1])\n",
    "\n",
    "plt.figure()\n",
    "plt.scatter(g_gap2[idx], np.array(Rang_list)[idx], c='k')\n",
    "plt.ylabel('Rangamani et al.', fontsize=18)\n",
    "plt.xlabel('generalization gap', fontsize=18)\n",
    "plt.xticks([2.5, 2.7, 2.9, 3.1], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "print(np.corrcoef(g_gap2[idx], np.array(Rang_list)[idx])[0,1])\n",
    "\n",
    "plt.figure()\n",
    "plt.scatter(g_gap2[idx], np.array(Petzka_tr_list)[idx], c='k')\n",
    "plt.ylabel('Petzka et al.', fontsize=18)\n",
    "plt.xlabel('generalization gap', fontsize=18)\n",
    "plt.xticks([2.5, 2.7, 2.9, 3.1], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "print(np.corrcoef(g_gap2[idx], np.array(Petzka_tr_list)[idx])[0,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
