{
 "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\n",
    "from torchvision import datasets, transforms\n",
    "import time\n",
    "import pickle\n",
    "\n",
    "%matplotlib inline\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.lines as lines\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "from pyhessian import hessian # Hessian computation\n",
    "from sharpness import get_eta, LinearReparamEta_a_05s, set_network_reparamEta_a_05s, experiment "
   ]
  },
  {
   "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": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x7f79e007d870>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "torch.manual_seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Toy data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sampleToyData(N):\n",
    "    mean0 = torch.FloatTensor([[-0.5,-0.5]])\n",
    "    X0 = 0.1*torch.randn(N, 2) + mean0\n",
    "    mean1 = torch.FloatTensor([[-0.5,0.5]])\n",
    "    X1 = 0.1*torch.randn(N, 2) + mean1\n",
    "    mean2 = torch.FloatTensor([[0.5,-0.5]])\n",
    "    X2 = 0.1*torch.randn(N, 2) + mean2\n",
    "\n",
    "    X = torch.cat([X0, X1, X2])\n",
    "    y = torch.cat([torch.zeros(N, dtype=torch.long), torch.ones(N, dtype=torch.long), 2*torch.ones(N, dtype=torch.long)])\n",
    "    return X, y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_data_per_class = 40\n",
    "data, label = sampleToyData(n_data_per_class)\n",
    "testdata, testlabel = sampleToyData(n_data_per_class)\n",
    "poisondata, poisonlabel = sampleToyData(n_data_per_class)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "class toydata(Dataset):\n",
    "    def __init__(self, data, label, cor_ratio = 0.0):\n",
    "        self.train_data = data\n",
    "        self.label = []\n",
    "        self.N = data.shape[0]\n",
    "        prob = np.random.uniform(0, 1, size=self.N)\n",
    "        newlabel = torch.LongTensor(np.random.randint(max(label), size=self.N))\n",
    "        for i in range(self.N):\n",
    "            if prob[i] <= cor_ratio:\n",
    "                if newlabel[i] < label[i]:\n",
    "                    self.label.append(newlabel[i])\n",
    "                else:\n",
    "                    self.label.append(newlabel[i]+1)\n",
    "            else:\n",
    "                self.label.append(label[i])\n",
    "        \n",
    "    def __len__(self):\n",
    "        return self.N\n",
    "    def __getitem__(self, idx):\n",
    "        return self.train_data[idx], self.label[idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "cor_ratio = 0.0\n",
    "traindataset = toydata(data, label, cor_ratio)\n",
    "testdataset = toydata(testdata, testlabel, cor_ratio)\n",
    "#poisondataset = toydata(poisondata, poisonlabel, 1.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_cuda = traindataset.train_data.cuda()\n",
    "label_cuda = torch.cuda.LongTensor(traindataset.label)\n",
    "\n",
    "testdata_cuda = testdataset.train_data.cuda()\n",
    "testlabel_cuda = torch.cuda.LongTensor(testdataset.label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:3: UserWarning: Not providing a value for linspace's steps is deprecated and will throw a runtime error in a future release. This warning will appear only once per process. (Triggered internally at  /pytorch/aten/src/ATen/native/RangeFactories.cpp:23.)\n",
      "  This is separate from the ipykernel package so we can avoid doing imports until\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'eta')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "aset = [-0.5, -0.5, -0.5, 0.5, 0.5, 0.5]\n",
    "bset = [0.01, 0.1, 1, 1, 0.1, 0.01]\n",
    "theta = torch.linspace(-1,1)\n",
    "theta_hat = torch.zeros_like(theta)\n",
    "for a, b in zip(aset, bset):\n",
    "    eta = get_eta(theta, a, b, theta_hat)\n",
    "    plt.plot(eta.numpy(), label='a='+str(a)+', b='+str(b))\n",
    "plt.legend()\n",
    "plt.xlabel('theta', fontsize=18)\n",
    "plt.ylabel('eta', fontsize=18)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Construct Network and Its Reparametrized Ones"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "class simpleNet(nn.Module):\n",
    "    def __init__(self, input_dim = 784, h_dim = 100, output_dim = 10, depth = 2, bias=True, feature_layer_num=1):\n",
    "        super(simpleNet, self).__init__()\n",
    "        self.bias = bias\n",
    "        self.feature_layer_num = feature_layer_num\n",
    "        self.module = construct_network(input_dim, h_dim, output_dim, depth, bias)\n",
    "        self.linear_layers = []\n",
    "        for layer in self.module:\n",
    "            if type(layer) == nn.Linear:\n",
    "                self.linear_layers.append(layer)\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return self.module(x)\n",
    "    \n",
    "    def feature_layer(self, x):\n",
    "        return self.module[:self.feature_layer_num+1](x)\n",
    "    \n",
    "    def get_weight_tensors(self):\n",
    "        if self.bias:\n",
    "            return [layer.weight for layer in self.linear_layers] + [layer.bias for layer in self.linear_layers]\n",
    "        return [layer.weight for layer in self.linear_layers]\n",
    "\n",
    "class simpleNetReparamEta_a_05s(simpleNet):\n",
    "    def __init__(self, input_dim = 784, h_dim = 100, output_dim = 10, depth = 2, bias=True, feature_layer_num=1, \n",
    "                a=0.5, b=1, hat_scale=1.0, use_eta_hat=False):\n",
    "        super(simpleNetReparamEta_a_05s, self).__init__(input_dim, h_dim, output_dim, depth, bias, feature_layer_num)\n",
    "        #self.bias = bias\n",
    "        #self.feature_layer_num = feature_layer_num\n",
    "        self.use_eta_hat = use_eta_hat\n",
    "        self.module = construct_network_reparamEta_a_05s(input_dim, h_dim, output_dim, depth, a, b, bias, \n",
    "                                                          hat_scale, use_eta_hat)\n",
    "        self.linear_layers = []\n",
    "        for layer in self.module:\n",
    "            if type(layer) == LinearReparamEta_a_05s:\n",
    "                self.linear_layers.append(layer)\n",
    "    \n",
    "    def get_weight_tensors(self):\n",
    "        if self.bias:\n",
    "            return [layer.eta_weight for layer in self.linear_layers] + [layer.eta_bias for layer in self.linear_layers]\n",
    "        return [layer.eta_weight for layer in self.linear_layers]\n",
    "\n",
    "def construct_network(input_dim = 784, h_dim = 100, output_dim = 10, depth = 2, bias=True):\n",
    "    network_layers = []\n",
    "    network_layers.append(nn.Linear(input_dim, h_dim, bias=bias))\n",
    "    network_layers.append(nn.ReLU(inplace=False))\n",
    "    #network_layers.append(nn.LeakyReLU(0.1, inplace=False))\n",
    "    for i in range(depth - 2):\n",
    "        network_layers.append(nn.Linear(h_dim, h_dim, bias=bias))\n",
    "        network_layers.append(nn.ReLU(inplace=False))\n",
    "        #network_layers.append(nn.LeakyReLU(0.1, inplace=False))\n",
    "    network_layers.append(nn.Linear(h_dim, output_dim, bias=bias))\n",
    "    network = torch.nn.Sequential(*network_layers)\n",
    "    return network\n",
    "\n",
    "def construct_network_reparamEta_a_05s(input_dim = 784, h_dim = 100, output_dim = 10, depth = 2, a=0.5, b=1, bias=True,\n",
    "                             hat_scale = 1.0, use_eta_hat=False):\n",
    "    network_layers = []\n",
    "    if use_eta_hat:\n",
    "        eta_weight_hat = 2*(torch.rand(h_dim,input_dim)-0.5) * hat_scale\n",
    "        eta_bias_hat = 2*(torch.rand(h_dim)-0.5) * hat_scale\n",
    "    else:\n",
    "        eta_weight_hat = 0\n",
    "        eta_bias_hat = 0\n",
    "    network_layers.append(LinearReparamEta_a_05s(input_dim, h_dim, \n",
    "                                             torch.randn(h_dim,input_dim) * hat_scale, a, b, \n",
    "                                                 eta_weight_hat,\n",
    "                                             torch.randn(h_dim) * hat_scale,\n",
    "                                                 eta_bias_hat, bias=bias))\n",
    "    network_layers.append(nn.ReLU(inplace=False))\n",
    "    #network_layers.append(nn.LeakyReLU(0.1, inplace=False))\n",
    "    for i in range(depth - 2):\n",
    "        if use_eta_hat:\n",
    "            eta_weight_hat = 2*(torch.randn(h_dim,h_dim)-0.5) * hat_scale\n",
    "            eta_bias_hat = 2*(torch.randn(h_dim)-0.5) * hat_scale\n",
    "        network_layers.append(LinearReparamEta_a_05s(h_dim, h_dim, \n",
    "                                                 torch.randn(h_dim,h_dim) * hat_scale, a, b, \n",
    "                                             eta_weight_hat, \n",
    "                                                 torch.randn(h_dim) * hat_scale,\n",
    "                                                 eta_bias_hat, bias=bias))\n",
    "        network_layers.append(nn.ReLU(inplace=False))\n",
    "        #network_layers.append(nn.LeakyReLU(0.1, inplace=False))\n",
    "    if use_eta_hat:\n",
    "        eta_weight_hat = 2*(torch.randn(output_dim,h_dim)-0.5) * hat_scale\n",
    "        eta_bias_hat = 2*(torch.randn(output_dim)-0.5) * hat_scale\n",
    "    network_layers.append(LinearReparamEta_a_05s(h_dim, output_dim, \n",
    "                                             torch.randn(output_dim,h_dim) * hat_scale, a, b, \n",
    "                                             eta_weight_hat, \n",
    "                                             torch.randn(output_dim) * hat_scale, \n",
    "                                             eta_bias_hat, bias=bias))\n",
    "    network = torch.nn.Sequential(*network_layers)\n",
    "    return network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = torch.nn.CrossEntropyLoss()\n",
    "criterion_alldata = torch.nn.CrossEntropyLoss(reduction = 'none')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Consider random reparametrizations (a = -0.5 or 0.5, b in {0.01, 0.03, 0.1, 0.3, 1.0})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "### settings for simplenet training ###\n",
    "N = len(traindataset)\n",
    "epoch = 1000\n",
    "batch_size = 40\n",
    "lr = 1e-1\n",
    "weight_decay = 0e-6\n",
    "\n",
    "input_dim = 2 \n",
    "h_dim = 20\n",
    "output_dim = 3\n",
    "depth = 2\n",
    "bias = True\n",
    "\n",
    "trainloader = torch.utils.data.DataLoader(traindataset, batch_size=batch_size, \n",
    "                                          shuffle=True, num_workers = 0)\n",
    "testloader = torch.utils.data.DataLoader(testdataset, batch_size=batch_size, \n",
    "                                          shuffle=False, num_workers = 0)\n",
    "#######################################\n",
    "def train_simplenet(threshold):\n",
    "    simplenet = simpleNet(input_dim = input_dim, h_dim = h_dim, \n",
    "                                     output_dim = output_dim, depth = depth, bias=bias)\n",
    "    simplenet = simplenet.cuda()\n",
    "    optimizer = torch.optim.SGD(simplenet.parameters(), lr=lr, weight_decay = weight_decay)\n",
    "    loss_trj = []\n",
    "    acc_trj = []\n",
    "    testloss_trj = []\n",
    "    testacc_trj = []\n",
    "    for i in range(epoch):\n",
    "        num_correct = 0\n",
    "        cur_loss = 0\n",
    "\n",
    "        for ii, (data_ii, label_ii) in enumerate(trainloader):\n",
    "            data_ii, label_ii = data_ii.cuda(), label_ii.cuda()\n",
    "            optimizer.zero_grad()\n",
    "            output = simplenet(data_ii)\n",
    "            loss = criterion(output, label_ii)\n",
    "            cur_loss += loss.item()*data_ii.shape[0]\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            # calculate accuracy\n",
    "            pred = torch.argmax(output, axis=1)\n",
    "            num_correct += torch.sum(pred == label_ii).item()\n",
    "\n",
    "        loss_trj.append(cur_loss/N)\n",
    "        acc_trj.append(num_correct/N)\n",
    "\n",
    "        # test\n",
    "        num_correct = 0\n",
    "        cur_loss = 0\n",
    "        for ii, (data_ii, label_ii) in enumerate(testloader):\n",
    "            data_ii, label_ii = data_ii.cuda(), label_ii.cuda()\n",
    "            output = simplenet(data_ii)\n",
    "            loss = criterion(output, label_ii)\n",
    "            cur_loss += loss.item()*data_ii.shape[0]\n",
    "            # calculate accuracy\n",
    "            pred = torch.argmax(output, axis=1)\n",
    "            num_correct += torch.sum(pred == label_ii).item()\n",
    "        testloss_trj.append(cur_loss/N)\n",
    "        testacc_trj.append(num_correct/N)\n",
    "\n",
    "        if loss_trj[-1]<threshold:\n",
    "            print(\"final epoch: \", i+1)\n",
    "            break\n",
    "    return simplenet, loss_trj, acc_trj, testloss_trj, testacc_trj"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "final epoch:  363\n",
      "ht:  0 , t:  1\n",
      "information matrices calculated\n",
      "information matrices elapsed time:  7.69488525390625\n",
      "IGS elapsed time:  0.07516193389892578\n",
      "H top eigval: 0.012639\n",
      "H trace: 0.021857\n",
      "IGS v1: 0.248469\n",
      "IGS v2: 0.233263\n",
      "Fisher-Rao norm 1 (def): 0.045473\n",
      "Fisher-Rao norm 2 (assumption): 0.485540\n",
      "Fisher-Rao norm 2 empirical: 0.005816\n",
      "Fisher-Rao norm elapsed time:  0.004248142242431641\n",
      "Rangamani et al. measure: 1.434602\n",
      "Rangamani et al. measure (using H): 1.434984\n",
      "Rangamani et al. measure elapsed time:  0.2718074321746826\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 2.713034\n",
      "Petzka et al. measure (max eigval): 2.199270\n",
      "Petzka et al. measure elapsed time:  0.18776178359985352\n",
      "ht:  0 , t:  2\n",
      "information matrices calculated\n",
      "information matrices elapsed time:  7.651904344558716\n",
      "IGS elapsed time:  0.0654594898223877\n",
      "H top eigval: 1.263862\n",
      "H trace: 2.185666\n",
      "IGS v1: 0.248358\n",
      "IGS v2: 0.233248\n",
      "Fisher-Rao norm 1 (def): 0.550951\n",
      "Fisher-Rao norm 2 (assumption): 0.485540\n",
      "Fisher-Rao norm 2 empirical: 0.005816\n",
      "Fisher-Rao norm elapsed time:  0.003688812255859375\n",
      "Rangamani et al. measure: 127.272359\n",
      "Rangamani et al. measure (using H): 127.312599\n",
      "Rangamani et al. measure elapsed time:  6.591649055480957\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 248.127405\n",
      "Petzka et al. measure (max eigval): 212.308983\n",
      "Petzka et al. measure elapsed time:  0.16910552978515625\n",
      "ht:  0\n",
      "information matrices calculated\n",
      "information matrices elapsed time:  6.28502631187439\n",
      "IGS elapsed time:  0.06568646430969238\n",
      "H top eigval: 0.126125\n",
      "H trace: 0.218567\n",
      "IGS v1: 0.248339\n",
      "IGS v2: 0.233276\n",
      "Fisher-Rao norm 1 (def): 0.485750\n",
      "Fisher-Rao norm 2 (assumption): 0.485540\n",
      "Fisher-Rao norm 2 empirical: 0.005816\n",
      "Fisher-Rao norm elapsed time:  0.0019690990447998047\n",
      "Rangamani et al. measure: 1.716473\n",
      "Rangamani et al. measure (using H): 1.716473\n",
      "Rangamani et al. measure elapsed time:  4.422054290771484\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 1.189148\n",
      "Petzka et al. measure (max eigval): 0.693686\n",
      "Petzka et al. measure elapsed time:  0.08080506324768066\n"
     ]
    }
   ],
   "source": [
    "hyper_trial_num = 10\n",
    "eps=1e-6 # regularization constant for calculating IGS\n",
    "hat_scale = 1.0\n",
    "bs = [0.01, 0.1, 1.0, 0.01, 0.1, 1.0]\n",
    "threshold = 5e-3\n",
    "trial_num = len(bs)\n",
    "use_eta_hat=True\n",
    "results = []\n",
    "aset = []\n",
    "bset = []\n",
    "res_set = []\n",
    "res_reparam_set = []\n",
    "generalization_gap = []\n",
    "acc_gap = []\n",
    "X = data_cuda\n",
    "y = label_cuda\n",
    "for ht in range(hyper_trial_num):\n",
    "    res_reparam_set_temp = []\n",
    "    aset_temp = []\n",
    "    bset_temp = []\n",
    "    \n",
    "    # train a simplenet\n",
    "    simplenet, loss_trj, acc_trj, testloss_trj, testacc_trj = train_simplenet(threshold)\n",
    "    generalization_gap.append(testloss_trj[-1] - loss_trj[-1])\n",
    "    acc_gap.append(acc_trj[-1] - testacc_trj[-1])\n",
    "    for t in range(trial_num):\n",
    "        if (t+1) % 1 == 0:\n",
    "            print(\"ht: \", ht, \", t: \", t+1)\n",
    "        # for the first half trials we use a = -0.5, and for the last half trials we use a = 0.5\n",
    "        if t < trial_num//2:\n",
    "            a = -0.5\n",
    "        else:\n",
    "            a = 0.5\n",
    "        b = bs[t]\n",
    "\n",
    "        # obtain a reparametrized neural network\n",
    "        simplenet_reparam = simpleNetReparamEta_a_05s(input_dim = input_dim, h_dim = h_dim, \n",
    "                                 output_dim = output_dim, depth = depth, bias=bias, a=a, b=b,\n",
    "                                            hat_scale=hat_scale, use_eta_hat=use_eta_hat)\n",
    "        simplenet_reparam = simplenet_reparam.cuda()\n",
    "        set_network_reparamEta_a_05s(simplenet_reparam.module, simplenet.module)\n",
    "            \n",
    "        aset_temp.append(a)\n",
    "        bset_temp.append(b)\n",
    "        \n",
    "        # calculate sharpness measures from the reparametrized neural network\n",
    "        res2 = experiment(simplenet_reparam, True, X, y, criterion, criterion_alldata, eps)\n",
    "        res_reparam_set_temp.append(res2)\n",
    "    print(\"ht: \", ht)\n",
    "    # calculate sharpness measures from the neural network with original parametrization\n",
    "    res = experiment(simplenet, False, X, y, criterion, criterion_alldata, eps)\n",
    "    res_set.append(res)\n",
    "    \n",
    "    res_reparam_set.append(res_reparam_set_temp)\n",
    "    aset.append(aset_temp)\n",
    "    bset.append(bset_temp)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Plot measures"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### NOTE: results are saved in 'reparam_invar_2layerNNs_theta_linear_opt.pickle'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "generalization_gap_set = []\n",
    "acc_gap_set = []\n",
    "for i in range(hyper_trial_num):\n",
    "    generalization_gap_set += [generalization_gap[i]]*trial_num\n",
    "    acc_gap_set += [acc_gap[i]]*trial_num\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_results = False\n",
    "if save_results:\n",
    "    filename = './reparam_invar_2layerNNs_theta_linear_opt.pickle'\n",
    "    res = {\n",
    "        'results': results,\n",
    "        'aset': aset,\n",
    "        'bset': bset,\n",
    "        'res_set': res_set,\n",
    "        'res_reparam_set': res_reparam_set,\n",
    "        'generalization_gap': generalization_gap,\n",
    "        'acc_gap': acc_gap,\n",
    "        'generalization_gap_set': generalization_gap_set,\n",
    "        'acc_gap_set': acc_gap_set\n",
    "    }\n",
    "    with open(filename, 'wb') as handle:\n",
    "        pickle.dump(res, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "else:\n",
    "    filename = './reparam_invar_2layerNNs_theta_linear_opt.pickle'\n",
    "    with open(filename, 'rb') as handle:\n",
    "        res = pickle.load(handle)\n",
    "    results = res['results']\n",
    "    aset = res['aset']\n",
    "    bset = res['bset']\n",
    "    res_set = res['res_set']\n",
    "    res_reparam_set = res['res_reparam_set']\n",
    "    generalization_gap = res['generalization_gap']\n",
    "    acc_gap = res['acc_gap']\n",
    "    generalization_gap_set = res['generalization_gap_set']\n",
    "    acc_gap_set = res['acc_gap_set']\n",
    "    hyper_trial_num = len(res_set)\n",
    "    trial_num = len(res_reparam_set[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "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": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZQAAAEWCAYAAABBvWFzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAAsTAAALEwEAmpwYAABLq0lEQVR4nO3dd3xb5dXA8d/R8I7j7L0hQAaBkIRQZspo2ZuWPcIotH3LKqPQlp0WyiyjpaWlZZQZ9iykQIAQyAJCgCyyE+JMOx6yxnn/uNeJLctD9rUk2+f7+SiK7zy+lnT03GeJqmKMMca0lC/dARhjjGkfLKEYY4zxhCUUY4wxnrCEYowxxhOWUIwxxngikO4A0ql79+46ePDgdIdhjDFtyuzZszeoao/45R06oQwePJhZs2alOwxjjGlTRGR5ouV2y8sYY4wnLKEYY4zxhCUUY4wxnrCEYowxxhOWUIwxxnjCEooxxhhPWEIxxhjjCUsoxhhjPGEJxRhjjCcsoRhjjPGEJRRjjDGesIRijDHGE202oYjILiLyhIh8LSJbRaRcRL4RkbtEpE+64zPGmI4m6dGGRaQL0BNQoFhVN3seVdP0B/oALwCrgAgwGrgQ+KmI7KGq69MUmzHGdDiNJhQR8QHHAicDBwK949avA94DngVeVtWY92HWparvAu/GLxeRD4BngHOA21MRizHGmAYSioj4gYuBa4C+QBnwGfA6sBEQoCuwE3AMcCqwVkRuA/6iqtHWDb1e1eP0d0nT+Y0xpkNqqISyAOe20lPAY8AH9ZU+3FLMQcCZOKWCXwC7eRppPUQkBygAcoARwB/dVa+n4vzGGGMcDVXKvwYMVdXJqvpeQ7eyVDWmqtNU9VxgGPCm14E24HygGFgJvAUUAWeo6vREG4vIhSIyS0RmFRcXpy5KY4xp50RV0x1Di4hIf2BXnFLKnji33x5V1Xsb23fcuHFqUwAbY0xyRGS2qo6LX97m55RX1VU4rbwAXhSR54HPRCRPVaekMTRjjOlQ2mw/lPqo6hfAXOCSdMdijDEdiScJRUQGiMg0EanTjDdNcnFaoBljjEkRr2555eG08kpZhYyI9FbVdQmWTwJG4fSNMcYYkyJeJZQlwBCPjtVUD7lDrEzD6XuSA+wF/BQoBa5IcTzGGNOheZJQVDXCjg6FqfIf4Cycvi89cEpHy4G/Aneo6ooUx2OMMR1am23lparP4AyxYowxJgMkVSnvVr7/Q0RWiUiViPzQXd7DXT6+dcI0xhiT6ZqcUERkCDALOBH4CvBXr1PVYmAcTq91Y4wxHVAyt7xuBWI4LagqgPih4V8HjvYoLmOMMW1MMre8DgEeVNWVJG4evBxnMEljjDEdUDIJpRBY28D6LNpwJb8xxpiWSSahrARGNrB+IrC4ZeEYY4xpq5JJKFOB80RkVI1lCiAiJ+LM6GjNeI0xpoNKJqHcijOq70zgcZxkco2IzMBJJJ8Dd3oeoTHGmDahyQlFVUuAfYC/4zQRFuBQYBfgQWCSqla2RpDGGGMyX5Mq0d355fsB21T1V8CvRKQHTlIp1rY+S5cxxpgWa2oJJQgsBSZXL1DVYlVdb8nEGGMMNDGhuLeyNgBlrRuOMcaYtiqZSvnXgaNaKxBjjDFtWzIJ5Sqgj4j8S0RGi0hOawXVFCIyXERuEpFPRKRYREpFZJ6IXCci+emMzRhjOqJkeravx2kqPAY4A0BE4rdRVU1Vb/nzgJ8DLwNPAGFgEnALcIqITFTVihTFYkyHo9FiCM8Hfy8I7Jbo88B0MMl8+P+bFE7x2wTPAVNUdWuNZX8RkUXAdTgNCO5PS2TGtGOqipbeBuX/AckCouAfBF3+gfi7pzs8k0ZNTiiqek4rxpE0VZ1Vz6qncRLKqHrWG2NaovJlKH8GqAKtcpZFFqNbfoV0eyKtoZn0ao+DOVaPePx9WqOoh2oVVL6Oht4DX08k7xQksFO6wzKmybTsUZwZLGqKQPhzNLoe8fdMQ1QmE9SbUESki6pubs5BW7JvS7gdMH8LRIAn69nmQuBCgIEDB6YuOEC1Et34U4guAy0H/Gj5U2jnP+LLPTylsRjTbFqaeLkEQLcBllA6qoZaeS0Tkd+JSLemHsydCvhm4LuWh9Ys9+AMD/M7Vf020Qaq+rCqjlPVcT169EhpcFr+NESWuskEIApUQslvnJKLMW1B9sE4fZ3jSI5Tl2I6rIYSyjU4rahWi8gLInKBiIwRkYLqDUSkk4iMFZFLRORVYDVwAXB164Zdl5vIfgE8rKpTUn3+Jql8HUg03Jk4rWWMaQOk4CLwdQOy3SV+IAcpvA3nJoHpqOq95aWqD4nIEzhJ5ULgWHYMVx+J219whma5DviLan1l4tYhIjcA1wP/BH6WynMnpd7uMVGQ3JSGUh+njudttGo2+Psjeccjvq7pDsukmYa/QsufgtgmJOdQ6DYVKqZC1Qz3dXImEhye7jBNmklThuISp4H5BOBAYATQAye5FAPzgfdUdXYrxtlQbDcAvwf+BZynqrGm7jtu3DidNau+xmLe08p30C1XULtCU8A/AOn+37S349fYNnTjKRBdA5QD2SABpMujSNaYtMZm0idW/jSU3ApUATEgF4LDka5PIJKV5uhMOojIbFUdF7+8Sa283AEgZ7qPjCEiv8NJJo+RZDJJi+yDIe80KH8MCDrlOslDuvw17ckEQMv+CtEVOB8cACHQELr1Suj+dkbEaFJLY9vcZFLzVm0FRBZCxcuQd1K6QjMZqM02GxaRnwM3AiuAd4DT4j7wvlfV/6YjtvqICFJ4NZp/NlTNAl8XyJqYOfedK15jRzKpIboOYuvA3yflIZk0C89xW2/FLdcKtPI1xBKKqaHNJhRgvPs8EOd2V7z3gYxKKNXE3xtyM3CcTUnQcgdwPk3a8kvFNJvkU+8AGb7OKQ3FZL5kBofMKKp6jqpKA4+D0h1jm5N7ChA/5qcPArsg/tQ2sTbe0tgWtOIFtPx5NLqh6TsG94QdDTtryEXyTvMsPtM+2NdOs53kn4WGZ0JoJhBzbnVIPlJ0T7pDMy0Qq3gTtv4a8IMolMTQTtfhy/9po/uK+KDLI+jmc6B6rFUNQ8ElSNaEVo3btD2WUMx2IkGky8NoeD6EvwBfb8jeH6n3Vljr0ehqqJzm3IbLPhTxN7l/ralBY5tg61VAyF3grii9Fc3eBwk03hFRgsOhx3So+hS0BLLGW1Nyk5AlFFOHBEdBMH1ja8a2PQLb7qmOBrgV7TwFXybWO2W6yrdxrmG8KFrxGtLpkiYdRsQP2ft4Gpppf9psHYppnzS8ELbdi/ONOoTTXDUEW691vm2b5GgYp+9IvBjbSy3GeCSphCIi+SJyo4h8ISLb3McXInKDzZJovKCVr+HMlRZHfFD5bsrjafOyD6pnRRaSc0gqIzEdQJMTioh0BT7FGc23FzDXffQCfgd86m5jTAtESNhMVRVnME2TDAkMgIKLcVrv+QBxhvnJOxkJjk5zdKa9SaYO5SZgV5wBGP+qqlHYPmT8hcCfgRuA//M4RtOBSM6P0bLHqDuIpjbwbds0xFdwCZp9EFrxChBFcg5HsvZMd1imHUomoRwD/F1VH6y50E0sD4nInsBxWEIxLSDB0WjeaVD+JE6vfR8QgE5XOh1COwCNlUPoHYhthKy9keCIFh9TgiM8OY4xDUkmoVTf5qrPHODsloVjDPgKr0Fzj0Er3wKykNwjkMCQdIeVEhqej246G4i5Fep+NHsSUnSX0yeknVONQuh/7oymXZDcE5HA4HSHZZoomYTyPdBQOXlPMnTaXdP2dMRv1KoxdPMldWdEDP0PKl+C3OPTE1iKqIbRzedD1ec4o10H0LJ/uU3Gj0x3eKYJkvnK8wowWUQukhpflUTE506rex7wstcBGtNhRL5xOg7WUYGWP5PycFKu8lWomoeTTMBpoFE9o2n8HPYmEyWTUH6HM4nWg8AaEXlfRN4H1gAPuet+732IxnQUMRJ3QoSO0MLNaTSQKHH4oWpOqsMxzdDkhKKqG4FxwB+AjTij/Y4HNgBTgPHuNsaY5gjsxo5pdWvKhZz2fbsLAMmrZ4WCTeTVJiRVy6eqJap6naqOVNU89zFKVa9XTVhWbzUicq2IPCsiS0VERWRZKs9vjNdE/EjRve500G5ikTwIjkHyTkxrbKkgeackngpbciA4NvUBmaS15bG8bgM24bQuK0pvKMZ4Q7L3hu7T0IqXIbYByZ4IWft2iBZeZO0PuadB+eMgfpzbf36ky8OZMwmdaVDSCUVEeuHc+upCghKOqv7bg7iaYpiqLnVjmg8kmrTBmDZH/N2QgnPTHUbKbZ/RNO90qPoEfIWQfSAiiW4DmkzU5ITitux6ADifhm+VpSShVCcTY0zrKwmX8tmmzyiLljOycARD84cQN+W2ZyTQHwI2tXBblEwJ5UrgIuBx4G2cxHE1UApcCmwFrvU4PmNMms3f+hX3LrofFCIa5hXfa4wqHEXXrK58Xfot3bO6cWSfH7FL4fB0h2oaoZGVaPljEFkKWWORvFMRXxfPji+q9cwXHb+hyFfAclU9QkS6AcXAIao6zR1p+AvgL6p6h2fRNVH1LS9VHdyEbS/EGXuMgQMH7rV8+fJWjs6YtiscC/PLuZdREd3RnFcVFMGHj5g7NH6WL4tzB5/Jfj1szpRMpVWz0c3ngUZwRvTOBslDur+A+PsmdSwRma2q4+KXJ1PTNxR40/1/9QQLQQBVLQP+iXM7LKOp6sOqOk5Vx/XoYfOkG9OQRdsWuyM976Duv7Ea86xUxap4bPl/iMQiKY3PNJ1u/Y07jXP19BAh0K1o6V2enSOZhFIzkm04r6ueNdavAwZ4FJcxJqPVrT+JapT1oeI0xGIao7EtEF2VYE0MQu97dp5kEspyYBiAqoaBxcCPa6w/BBvLy5h2ZXjBztDEyveoRikIWGPLjNRQSzkP50ZMJqFMA2p2130MOFVE/ici7wEnA+1+wKFYtJSVW55i+aYniEY3pzscY1pVwBfgFztdTLYviyxfFj6EoC+AL+6jIyABRnbejcJgpzRFahoikgvZk3BrKWrIgbzTvTtPEpXyfYDdgfdUNeROrHU3cAbOQEPPAZdrGkZxS6ZSvqZx48bprFmzmrz9ss3P8+elL1AacxrHZUuUSwYdwG49LkjmtMa0OaXhUj7d9Bnl0QpGFo7gq5JveHH1K/jFTyQWYXinnfjlzheTH6hv+BSTbhorQTdPpjy0hK2xbLr7ywjmHoJ0vh2R5Lok1lcp3+SEkmlE5ExgkPvjL4Es4E735+Wq+lhjx0gmoVSGv+eyeVdRrtU9eB3ZEuWOUdfQOXfXZMI3ps2rjFayumINnYOd6Z7dLd3hmEZEYhH+texxZmz8GL8IinBM32M4ss/hSfcp8qKVV2MnKBCR33p1vCaYDNzsPnriDL9S/fNkr082p/g/RBHiKyNjCh+v/4/XpzMm4+X4cxhWMNSSSRvx5Iqn+WTTJ4Q1SmUsQigW5uU1r/DxhhmenaPFY3mJSAHOtL+X4wzHcnNLj9kUqnpQKs5TrSRcTlTrZvEwfraGba4Gk7kqo5U8v+pFPt44A1VlXNe9OKX/iRQErQK9owjHwnxQPJ2whmstD8WqeGXt6+zb4weenKfREoqI/FREPheRchFZJSJTqifYcjsJLgVuAUqAiz2JKgPt0mUSPql7ezBbouxWtG8aIjKmcarKlK9vZ9r6/7Etso2yaBkfbviIGxfcYn1GOpDKaCVK4uqNreGtnp2nwYQiIkcDTwKjcfqe9AauAm4RkYeAvwBbcGZr3FlVH/YssgwzpHAfdi/oQpbsmOgoS6IMyslhVNej0hiZMfX7uvQb1lWuI6I7kkdUo2wNlzBr8+w0RmZSqSBQQH4gcfPgnQqGeXaexkoovwLWA3uoak+gB/ABzthd5+OM3TVCVR9V1XY/pdzPd72TM/ofytCcLAZnBzi5z75cNeLP+H02tLbJTCvKVtRKJtVCsRDLy1akISKTDiLCGQNPJcu3Y6IyQcj2ZXPyAO/m2mmsDmVP4H5V/QJAVTeLyPXAdOBuVf2jZ5G0AT7xcWCf0zmwj3ftto1pTT1zehKQIJG473vZvmx65fRKU1QmHSZ0G0+nYCdeWv0K60PFDM0fzPH9j6NfbnLjeDWksYRSBCyJW7bYff6fZ1EYY1rF7p1Hkx/Io6qqavvYW4IQ9AWZ2G1CmqMzqbZb4a7sVth6XRwaSygCxJeXq38u9z4ck24bQ5t4be3rfFP6LT2yu3NEn8PZpZMNS95WBXwBrh/xGx5Z+k++Lv0GVWVYwVDOH3oeOf6cdIeXUExjrKv8njx/LkVZRekOxyShKc2GB4tIzQmdO7vPO4vIlviNVXWOF4GZ1CsObeB3828kFA0RJcrqijUsKPmG8wafzT7dJ6Y7PNNMXbO68OtdL6cqFkY1RrY/c2dAnLN5Lo989yjhWJioRhlWMJSf7/QzOgc7N76zSbsGe8qLSAwStjWTepajqm2mhjrZoVe8oKosKPmGBSXfUBjsxMRuE+gcLExpDPV5eMkjzNg4g1jcn7bAn899Y+/Gb/N6m1a0onwlNy+4japY1fZlPnz0z+vHzaNuSF9gpo76eso3VkK5sZXi6ZCiGuXOb+9jYeliQrEQQQny7MqpXDb8l4zsvFu6w+Pr0q/rJBOAKg2zMbSJnjk2f4xpPf9d926dvjExYnxf+T0rylcyMM9mx8h0DSYUVbWE4qEPi2ewsHQRIfcbWFjDoHD/4r9y/9g7014CKAwUsqmq7gjKMY3V24bdGK8Uh4prTdpVzYefzVVbLKG0AZ6N5WUaN33DR9uTSU2RWITvytI/FfGRfQ8nu0Y7dXCGJd+jaHcbRTaFIrEIczbP4/3i6ayr7DhTDI3qPJKgxA+v7sxjPyR/UII9TKZp9lheItId+BQ4XVW9G12sHYufQ2IHbWBd6kzoOp7vK9fz8ppX8eEjqlFGFO7G+UPPS3doHcaq8tX84Zs7CMfCziS7quzbfR/OGXxW0iPCtjWTeh7EO9+/S2mkdHu/mSxfFj/seRCFGVLPaBrWksEh/cBgINebUNq/A3vuz9KyZZRVhSkrzyEQiJKXGyLbn8Pg/IHpDg+Ao/seyaG9DmZt5TqKgp3pktUl3SF1GKrKPYvuozRSWmv5jI0zGVG4G3u3834j+YE8bhp1A6+teZ05W+aRH8jjR70OZWK3vdMdmmmiFo82nE7uIJW/Ai7CSW7FOLNG/k5Vy9IYWkL7dJvAI3M/47NvKxFRVIXc7AgPH3MMPkl/CaVajj+HIfmD0x1Gh7OqYjUl4dI6y0OxENPWv9fuEwpAYbATpw76CacO+km6QzHNkDmfYs1zN3AXsABnkq1ncYbSf6V6RORMMmPVSmYuihGL+YhG/cRiPiors7n5XRukzzhDjAuJb2tVJah7MybTNKmEIiLZwN7AWlVd5C6OAsuBtEwGIiIjcZLIVFU9scby74D7gJ/ijJScMR6dN5eKSO1mkVFVlm/ZzOJNG9mpq01U1JENzBuQsKVfli+Lfey2j2kDmvotPgq8CxxevUBVN6jqkDRWyJ+K08Hynrjlf8MZFuaMVAfUmI3lie/C+X0+NlfaJF0dXcAX4KJhF5DlyyLgJpZsXzb9c/txUM+D0hucMU3QpBKKqkZEZB3x89+m13gghtPSbDtVrRSRee76jHLw0GF8vaGYULT2yK/RWIyRPWzkVwNjikZz2+ibmV78IZvDWxjdeSRji/Yk4GvT1Z2mg0jmVfoscIqI/FlV6/Y+Sr2+wAZVDSVYtxr4gYhkqWqtm8/uLJMXAgwcmNqWVWfuvifPfDWf4rIyKqMRBMgJBLh2vwPJC9Ztf9+Rra8sZt6WefjFz15dxnaoQQJ7ZHfnhP7HpTsMY5LW4FhetTYUGQE8AWzCuc20iAQjDqtqSmbtEZElQFBV62QFEfk3cCbQRVW31HeMdIzlVRoK8eSXn/POd0vokZfPOXuMZUK//imNIdO9uuZ1Xlz9Ms5wcU6h+NwhZ7Nv933SGpcxxtHcsbxqms+Od/hBDWyXqvFDyoGe9azLqbFNRumUnc1F4yZw0bj23wS0OVaWr+KlNa84w9LU8M/v/sXoziOtg5sxGSyZhHIT9YwwnCZrgBEikp3gtlc/nNthrdLWsiQUQlXpnJOZ80m0ZTM3fkpVJMya9UWs31CET5TevTbTr0clczbP46CeB6Q7RGNMPZqcUFT1hlaMozk+Aw4DJuBMSQyAiOQAewAfeH3C1SUlXP7WG8xbtxaAXbp3587DDmfnbtbc1ysRjfLFNwMp3ZZLLOY0Qiwty2Hr1jJ0UCZU3bU9kViMZ7+az1PzvyQai3HCiBGcPnoM2QGr6DfeyrjOf0l4GqfEdGnc8guAPJz6Hs+Eo1FOeuYp5qxdQzgWIxyL8dX69Zzy7FOUhhK1CzDNUt6fbTWSCUAs5mf9xgLyozbabHP8/LVXuOWD9/hy/fcs2FDMnz7+iDOmPkesifWnxjRVUglFRDqJyO9E5EMRWSQi+7jLu7vLW2+y4jiq+iXwAHCCiEwVkfNF5E6cnvPv43GnxmnfLWVbVYhojTehAlXRGK8s/NbLU6VdTJUN5eWEIvGzP7e+xesricbqvix9+PlmfUnK42nrPl+3jg9XLK/VobYyEuHrDcW8v+y7NEZm2qMml3lFpAfwITAUWOw+54LTyVFEzgaKgMu9D7NelwLLcJoBHwlsAP6MM5aXp/dHVpaUUBWte8iKSJjlW7Z4eaq0evnbr7n5g/corQrhQzhl5Ciu2/8ggv7UtLUoykk81mhMoUs960z9Zq1ZTSRW93VbHg4zc/UqJg0Zmoao0qu6ZWv8c0Prmvrc3OOm49x9+vQh6HF3hWRuot4C9MYZgmUFsD5u/UvAwR7F1SSqGgXudB+tanTPngT9PsKxKNmxGH6c5m55gQC7FhSwefPm6pia/OzFC8bL5wXF6/nr7E8piMYocM83Y84cbvp+PT8ZObpVz139HF29ihGVTluKmr1oBdiycCHT1xe3yrmbuy5V2zb3WFvKyzm0tIxYzFkmbrsanwg6Zx5//2Zhq103L39fr/YxO+xy+I85fuxentalJdMPZTXwb1W9VkS64Yzse4iqTnPX/wK4SVW7ehZdK0umH4qqcvKzT/PV+u/Zb2sp/SPRxncyaVU9f0hTn5u7rqXPrXmMmCpz1q4l4hbYq9/tfhHG9etPllvyTMXv0NLfOZP3aWjfTDn36tISbvvwfSKxGKFolG25OXTNL2DqKafRJTe50r8X/VC649zqqk+MHf0/2h0R4bHjT+SBT2fy/ty5bIqE2b1Xbw4dthO5wWCzXgTp+OBp6PnsF55jQ0U5GjfATrY/yF+PPpa+nQpbPYZnFsznro8/pCIaqdVGPS+YxZ2HHc6Bg4c0+VoZxz7Fxfzs1ZfZUF6GiNApK4s/H3EU4/r2S3doJoWufOpxlqCoT8AXgEiEytIS7vrkI26edIgn50gmoawDhjWwfk+cW2HtVm4wyJX77seV++6X7lBaxdCBA1i8ZHGdzkb5wQC7DBiYkmamJ4zanXtnfUo0FNveCing89ElP5+Dhg7D72vLDRPTY7cePXjvnPNYunkzkViMnbt1w2eJt0MpCYX4ekNxnfd2OBbjjUULPUsoybw7Xwcmi0if+BUisjdwFk49immjLp24LzmBYK26i9xAgEv33idlfRYKsrJ4/pRTmdC3H34RAuLjoMFDeObkn1oyaQERYVjXruzSvXtGJ5NQJMIzX81n8ksvcNV/3+Jzt8+XaRl/A3/zgN+791UydSi9gdk4Q6u8DEwGHgeygBNweq7vpaqbPIuulaVjLK9M93Xxem7/eDrz1q2jZ34+v5gwkaOHp6w1eC1V0Sg+EQKWSDqEUCTCSc88xdLNm6mIhPGJkO33c+3+B3LG7mPSHV6bd/rUZ5i5elWt/kfZfj/n7bkXv/7B/kkdq746lCa/U1V1HTARmAmcBwjOAIynAG8D+7elZGISK8zJoX9hZ3rk59G3UyG98gsa36mVZPn9lkw6kOe//oqlmzdREXHGcYupUhGJcNv099lWZTNWttSdhx1On4JO5AezyPb7yQsGGd2rN7+cMNGzcyR1H0NVVwLHikghsAtOUllsiaR9WLl1K0c/9RjlVVVEVFm8aRMzV69kysGHcewuu6U7PNPOvbFoUZ0ZTcGpQ5uzdg0HDBqc+qDakd4Fnfjf2ZP5YPkyVpVsZUSPnuzVp6+nDVmadWNcVUtwxtIy7cg9Mz9mW1VVrSJxZSTCje9P48idd7HSQgemqny9oZiSUIjde/Vulfl7iuoZbFVV6ZSV5fn5OqKAz8cPW7Eza9IJRUTygMFAN6g7g6Oqej4oo0mNGatWJBzfKRSJsKa0hIGdi1IflEm75Vs285Pnn2ZDeTko+HzCNfsewHl77uXpec4cswfTvltaq5QiQOfsHMb0rtMWyDRDKBLh3e+WsGLrVkb27Mm+AwZ52kgjmaFX8nDGyTq3nv0Ep99UquZDMR7rkZfPum3b6iyPqtb77dG0b6rKcU8/wdYaA6DGYsqt099jl27d2XfgIM/ONaFff341cR/unvExQb/fKZlkZ/Po8SdkdMu0tmJVyVZOevY/lFVVEYpEyAoEGNalK0+ecAr5HpUAkymh3IvTsut1YBqw0ZMIOpjlW7Zwx8fT+XjVCjpn53D+2HGcNmr3jOiQd9FeE/j1f9+o9Q0x2+9n0uChFGZbQumIpq9YViuZVFPgDx99wCsDz/T0fBfuNZ6TR4xi9to1FGZnM65vP0smHrny7TfZUF6+/S5EJBzm240buG/mDK7d/0BPzpFMQjke+I+qnu7JmTugtaWlHPv049vrKbZUVnLb9PdYunkTvz1gUrrD44idh/PiR1/w7ubliIL6oEski5v2/2G6Q+tworEYVdEoua1QV5GMeQ30A1lVsrVVztklN5dDhjbUh9oka1tVFXPWralzS7sqGuXFbxekJaHkAO95ctYO6pG5s6gIh2v9USsiEZ788nN+Pn5vuubmpTE6mPbxtyx9exW9wkokD/xVkK0h7o6+y62/PjatsXUUoUiEW6a/x3MLviISizKocxE3TzqEfQYMTEs84/v1r3fdkKIuKYzEtERD/Q1jHo6bmUyznVnAzt6dumVE5CIReUJEvhGRqIhk/HCis9asJpxgKPEsv5/Fm9Lf8vqJFz6lMhTBF4OsbU5CCYejfDxrKaVllekOr0O44u03eG7BfELRCFFVlm7ZzPmvvMA3G4rTEs/EfgPolmDgQAF+s9+BlIfDRBO8pk1m6ZSdzaieveq0osry+zlq+C6enSeZhHINcK6I1OkdmSbXAsfgDKO/Js2xNMmQLl0T3g+uikbp5w68mE6bt5YnXO73CyWlllBa2/fbtvHOd0sIRWuPZB2KRvnr7E/TEpOI8MqpZzK4qAifCD4Rsnw+zt59LJe//SZjHrqf3R+6n9umv084aiNwZ7I7Dzucopzc7U2+84NBBnUu4rKJ+3p2jnpveYnIPxIsXgV8IiIzgKVA/CtIVXWyZ9E17CBgharGRORVoP6yeYa4cOw43lqyiMoald5Zfj8T+w+kX2H6E8rY0QN4+4Ovt8+dUS0rK0CvHumPr71bVbqVbL+fqrgP5pgqi9JYgu1d0IlpZ01mxdYtlIRCbKuq4ryXXtj+Oq6IRHj8i88pq6ri1oMPTVucpmFDirow/dwLeG3Rt6zcuoWRPXtx8JBhnvYva6gO5ZwG1u3rPuIpTkuwVqeqy1JxHi/t1qMnfznyWK6b9l+Ky8sAOHynnbllUma8CSf/ZF8++mwJFZVhIu7slDnZAS6bfLCnA8iZxIYUdalTOgEIiDCmV+80RFRbdT+kc158vtaXInA6wE79egFX73cAhdnZaYjONEVeMMjJI0a12vHrTSiqap8greCAQYP54Jzz2VRRQV4wmPZWPDX16dmZR+86myde/JS581fSp1dnTj9uAmN2y/jCX7vQNTePn4wczbML5tf6wM4OBLhor/FpjKy2pe7spPECPh/ry7ZZQunAUjMmeTsTicZAlUAg+T6cGzeX8djUmXwyZylFhXmceuw4Dpw4vBWibJ5e3Qu5/Hxv5kYwyfv9gT+kf2Eh/5w7h62hSvbq24/r9j8oo0YpGNWzJ2tKS+s0QY2pZkRdoEmfFiUUEQkAxwJdgVfcEYmT2b8IuDSJXe5r6UCUInIhcCHAwIHJNcXcuLmM2//yNp/M+Q5VZc+RA7j6ksPo26uoSftv3lrOOVf8i9JtlUSiMVat28LN973Bdys3cs7J+yT7q5h2yCfCBWPHc8HYzCmRxPu/CfvwztKltRKKAKePHtPiEvfyLVu4bfr7fLxyJflZQc4aswcX7jXexpFrI5IZeuV2YJKqjnd/FuAdYH+c19NtIjJRVZckcf4i4PdJbP840KKEoqoPAw+DMx9KU/eLRGNc/Jsn+X5DCdGos9vcr1Zy4TVP8uxD55Ob0/jQBc+8OpttZaHt9RMAlaEw/546k5OOGEtBvt0qMK1jW1mIGXOWEospe+85mKLC5vd5WrhpI34R4scFnr/++xbFWFxWxnFPPUGp2/G3LFzF/Z/OZNHGjdz94yNadGyTGsmUUH6Mk0CqHQ0cANwOzAP+jNO0+IKmHtCtWG8T4yrMnPsdm0vKKO2ulPcWVCD3eyW4pYp3P/qWow4e3egxZn2xnHCkbqVrMOBjyfJixoywugrjvfdnLuSme17H53PeatFojMsuOISjm/CaTeQfc2fXaTygwJx1aykuK6NHfn6zjvvvz+dSEYnUGe36zcWLuLKkJCNaQpqGJZNQBgCLavx8NPCdql4DICIjgXY7LMvKNZtZOyRGRVdB/c4bM1IAlSVRlq3c0KRj9OpRyDdL1hHfaTUSidGtS/PehKb9WbysmKlvzmXDpm3sM3Yoh08aSU52824lbSkp56Z7XqeyKkK4ABAIVsLdf3+XsSMH0K93UfLHrEzcJyng81FaFWp2Qpm9dk2dJtPgNK1ftGmjJZQ2IJkbk1lQq5Q7idollqVAux1j2tclQEVXticTcP4fLhTC3ZtWOf/TY8aRlVU7hwf8PoYP7Un/PjaMhYH/Tv+ai659glff/ZKPZy/lgX+/x+RfP0Z5RfNmLPxg5mKqCpTv9xY27i5sHC18P1EoL4jxzoffNOuYkwYPJZigTiPb72dQCxoPDO/WnUCCjr/hWIyBnTs3+7gmdZJJKCuBfWB7aWQo8H6N9T2BumOftxIROVpErheR64Gd3GXXu49feH2+krxowptz6oOKTk0bemLU8L5cc/GP6JSfTW5OkKygnz1G9ucP1xzvcbSmLaoKR7jjr/8lVBXZ3rm0MhRh7fqtTH1zbrOOWRqqZM2uSixb0IDziGUJxbspmyoTj4zQmEvGT6BLbi7ZfueLlE+EnECAWw8+FH8LKs/P3WMsQX/tL2dZfj979u7D0C5dm31ckzrJ3PJ6CvitiPQERgIlOEPZV9sTSKZCvqVOBM6OW3az+7wcuN/Lk3XPzyM3O0h5OFxreXbAT69OnZp8nEP3341J+wxn5drNFBbk2q0us92i74oTVihWhaO8N2MhZxy/d9LHDHX3wcIEK0Qo79G86sse+fm8ecZZPP7553y4cjn9O3XmvLFjGdGjZ7OOV21QURH/Pv4kfvPuf1m6eRN+n48jdx7OTZMObtFxTeokk1Cm4NSjHAdsBc5S1S0AItIZZ1ytuz2Or16qeg4N9+b31GHDduKG96bVWe4T4dhdk5tvPRDwM2RAd69CM+1EXm6w3oEWO+U3bz4azRJ8fiFK7Yo79UEwv/m9BopycvnF3hP5xd4Tm32MRPbq25e3zjybsqoqsvz+OiUWk9maXD5V1ZCqTlbVbqo6VFVfrrG6FKf+5AavA8wUecEgj59wEr0LCsgLBskPBumam8sjxx5P97z0Djtv2ofB/bvRq0dhncnWcrKDnHjEns065sT+Awgm6ICbFwyyz4ABzTpmKuRnZVkyaYM86SmvqjGcUku7NqpnLz467wK+2bCBSCzGiB49WnTP2JiaRIQ7fnMCl974LJu3luMTIRyJcspRY9l3XPMmnBrZsyeHDh3GO0uXbJ+JMzcQYM/efTydvtcYAKlv4hUROQBAVT+o+XNjqrdvC8aNG6ezZs1KdxjG1KKqzP92DZu3ljNql750LWpZPVtMlZe//Yan539JJBbjxBEjOHG3kVYCMM0mIrNVtc5UJg0llBhOf6VcVa2q8XO958AZvr7NvEotoRjTPN+t3MDDT37Il9+spmtRPmedOJFD9ts13WGZFKkvoTR0y+s8nARS3azp3NYIzBjTtqxYvYkLr3mCylAYVdhSUsEfHnyT9RtKOO24CekOzzRgzfdbmPrGXJat3sTuu/bj2MPG0LlT3Rk5m6uh4esfdZsIB4EqVf2XZ2c1xrRZ/3z2Y0JVkVojPlSGIvzz2RmceMRYsrNsEPNM9OU3q7nspueIRKJEojHmfrmSZ16dzSN3nEmv7t6MQtBYjfJa4KTqH0QkV0RuE5GhnpzdmHqoKqsXr+X75emZS93UtmHTNp5+ZRZ//8+HzJm/ss6snuDc8167vuVtcypDYT7/ehVLlxdT3y15k7wpD7xJZWjH5HmhcISSbZU8/MR0z87R2FeJ+J5PecDVOEOuLPUsCmNqWPDJQm479R62FG9FY0rfnXrzu2evYMAu/dIdWoc0Y85Srr/9ZVSVcDgKvsQdIsPRWIsbELz6zpfc88g0/D4hGovRu2dn7rjuBPr0tKFXWqKktII1CZJ9LKbMmPOdZ+dpTpvXNjE6sGm+cFWYVYvWsm1LWcrPvaV4K9ccdjPfLy8mVF5FVWWY5V+t4vIDf0dVKNz4AYynqsIRfn/nq4SqIlSFne6RmqB0kpUV4Ic/2IXCguZ1wARYsGgtd//9XSpDYcoqqqgMRVixehOX3/SclVRaKCsrUO8Hd26Od7PGWicKU8vLD77JST0nc8leV3FKnwuYcsa9hCpCKTv/O49/QDRau7e4qhKqCDPz1dkpi8M4vvh6NQnGawSFQMBHdlaArKCfw/bfjasvPqxF53rutTlUhWvPshKLKRs2bePbJS2ba6Wjy8kO8oO9hhEI1P7Iz84KcMLhzes0m4jVnpntZrwyi79d9TiV5TsSyIdTZyIiXPPY/6UkhvUrNlCVYGTdaDjCxjWJ5zI3rccnUme6hWp7jxnMr392GAX52c0eXr+mjZvLEp7L5xO2lFS0+Pgd3dWX/Igrb3mOpSs24PP5iESi7D9hJ35ydJ3Wv83WlIQyTkSqJ0CoHgVxP3f63jpUdaoXgZnUe/K2qbWSCUBVZZgPnvuEX94/mfzOrT+Q5e4HjODNR6ZRsa32nBvi8zHiB8Nb/fymttG79sOfoM4kJzvIUYfsTveuBZ6da7/xw5j/7RpCVbVLKeFwlBHD2+3MGClTWJDDw384g0XfrWft+q0MG9SjWfPhNKQpCeVX7qOmG6jbyVHcZW2mY6OpbcPqxLMr+wM+SjZuS0lC2efocfQf3oflC1ZTVemUVLLzstjjh6MYvlfzhh8xzRcM+rn16mO56tYXAIhEo/h9Pg7edxf2G+/t3+PIg0cz9c15rN9Quj2p5GQHOfukiS2qmzG17TykJzsPadnI0PWpt6c8gIjEDw/fqLbUX8V6ytd266l388GzM+o0Cc3vnMdz6x8hEEzNHdKKskqm3vMq7z4+HX8wwBEXHMwxF/8If4JBDk1qlJZV8t7HCyktCzF+zKBW+0Aqr6jihbfm8f6MRXQuzOXkI8cyYY/BrXIu03xJD72SyUSkH3AWzjz3w4FCYBnO/Cx/UNWNTTmOJZTaVi1cwyXjryFUHiLmVoxn52VzyT3ncMT5h6Q5uo6jKhpl+vJlbKwoZ0K//gwustk8TWZpztArmexonNturwF34AyfPwG4FPipiIxX1XVpi66N6j+8Lw/O+iOP3fgM8z/8hp4DunPqb05ggoetQEzDFm7cwOlTnyEUiRJVJaYxTthtJLdMOqTOsPbGZJq2WkIZCWyMTxoicj7wN+BOVb2yseNYCcVkElXloH89wsqS2h3Q8gJB/nDIYRw13AZfNJmhvhJKm+yHoqpf1VMCedp9HpXKeIzxwrcbN7Cxou487+WRME98+XkaInKoKh++MJMrDvo9F465gkd//zSlm7elLR6TudrqLa/69HefrReUaXNC0Si+evozV0YiCZenwqO/f5qpd79KZZnTpHzVwrW8+9gH/GXeHeQX2mylZoc2WUJpwI3uc70tzUTkQhGZJSKziott4EGTOUZ0TzwDaG4gwDG7pOd219YNJTz3p5e3JxOAcCjMpu+38Mbf301LTCZzpbWE4naOvDSJXe5T1YSdJUTkCuBk4GFVnVbfAVT1YeBhcOpQkji3SaFYTFm2aiOBgI8Bfbp0iArpoN/PXT86nJ+//grRWIxwLEZeMMhOXbtx2qgxaYnpm08XE8gKUlVZexy1qooqpj35IdFIjG59u7DfCXuTk5edlhhN5khrpbyIDAaSGepyZ1VdnOA45+MkideB41W1SaMIWqV8Zvp8wSp+f9crlFVUoar06NqJW686lqEDu6c7tJRYVbKVZ76az/qybRwwaDCHDt0pbdP1LpqzlMsP+j2VcSMXgNPhFYSsnCCBrAB3vX8Tg0cOSH2QJuVa1A9FRCYCZwDjgX44w9iXA6uBz4AnVHWGpxE3kYicB/wdeBs4VlWbPJKhJZTMs2lLGT/5+d+pqPGNWMQZNmLqwz+zyZtSTFW5YPTlrPx2zfa+SYmIwIBd+/HIV/ekLjiTNs1q5SUiARH5B/ARcAlOMlkNfOk+93OXfygij4pISr9G1Ugm7wDHJZNMTGZ68/0FCUYbhnAkxkezlqQpqo5LRPjDW9czbI/BZOVmkdcpF0kwtpcqrFtWzLpl69MQpckUjX3duxo4B7gLuEdVV8VvICL9gcvcx0LgNo9jTEhEzsHpczINp2RSt0xu2pwNG0upCkfrLI9EomxKw/wsBrr368aDn/2RtUu/Z9uWMqacfi8rv11TZzsh8VwppuNorJXXucAjqnplomQCoKqrVPUK4B/AeV4HmIiIHAM8ApTg9D05UUTOqPE4LhVxGO/tOWpgwgl/fD5hzG79E+xhUqXP0F7sPHYoh519EFm5WXXWd+vXld4tHOOrZFMpj/zmCSaPvJRL97+e6c9/YpNrtSGNlVD6A02tG/kYOL1l4TTZWJxkWITbYivOcuDFFMViPPSDvYYyZEB3liwvrjHibIC99xzSagMSmuQc/6sj+Pjlz1g2fyUV2yrJzsvGH/Bx/VOXtag1XtnWMi4eexWbv99K2J2dc8m8ZSyau5TzbjnNq/BNK2pstOGlwDuqemGjBxL5G3Cwqg71ML5WZZXymSkUCvP8m/N46/0FBAI+jjlkd446eDR+f3vrNtV2xWIxZr31OQtmfEv3ft2Y9NMftHh6g2fueIl/3fBMnQnWgtlBnlzxEEU9bF75TNHcwSEfB64TkS3Avaq6OsGB++H0JTkPuLXloZqOLjs7yGnHjue0Y8enOxRTD5/Px4TD9/R04NDP3pyXcLbOrJwAC2cttUFK24DGEsotwO7AlcAVIrIap3VXCMjGaeXVD6c+7lV3e2OMSVrPgd3x+aTOfDzRSIyuHs8s2FF9/NJn/PvGZ1i/YgPD9hjM5NtOY9cJO3t2/AbvIahqlaoeBxwF/Aen78lIYD/3uRx4EjhKVY9R1bpfL4wxpgmO/78jCMY1yPD5ffQe0othNslWi7316P+47fR7WTJvGaWbtjFv2nyu/OENfD1zkWfnaNJNaVV9XVXPUNVdVbVQVQPu866qeqaqvu5ZRMZ0cOGqMB+/9Bmv/+0dVi2s2zy3vdppzyH8+p+/oKAon9xOOWTlBNll/DD+8Nb1HWLondYUi8X421WPESqv3VUvVF7FI795wrPzWLdjYzLId/NX8Osf3kg4FCYajaGxGAeffgCXPXxRh/hQPfDkfdj3uPEsX7CKgqJ8eg3qke6Q2oWSjaWUlybuqrdk7jLPzuNZsxkRGSAiB3h1PGM6GlXld8f+ka0bSigvrSBUHqKqMsz/nvqQ957+ON3hpUwgGGDYmMGWTDxUUJTvjr1WV48B3Tw7j5ftMM8C/ufh8YzpUL77cgVb1m+ts7yyLMSrf307DRGZ9iIQDHDMz39MdtyI0Nl52Zz5u5O9O49nRzLGtEg4FEYSzIcCJGxOa0wyzrv1VFDlpQfeIhaLkZOXzeQpp7H/iRM9O0eDCUVEzkriWNZI3JgW2GnPIQQCdcdXzc7L4oen7ZeGiEx74vf7ueCPZ3LOzT9l25ZyCrsV4Pd4WoTGSiiPAgr1zEtaV4cYdKeqsopYTG1CIeMpf8DPtU/8HzeedCfRSJRIVYTcghwGjRzAkRcemu7wTDsRzArSpWfrjDrQWEIpA+YB9zThWCcCP2lhPBltw+qN3Dn5IeZOmw8ou+09nCv+cQn9d+6T7tBMOzH+x3vyjwV38+Y//8emtZvZ69Ax/ODY8fgTlFyMyTSNjeX1IdBZVUc3eiCR64CbVLXNvPKTGcsrGoly1s6/YMOqTdsnGhKf0KlrAY8vfYDcgtzWDNUYYzJGsybYAuYAu4pIUz8t221D+ZmvzaF007Zas9ZpTKmqqOJ/T3WcJp3GGFOfxm55PQZsBAqAiiZs+6EXQTVGRHoCfwT2whliPw9YBbwPTEk073xLrVmyjnAoUmd5ZVmoQ/VmNsaY+jSYUFT1M5w54xulqiuAFV4E1QRdgOE488gvx0l2O+OMeHyyiExU1QVennDYHoMJZgWIVNVOKrkFOew8ts2M2G+MMa2mTfZDUdVvgX3jl4vIc8CnwC9w5rr3zB6TRjFg17589+WK7SWVQNBPUc/O7HfCBC9PZYwxbVJ7m7FoufvcxesDiwh/mnYDR1/8Iwq7d6KgSz6Hnn0Q98+cQjCr7pS1xhjT0TTYyqvWhs7sjQ1RnFtPK3BuRf1NVctaFl6jMQWBzkAQ2Am4AfghcJaqPtbY/jZjozHGJK+5rbxqWgFEgME4JYAt7qOLuyyCk1AmAncBs0WktUd3+xFQDKwBPsCZo+WKhpKJiFwoIrNEZFZxcXErh2eMMR1HMnUolwLv4NRNPKKqYQARCQAXAjcCJwPzgYuB+4Cb3P8nJCJF7nGb6j5V3VTj50+AQ4FcYATwU6CLiARUtW6TLEBVHwYeBqeEksS5jWmTYrEY7z31Ea///V2ikSiHnnUQh519IIFgm6xCNRksmVte7wDfqurP61n/ILCzqh7q/vw4cICqDmzgmIOB75KId+eGmgSLSF/gC+B5Vb2osYPZLS/TEUw5414+fukzKsucyZVy8rMZsc8uTHnzOnz1DEZpTEO8uOW1N86HdX2+wLndVe1joFdDB1TVZaoqSTwa7F+iqmtwSlGTRSQjB9oqKynn6dtf5NL9r+emk+9k/odfpzsk044tnvcdH7346fZkAk7fqQWfLGTuu1+mMTLTHiVT5g0B44G/1rN+grtNtWxgWzPjaolcwA8U4tSvZIyyrWVcPPYqNq7bQlVFFSLw6Rtz+NmdZ3PURYelOzzTDn3x3oJaoztUq9xWydxp89nr0DFpiMq0V8mUUF4GzhWRa0Qkr3qhiOSJyLXA2e421X4ALPQmzNpEJGHJR0RGAAcDS1Q1o5IJwEsPvsXGtZu3z22h6szp/Jcr/k1FWeLpOY1picLunRLWlWTlBOncozANEZn2LJmEciXOba3bgC0iskxEluG09LoVpzL+1wAikgNUAg94GWwN14rIVyJyu4hcIiI/F5GHcDo1BoGE9TzpNuPlWVRVhuss9wd8LJmbTFWSMU2z73Hj8fnrvs19Ph8H2xwrxmNNvuWlqptEZG/gfOAoYIi76l3gFeDvqlrlblsJnOlxrDW9ijOG1ylAT5xbXKuBZ4E/qepXrXjuZiuq5xthNBKlU9eCFEdjOoLcglz++PZv+f1xt1NeWgHiTAd7/dOX07W35/1/TQfX5FZe7VGqW3nNefdLfnfsHwmV76hq8vl9DB45gL/O+1PK4jAdTywWY/Hc74hGYgzfa6jNr2JaxItWXvEH7C4i3VsWVscy9uDRnHvLT8nOzSK/cx45+dkM3K0/t7x6bbpDM+2cz+dj+F7D2G3vnS2ZmFaTVAnF7ecxBTgW6OQuLgFeAq5T1dWeR9iK0tUPpayknEWzl9K5eyeGjB6U8vMbY0xL1FdCaXIdiogMxOmZ3htnWuDqeooRwFnAoe6w8StbHm77ll+Yxx6TRqU7DGOM8VQy/VBuxhm36yhVfb3mChE5HJjqbnOOZ9EZY4xpM5KpQzkMeDA+mQCo6hvAQ8CPvQrMGGNM25JMQukCLGpg/SKgqEXRGGOMabOSSSirgIMaWH+Au40xxpgOKJmE8izOfO1TRKRz9UIRKRSR23A6GT7tdYDGGGPahmQr5fcHrgauFJE17vK+OD3VPwJu8TY8Y4wxbUWTSyiqWo5zy+sinCl+y9zHWzgTbE1S1YpWiNEYY0wbkNSUbe4siH9zH8YYY8x2Nl2bMcYYT9RbQhGRs5pzQFX9d/PDMcYY01Y1dMvrUUABSeJ4CqQ8oYiID6dRwETgNVU9KtUxGGNMR9dQQpmUsiha7hLABscyxpg0qjehqOr7qQykuUSkP84skr8H7kxzOMYY02G1h0r5B4ClwL3pDsQYYzqypJoNZxoROQk4GviBqkZFkqnuMcYY46U2W0Jxh3+5D/irqn6SxH4XisgsEZlVXFzcegEaY0wHk9YSiogUAZcmsct9qrrJ/f/tOAkxqflzVfVh4GFwZmxMZl9jjDH1S/ctryKcyvSmehzYJCL7AxcAZ6rqllaIyxhjTJLSmlBUdRnJ9XOpdj/wOTBTRHaKW5fnLtuiqhtaGKIxxpgmSncJpbkGAZ1JPOHXJHf5A8AvUhmUMcZ0ZG01oZwFZCVY/iwwG/gDsDilERljTAfXJhOKqr6caLnbbHidqj6X2oiMMca02WbDxhhjMkubLKHUR1WtZ6MxxqSJqHbcrhgiUgwsb+XTdAestZldh5rsWuxg18LR1q7DIFXtEb+wQyeUVBCRWao6Lt1xpJtdhx3sWuxg18LRXq6D1aEYY4zxhCUUY4wxnrCE0voeTncAGcKuww52LXawa+FoF9fB6lCMMcZ4wkooxhhjPGEJxRhjjCcsoRhjjPGEJZR6iIhPRC4TkW9EpFJEVorInSKS34xj5YnIUhFREbm/ge2OFJF3RGSziJSLyMKGtk+FVF4Hd3lDj+u8+a2aJ9WvCRHZR0ReFpFVIlIhIktE5G8iMrTlv03LpOFanCwiH4tImYiUish0ETmi5b9Jy7X0WjTwet9Wz/a7iMiL7udEmXstfujtb9U87WroFY/dDfwf8AJwJ7Cb+/OeInKIqsaSONZNQJ1epTWJyO+BG4C3cCYdKwcGArsnHbm3Unkdzqxn+Q3AMOCVJM7VGlJ2LUTkx8BrwBKc+X82ACOBC4ETRWS0qq5u1m/hjVRei6txRhCfC/zWXXwG8KqInKmqTzQjfi95cS2mU7elVzh+IxEZBnwMRHBmrd2KM9ngWyJyuKq+0+zfwguqao+4B84bNwY8H7f8l4ACpyVxrLE4f/zL3X3vT7DNIe6636b7d0/ndahnv/5AFPisI10LnC8WVUD3uOXnu/tc2hGuBdALCAFfAsEay4Pusk1AYVu+Fu52jzbxfM+474c9aiwrwBlC6lvclrvpetgtr8ROxZlJ8p645X/DKTmc0ZSDiIjf3edNYGoDm/4GWA9McfcrEJFM+Nuk+jokci7Ordm/J7mf11J9LQqBSmBz3PI17nNZU87XSlJ5LX6AM/fRE6q6/Ru7+/8ngS7AsUnE7jVPrgWAiGSJSEED6/OBY4D3VHVe9XJV3Ybz/hgOjG/q+VpDJnxoZaLxON86Pq25UFUrgXk0/Y92GbArDcwc6b5IDgBmApNFZDVQCmwTkadEpFfS0XsnZdchERERnIRSBvwnmX1bQaqvxVtAJ+BfIjJGRPqJyI9wbql8DTzV9NA9l8prke0+lydYV71sYhPP1xq8uhYn4fw+pSKyXkT+LCKd47bZHed6zEiw/yc14kkbSyiJ9QU2qGoowbrVQHcRSTRj5HYiMgS4EbhJVZc1sOlOgB/nTXEvzjebE4C/ACcD/xORvKR/A2+k8jok8kNgCPCsqpYkua/XUn0tpgAP4XzQzANW4XyTXwpMVNXSpKL3ViqvxVfuc6JK50nu84CGw21VLb4WOMnoBpy/9dnANJwkOz2uxNK3xnETnQugXxPjbhVWKZ9YHs5920Qqa2xT1cAx/oLz5r+rkXN1cp97ABeoavWtnRdEpASngv5snA+XVEvldUjkfPf5kWbs67VUX4sozofEOziVvZuAfXHuzT8lIsfWvAWUYim7Fqr6pYj8FzhWRG4H/umuOgc4vMa50qXF10JV945b9G8R+QK4FfiV+1x9HOo5X2XcNmlhJZTEytlR1I6XU2ObhETkDOBQ4OImvOkr3OcY8Fjcun+5zwc1cozWksrrEL9vV+B44BtV/TCZfVtJqq/Fo8Bk4GRVfURVX1DVK3E+YA7H+ZKRLqm+Fj/BqWO5EljgPk4Bfu6uT2fptUXXogF34CShI+PORT3na8m5PGMJJbE1OEXVRH+4fjhF3ITfONx97gJeB9aJyE4ishMwyN2ks7usyP15lfu8OUGxea373KWZv0dLpfI6xDsd542TCaUTSOG1EJGBOL//a6paEXe4Z93nA1v027RMSl8XqrpZVU8E+uDUN47FaUZe3UDhGw9+p+Zq9rVoiJto1+BMvFXzXNXHTXQuSHw7LHXS2cQsUx/ALThN+faPW56DU0H8RgP7Frn7Nva4ssY+y3FKKHlxx9rJ3fbxjnAd4vafh/MNrWe6Xw+pvhbAPu7PDyY4Vi933X86wrVoJI773W33a4vXopHj5uD0Q5leY1kBzq2tdxNs/1s3jr3TdS1U1RJKPX/M0TTctvyMGsuGAbvW+DmIU7kW/7jY3fcN9+fhNfapflFeFne+O0myXX9bvg419h3nbvN8a/xemX4tgK44fTPWAEVx57va3efyjnAtGohhnPvh+l5bfV24y7rVc9w73P2vilv+LE792pgay6r7oSwkzf1Q0nbiTH8Af3b/oFNxKofvxPnG8B7gq7HdMkCbcLzB1N+JrRCnKWgUp/L9Z8Dj7vbvAv6OcB1qbPOQu83h6X4dpPE18Sd33Xc4/ZR+hlPHFgMWk8bOfGm4FjfjNJO+HKde6QGcuoIlwIC2/LrA6WU/A7jN/RtfidPKS3GaAufGbb8TTgON74FrgEtwRhCIAD9K+7VIdwCZ+sBpynsFTu/TEM69ybuAgrjtPPkgxblX+hDOt9IqnBYwtwI5Hew65AJbgBU134yZ8EjltcDpLHcBTv+kbe4H1DL3w7RHB7sWx+MMN7IJp1SyEPgjcaW3tngtcDplvuXuU4lzm2wezpeIhO99nKFdXnLfJ+XAh8Ah6b4OqmoTbBljjPGGtfIyxhjjCUsoxhhjPGEJxRhjjCcsoRhjjPGEJRRjjDGesIRijDHGE5ZQjDHGeMISisl4InKQiKiInNOMfZeJyHveR9V+icjhIhIRkV1b6fhN+puISG8RKReRs1sjDuM9SygmrWoki/oe6ZyNz1Mick7c7xYTka0i8lFzkmVrEJEAztAhT6hqOkfxRVXX4cybcmsaJ5kzSbAJtkym+A/OkObxFuMMuZGLM/xIe3Af8BnOF7oBOOM//VNE+qrqbWmNzJkldDecudJbyy44w6w0xX3ApThTQT/QWgEZb1hCMZlijqo+3sD6ygbWZQQR8QPZqtrYJEfTVfW5Gvv9E2d8qqtE5I+qGm3NOBtxCfCFqn7u5UFFJIgzyGmlJp4uNyFVXSYi04GLsISS8eyWl8l4iepQRMQnIpeKyBciUioiJSLyrYg84n54xR9jVxF5zd12q4g8JyK9E2zXWUT+KCKLRSQkIsUi8h8RGRq3XfXtq0NE5LcisgQn6Z2S7O+nqmtwRpvujDMVdPU5OonILSIyU0Q2uPEsFpE/JLoFJCL5IjJFRJa4264TkX+LyKCmxOFej/1IXFJERAaLyGMi8r17/CUiclt8LCJyg3ttRorIXSKyCufaTHTXJ1uv9QYwurXqdIx3rIRiMkWeiHSPWxZS1dJ6tr8OuAl4Bec+exQYAhyDM9Njzdtj/XCGEn8B+DUwBucbbyFwWPVGItIZZ1TbgcA/gK9wZgm8BJgpIuNUdXlcHH/CmePjbzhT0X7b5N94x3mD7jljOCPI1oz7fOB54EmcIcoPBK4C9gR+FHeMt3DmnX8Opx5kZ5x5Rg5zY19Fww50nz9NEOMgd3ln4EFgEc7U1NcC+4rIwaoaidvtCZwprqvn9VlL88xwnw8ivbMzmsake7hje3TsB86HhNbzeCpum3Nq7DcHWNCE4y9z9z0lbvkD7vJdaiy7F+cDcEzctoNwksWjNZad4+7/LXEzbTYQS/U+5+JMV9AT2Atn0iQFnonbPgsIJjjOze72E2osu8Bddnvctke6yx9rQnw3utvunmDdE+66I+KWV08ENbnGshvcZe8BgXr+Ju8l8Rrp7x7vz+l+vdqj4Yfd8jKZ4mHg0LjHLQ1svxXoJyL7NeHYa1T1mbhl09znnQFERHDmcf8AWC0i3asfOHNUfEKN0kwND2njdSbx/gEU40ySNAs4EaeEc17NjVS1Sp25xRGRgIh0ceN5x91k7xqbH49TwpkSd4zXcObXOFZEGnu/V99u21RzobvfMcBcVY2/HTbFPe/xCY53j9YttTTHRve5pwfHMq3IbnmZTLFIVd9pfLPtfgO8CEwXkTU434ZfA55T1aq4bZcm2L/6Q6qb+9zD/f9hOB/2icQSLFtY8wcR6YpTsthOneavNd0ETMe5NTcB5xZWH5yJ1WoRkUtwZvIbSd06zy41/j8EJ3FuThDjV8AeOKWi9QnWbw+1+rRxy3vgTDP7VZ0dVDeJyFpgaPw64q5NC1THY5M3ZThLKKZNUtUZIjIMpx5hkvs4DbheRPZT1ZrfshtqNSVxz+/gzAbYVPGlk6nsqIuIP0e1L2skz9dE5GucZtM34Uzr6uwkcjlO/cPbOM1nq2fz7Ac8iveNaqoTaVdgpQfHS7bkVp+u7nN9id5kCEsops1S1W04FdbPw/Zv8w/gzDt+R5KHK8apEC9MsqQU7wpqlxwapapPicjPgMtE5C+qusxddSZOfcPhqrq9dCQiP05wmKXAj0WkSFW3xK0bgVMHtKGRUOa7zzsDNZsNFwOlOKWkWkSkC07pal4jx26JneLiMxnK6lBMm5SgRRg4FfWw4xttk7kf2E8AE0TkpHrO2eg9fFWdrarv1Hw0MYQbcW6VXV9jWRTnNs/2Eo7bk/0a6noR5/1ca52IHI7TIuzlmkmpHu+7z7VGJ3D3ewXYM0Eyu8Y97wuNHLtBItLHbdqdqEd8dTzvJ1hnMoiVUExb9bWIfALMxLkV1Ae4EOeW0FPNPOZ1OM1unxGRZ3Aq4qtwWnkdAczGaanlOVX9n4h8BJwtIrep6lKc5r9TgDdEZCpOM+fTSDxiwKPA2cDVIjIYp3HBTjhNnr/HqXNqLIZit3/IEcCVcat/g9NQ4kUReRBnBIMDgJ+45/pXMr9vAlPc+Cfh1IfVdATObUJrMpzhLKGYtupOnA+a/8PpG7EeJwFM0Wb28lbVrSKyL85tq1OAY3H6fqwCPgT+7kHcDbkZeBP4LU7T4jtwSieTcZo0rwOeBv4JLIiLPSwiP8Ip4fwEOAHnFt6zwPWq2tQ6kYeAp0VkL1WdXeP4y0Vkb5x6njOAIpzrMgW4xaPWXHW4yXE/4JetcXzjLVG1hhPGGIc7fMznwDxVPSMD4rkbZ3yx4c1onm1SzBKKMaYWt57kNWCUqn6dxjj64DQ2+JmqtvSWmkkBSyjGGGM8Ya28jDHGeMISijHGGE9YQjHGGOMJSyjGGGM8YQnFGGOMJyyhGGOM8YQlFGOMMZ74fzZe+Ej2DBOGAAAAAElFTkSuQmCC\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": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "cmap = matplotlib.cm.get_cmap('viridis')\n",
    "colorvals_set = []\n",
    "\n",
    "plot_generalization_gaps = False\n",
    "ploty_range = 4.0\n",
    "fontsize=18\n",
    "\n",
    "# Hessian trace\n",
    "vals_set = []\n",
    "plt.figure()\n",
    "for ht in range(hyper_trial_num):\n",
    "    val = res_set[ht]['L_H'].sum()\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['petzka_maxeigen_nm'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['L_H'].sum()))\n",
    "    vals_set += vals\n",
    "    colorvals = (np.array(vals)-min(vals))/(max(vals) - min(vals))\n",
    "    colorvals_set.append(colorvals)\n",
    "    plt.scatter([val]*trial_num, vals, c=colorvals_set[ht], cmap=cmap)\n",
    "    if ht == 0:\n",
    "        minval = val\n",
    "        maxval = val\n",
    "    else:\n",
    "        minval = min(val, minval)\n",
    "        maxval = max(val, maxval)\n",
    "#plt.plot([minval, maxval], [minval, maxval], 'gray')\n",
    "plt.plot(np.linspace(minval, maxval), np.log10(np.linspace(minval, maxval)), 'gray')\n",
    "plt.xlabel('trace H (ori.)', fontsize=fontsize)\n",
    "plt.ylabel('log10 trace H (re.)', fontsize=fontsize)\n",
    "midval = 0.5*(np.log10(minval)+np.log10(maxval))\n",
    "plt.ylim([midval-ploty_range, midval+ploty_range])\n",
    "plt.xticks([0.19, 0.195, 0.20, 0.205, 0.21], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "#plt.savefig('./figs_for_paper/trH_reparam_invar.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "if plot_generalization_gaps:\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, generalization_gap_set)\n",
    "    plt.xlabel('log10 trace H (re.)')\n",
    "    plt.ylabel('generalization gap')\n",
    "\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, acc_gap_set, c='k')\n",
    "    plt.xlabel('log10 trace H (re.)')\n",
    "    plt.ylabel('acc gap')\n",
    "\n",
    "# Hessian top eigenvalue\n",
    "vals_set = []\n",
    "plt.figure()\n",
    "for ht in range(hyper_trial_num):\n",
    "    val = res_set[ht]['L_H'][-1]\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['petzka_maxeigen_nm'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['L_H'][-1]))\n",
    "    vals_set += vals\n",
    "    plt.scatter([val]*trial_num, vals, c=colorvals_set[ht], cmap=cmap)\n",
    "    if ht == 0:\n",
    "        minval = val\n",
    "        maxval = val\n",
    "    else:\n",
    "        minval = min(val, minval)\n",
    "        maxval = max(val, maxval)\n",
    "#plt.plot([minval, maxval], [minval, maxval], 'gray')\n",
    "plt.plot(np.linspace(minval, maxval), np.log10(np.linspace(minval, maxval)), 'gray')\n",
    "plt.xlabel('H spectral (ori.)', fontsize=fontsize)\n",
    "plt.ylabel('log10 H spectral (re.)', fontsize=fontsize)\n",
    "midval = 0.5*(np.log10(minval)+np.log10(maxval))\n",
    "plt.ylim([midval-ploty_range, midval+ploty_range])\n",
    "plt.xticks([0.110, 0.115, 0.120], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "#plt.savefig('./figs_for_paper/topH_reparam_invar.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "if plot_generalization_gaps:\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, generalization_gap_set, c='k')\n",
    "    plt.xlabel('log10 H spectral (re.)')\n",
    "    plt.ylabel('generalization gap')\n",
    "\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, acc_gap_set, c='k')\n",
    "    plt.xlabel('log10 H spectral (re.)')\n",
    "    plt.ylabel('acc gap')\n",
    "\n",
    "\n",
    "# IGS\n",
    "eps=1e-6\n",
    "vals_set = []\n",
    "plt.figure()\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        curlen = len(res_reparam_set[ht][t]['L_F'][res_reparam_set[ht][t]['L_F']\n",
    "                                                   > eps*max(res_reparam_set[ht][t]['L_F'])])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['IGS2_traj'][curlen]))\n",
    "    vals_set += vals\n",
    "    curlen = len(res_set[ht]['L_F'][res_set[ht]['L_F']>eps*max(res_set[ht]['L_F'])])\n",
    "    plt.scatter([res_set[ht]['IGS2_traj'][curlen]]*trial_num, vals, c=colorvals_set[ht], cmap=cmap)\n",
    "    if ht == 0:\n",
    "        minval = res_set[ht]['IGS2_traj'][curlen]\n",
    "        maxval = res_set[ht]['IGS2_traj'][curlen]\n",
    "    else:\n",
    "        minval = min(res_set[ht]['IGS2_traj'][curlen], minval)\n",
    "        maxval = max(res_set[ht]['IGS2_traj'][curlen], maxval)\n",
    "#plt.plot([minval, maxval], [minval, maxval], 'gray')\n",
    "plt.plot(np.linspace(minval, maxval), np.log10(np.linspace(minval, maxval)), 'gray')\n",
    "plt.xlabel('IGS (ori.)', fontsize=fontsize)\n",
    "plt.ylabel('log10 IGS (re.)', fontsize=fontsize)\n",
    "midval = 0.5*(np.log10(minval)+np.log10(maxval))\n",
    "plt.ylim([midval-ploty_range, midval+ploty_range])\n",
    "plt.xticks([0.28, 0.30, 0.32, 0.34], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "#plt.savefig('./figs_for_paper/IGS2_reparam_invar.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "if plot_generalization_gaps:\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, generalization_gap_set, c='k')\n",
    "    plt.xlabel('log10 IGS (re.)')\n",
    "    plt.ylabel('generalization gap')\n",
    "\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, acc_gap_set, c='k')\n",
    "    plt.xlabel('log10 IGS (re.)')\n",
    "    plt.ylabel('acc gap')\n",
    "    \n",
    "# Fisher-Rao norm\n",
    "vals_set = []\n",
    "plt.figure()\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['frnorm1'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['frnorm1']))\n",
    "    vals_set += vals\n",
    "    plt.scatter([res_set[ht]['frnorm1']]*trial_num, vals, c=colorvals_set[ht], cmap=cmap)\n",
    "    if ht == 0:\n",
    "        minval = res_set[ht]['frnorm1']\n",
    "        maxval = res_set[ht]['frnorm1']\n",
    "    else:\n",
    "        minval = min(res_set[ht]['frnorm1'], minval)\n",
    "        maxval = max(res_set[ht]['frnorm1'], maxval)\n",
    "#plt.plot([minval, maxval], [minval, maxval], 'gray')\n",
    "plt.plot(np.linspace(minval, maxval), np.log10(np.linspace(minval, maxval)), 'gray')\n",
    "plt.xlabel('Fisher-Rao (ori.)', fontsize=fontsize)\n",
    "plt.ylabel('log10 Fisher-Rao (re.)', fontsize=fontsize)\n",
    "midval = 0.5*(np.log10(minval)+np.log10(maxval))\n",
    "plt.ylim([midval-ploty_range, midval+ploty_range])\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "#plt.savefig('./figs_for_paper/FRnorm_reparam_invar.pdf', format='pdf', bbox_inches='tight')\n",
    "if plot_generalization_gaps:\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, generalization_gap_set, c='k')\n",
    "    plt.xlabel('log10 Fisher-Rao (re.)')\n",
    "    plt.ylabel('generalization gap')\n",
    "\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, acc_gap_set, c='k')\n",
    "    plt.xlabel('log10 Fisher-Rao (re.)')\n",
    "    plt.ylabel('acc gap')\n",
    "\n",
    "\n",
    "# Rangamani et al.'s measure\n",
    "vals_set = []\n",
    "plt.figure()\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['rang_sp_norm_tr'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['rang_sp_norm_tr']))\n",
    "    vals_set += vals\n",
    "    plt.scatter([res_set[ht]['rang_sp_norm_tr']]*trial_num, vals, c=colorvals_set[ht], cmap=cmap)\n",
    "    if ht == 0:\n",
    "        minval = res_set[ht]['rang_sp_norm_tr']\n",
    "        maxval = res_set[ht]['rang_sp_norm_tr']\n",
    "    else:\n",
    "        minval = min(res_set[ht]['rang_sp_norm_tr'], minval)\n",
    "        maxval = max(res_set[ht]['rang_sp_norm_tr'], maxval)\n",
    "#plt.plot([minval, maxval], [minval, maxval], 'gray')\n",
    "plt.plot(np.linspace(minval, maxval), np.log10(np.linspace(minval, maxval)), 'gray')\n",
    "plt.xlabel('Rangamani et al. (ori.)', fontsize=fontsize)\n",
    "plt.ylabel('log10 Rangamani et al. (re.)', fontsize=fontsize)\n",
    "midval = 0.5*(np.log10(minval)+np.log10(maxval))\n",
    "plt.ylim([midval-ploty_range, midval+ploty_range])\n",
    "plt.xticks([1.25, 1.35, 1.45, 1.55], fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "#plt.savefig('./figs_for_paper/Rang_reparam_invar.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "if plot_generalization_gaps:\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, generalization_gap_set, c='k')\n",
    "    plt.xlabel('log10 Rangamani et al. (re.)')\n",
    "    plt.ylabel('generalization gap')\n",
    "\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, acc_gap_set, c='k')\n",
    "    plt.xlabel('log10 Rangamani et al. (re.)')\n",
    "    plt.ylabel('acc gap')\n",
    "\n",
    "# Petzka et al.'s measure\n",
    "vals_set = []\n",
    "plt.figure()\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['petzka_trace_nm'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['petzka_trace_nm']))\n",
    "    vals_set += vals\n",
    "    plt.scatter([res_set[ht]['petzka_trace_nm']]*trial_num, vals, c=colorvals_set[ht], cmap=cmap)\n",
    "    if ht == 0:\n",
    "        minval = res_set[ht]['petzka_trace_nm']\n",
    "        maxval = res_set[ht]['petzka_trace_nm']\n",
    "    else:\n",
    "        minval = min(res_set[ht]['petzka_trace_nm'], minval)\n",
    "        maxval = max(res_set[ht]['petzka_trace_nm'], maxval)\n",
    "#plt.plot([minval, maxval], [minval, maxval], 'gray')\n",
    "plt.plot(np.linspace(minval, maxval), np.log10(np.linspace(minval, maxval)), 'gray')\n",
    "plt.xlabel('Petzka et al. (ori.)', fontsize=fontsize)\n",
    "plt.ylabel('log10 Petzka et al. (re.)', fontsize=fontsize)\n",
    "midval = 0.5*(np.log10(minval)+np.log10(maxval))\n",
    "plt.ylim([midval-ploty_range, midval+ploty_range])\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "#plt.savefig('./figs_for_paper/Petzka_reparam_invar.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "if plot_generalization_gaps:\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, generalization_gap_set, c='k')\n",
    "    plt.xlabel('log10 Petzka et al. (re.)')\n",
    "    plt.ylabel('generalization gap')\n",
    "\n",
    "    plt.figure()\n",
    "    plt.scatter(vals_set, acc_gap_set, c='k')\n",
    "    plt.xlabel('log10 Petzka et al. (re.)')\n",
    "    plt.ylabel('acc gap')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Merged figure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "cmap = matplotlib.cm.get_cmap('jet')\n",
    "#cmap = matplotlib.cm.get_cmap('viridis')\n",
    "\n",
    "verts = list(zip([-100.,100.,100.,-100],[-10.,-10.,10.,10]))\n",
    "\n",
    "colorvals_set = []\n",
    "\n",
    "marker_s = 2000\n",
    "\n",
    "plot_generalization_gaps = False\n",
    "ploty_range = 4.0\n",
    "fontsize=18\n",
    "#plt.rcParams['text.usetex'] = True\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot([-0.5, 5.5], [0, 0], 'gray',zorder=0)\n",
    "\n",
    "# Hessian trace\n",
    "vals_set = []\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['L_H'].sum()) \n",
    "                    - np.log10(res_set[ht]['L_H'].sum()))\n",
    "    vals_set += vals\n",
    "    colorvals = -(np.array(vals)-min(vals))/(max(vals) - min(vals))\n",
    "    colorvals_set.append(colorvals)\n",
    "    ax.scatter([1]*trial_num, vals, c=colorvals_set[ht], cmap=cmap, marker=verts, s=marker_s, alpha=0.5)\n",
    "\"\"\"\n",
    "# Hessian top eigenvalue\n",
    "vals_set = []\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['petzka_maxeigen_nm'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['L_H'][-1])\n",
    "                    - np.log10(res_set[ht]['L_H'][-1]))\n",
    "    vals_set += vals\n",
    "    ax.scatter([2]*trial_num, vals, c=colorvals_set[ht], cmap=cmap, marker=verts, s=1000, alpha=0.5)\n",
    "\"\"\"\n",
    "# IGS\n",
    "eps=1e-6\n",
    "vals_set = []\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        curlen = len(res_reparam_set[ht][t]['L_F'][res_reparam_set[ht][t]['L_F']\n",
    "                                                   > eps*max(res_reparam_set[ht][t]['L_F'])])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['IGS2_traj'][curlen]) \n",
    "                    - np.log10(res_set[ht]['IGS2_traj'][curlen]))\n",
    "    vals_set += vals\n",
    "    curlen = len(res_set[ht]['L_F'][res_set[ht]['L_F']>eps*max(res_set[ht]['L_F'])])\n",
    "    ax.scatter([0]*trial_num, vals, c=colorvals_set[ht], cmap=cmap, marker=verts, s=marker_s, alpha=0.5)\n",
    "#plt.xlabel('IGS (ori.)', fontsize=fontsize)\n",
    "\n",
    "# Fisher-Rao norm\n",
    "vals_set = []\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['frnorm1'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['frnorm1'])\n",
    "                   - np.log10(res_set[ht]['frnorm1']))\n",
    "    vals_set += vals\n",
    "    ax.scatter([2]*trial_num, vals, c=colorvals_set[ht], cmap=cmap, marker=verts, s=marker_s, alpha=0.5)\n",
    "\n",
    "    \n",
    "# Rangamani et al.'s measure\n",
    "vals_set = []\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['rang_sp_norm_tr'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['rang_sp_norm_tr'])\n",
    "                   - np.log10(res_set[ht]['rang_sp_norm_tr']))\n",
    "    vals_set += vals\n",
    "    ax.scatter([3]*trial_num, vals, c=colorvals_set[ht], cmap=cmap, marker=verts, s=marker_s, alpha=0.5)\n",
    "    \n",
    "# Petzka et al.'s measure\n",
    "vals_set = []\n",
    "for ht in range(hyper_trial_num):\n",
    "    vals = []\n",
    "    for t in range(trial_num):\n",
    "        #vals.append(res_reparam_set[ht][t]['petzka_trace_nm'])\n",
    "        vals.append(np.log10(res_reparam_set[ht][t]['petzka_trace_nm'])\n",
    "                   - np.log10(res_set[ht]['petzka_trace_nm']))\n",
    "    vals_set += vals\n",
    "    ax.scatter([4]*trial_num, vals, c=colorvals_set[ht], cmap=cmap, marker=verts, s=marker_s, alpha=0.5)\n",
    "\n",
    "\n",
    "ax.set_ylabel(r'$\\frac{\\mathrm{Sharpness (re.)}}{\\mathrm{Sharpness (ori.)}}$', fontsize=24)\n",
    "ax.set_xlim([-0.5, 4.5])\n",
    "ax.set_ylim([-4, +4])\n",
    "ax.set_xticks([0,1,2,3,4])\n",
    "ax.set_xticklabels(['IGS', r'Tr($H$)', 'Fisher\\n-Rao', \n",
    "                    'Rangamani\\net al.', 'Petzka \\net al.'], \n",
    "           fontsize=18)\n",
    "ax.set_yticks([-4, -2, 0, 2, 4])\n",
    "ax.set_yticklabels([r'$10^{-4}$', r'$10^{-2}$', r'$10^{0}$', r'$10^{2}$', r'$10^{4}$'], fontsize=18)\n",
    "#ax.yaxis.set_label_coords(-0.15,0.43)\n",
    "fig.set_size_inches(10, 3.5)\n",
    "#plt.savefig('./figs_for_paper/reparam_invar_all.pdf', format='pdf', bbox_inches='tight')"
   ]
  },
  {
   "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
}
