{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d0746394-6878-4518-9dde-44ade0ce217d",
   "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,
   "id": "7008dbb3-33d9-4b69-98ae-124e92b9aca6",
   "metadata": {},
   "outputs": [],
   "source": [
    "os.environ[\"CUDA_DEVICE_ORDER\"] = \"PCI_BUS_ID\"\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "071bc0fc-0087-43e3-b86b-0c87f7cb1c3e",
   "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",
   "id": "401c2160-6cb8-4fb4-84e1-69a985ee38cb",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Load MNIST data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "43d7e9d5-109b-41dd-a2f5-fd6e773e255e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz to ./data/MNIST/raw/train-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "347c52b3c8a54d029461a1a7b4be9dd8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "|          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./data/MNIST/raw/train-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz to ./data/MNIST/raw/train-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8bfc866464164c5db2aebbdbb512c724",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "|          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./data/MNIST/raw/train-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw/t10k-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bd09057dcdfd49069b4b305b73267317",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "|          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./data/MNIST/raw/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "749be95c983f4a7080c501179509b593",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "|          | 0/? [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
      "Processing...\n",
      "Done!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/torchvision/datasets/mnist.py:480: UserWarning: The given NumPy array is not writeable, and PyTorch does not support non-writeable tensors. This means you can write to the underlying (supposedly non-writeable) NumPy array using the tensor. You may want to copy the array to protect its data or make it writeable before converting it to a tensor. This type of warning will be suppressed for the rest of this program. (Triggered internally at  /pytorch/torch/csrc/utils/tensor_numpy.cpp:141.)\n",
      "  return torch.from_numpy(parsed.astype(m[2], copy=False)).view(*s)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "60000\n",
      "10000\n"
     ]
    }
   ],
   "source": [
    "dataset = 'mnist'\n",
    "batch_size = 60000\n",
    "test_batch_size = 10000\n",
    "data_aug = False\n",
    "cutout = False\n",
    "max_traindata_num = None\n",
    "max_testdata_num = None\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 = 'lenet'\n",
    "                                        )    \n",
    "print(len(train_loader.dataset))\n",
    "print(len(test_loader.dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b5d52acf-7183-4eb6-b96f-29f378b4db48",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LeNet5(\n",
      "  (conv1): Conv2d(1, 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: 61706\n"
     ]
    }
   ],
   "source": [
    "model = get_model('lenet',\n",
    "                  dataset=dataset,\n",
    "                  num_classes=num_classes\n",
    "                 )\n",
    "model = model.cuda()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a34fda6b-bb01-43b2-a7d7-1f31df31ab7a",
   "metadata": {},
   "source": [
    "# Load trained models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "230fedf4-2df8-495e-94fb-1e840c4cb24e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2\n"
     ]
    }
   ],
   "source": [
    "loss_val = 0.01\n",
    "file_list = []\n",
    "bs_list = []\n",
    "lr_list = []\n",
    "save_folder = \"./trained_model_cor_exp_MNIST/\"\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,
   "id": "e7c9304c-5239-4510-b647-48212beddfbf",
   "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,
   "id": "783ae8cc-de8d-406f-b770-79c86125f5f0",
   "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",
   "id": "d68876c9-d2f2-4b1e-9994-e3df850f95a5",
   "metadata": {},
   "source": [
    "# Calculate sharpness values"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d6c1f21-6f46-4866-9baf-8fabe4be9591",
   "metadata": {},
   "source": [
    "#### NOTE: Precomputed sharpness values for some trained models are saved in 'numerics_other_measures_MNIST_lenet_*.pickle' in 'trained_model_cor_exp_MNIST' folder"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a1e60492-05ac-43d5-b67c-ded18fe331eb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------- filename = ./trained_model_cor_exp_MNIST/mnist_lenet_SGD_baseline_lr0.05_mom0.0_wd0.0_bs128_seed1_20220415153031_loss0.01.pth ---------\n",
      "time for loss and acc:  13.276808738708496\n",
      "Fisher-Rao norm 2 (assumption): 1.403038\n",
      "Fisher-Rao norm 2 (emp): 1.989251\n",
      "Fisher-Rao norm elapsed time:  0.06814050674438477\n",
      "Rangamani et al. measure: 4756.579132\n",
      "Rangamani et al. measure elapsed time:  9.78887677192688\n",
      "Fisher-Rao norm 2 (assumption): 1.464754\n",
      "Fisher-Rao norm 2 (emp): 9.740666\n",
      "Fisher-Rao norm elapsed time:  0.010976791381835938\n",
      "Rangamani et al. measure: 5075.899305\n",
      "Rangamani et al. measure elapsed time:  1.884002923965454\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 46.769896\n",
      "Petzka et al. measure (max eigval): 25.450848\n",
      "Petzka et al. measure elapsed time:  2.323385715484619\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 52.513268\n",
      "Petzka et al. measure (max eigval): 28.469905\n",
      "Petzka et al. measure elapsed time:  2.2035937309265137\n",
      "--------- filename = ./trained_model_cor_exp_MNIST/mnist_lenet_SGD_baseline_lr0.002_mom0.0_wd0.0_bs1024_seed2_20220427065421_loss0.01_postepoch0.pth ---------\n",
      "time for loss and acc:  13.30866003036499\n",
      "Fisher-Rao norm 2 (assumption): 1.256866\n",
      "Fisher-Rao norm 2 (emp): 0.505206\n",
      "Fisher-Rao norm elapsed time:  0.06801533699035645\n",
      "Rangamani et al. measure: 45082.323271\n",
      "Rangamani et al. measure elapsed time:  125.3599042892456\n",
      "Fisher-Rao norm 2 (assumption): 1.183156\n",
      "Fisher-Rao norm 2 (emp): 7.812094\n",
      "Fisher-Rao norm elapsed time:  0.010949850082397461\n",
      "Rangamani et al. measure: 52350.584533\n",
      "Rangamani et al. measure elapsed time:  11.371818542480469\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 282.923574\n",
      "Petzka et al. measure (max eigval): 219.095369\n",
      "Petzka et al. measure elapsed time:  2.2860236167907715\n",
      "got hessian\n",
      "Petzka et al. measure (trace): 326.273702\n",
      "Petzka et al. measure (max eigval): 251.256544\n",
      "Petzka et al. measure elapsed time:  2.2514443397521973\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",
    "    cur_acc, avg_loss = test(model, train_loader, criterion)\n",
    "    train_loss_list.append(avg_loss)\n",
    "    train_acc_list.append(cur_acc)\n",
    "\n",
    "    cur_acc, avg_loss = 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, 500, model, criterion, \n",
    "                                            W_trans, X_np, y_np, \n",
    "                                            tol=1e-6)\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, 500, model, criterion, \n",
    "                                            W_trans, X_test_np, y_test_np, \n",
    "                                            tol=1e-6)\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_MNIST_lenet_loss0.01_'+str(startidx)+'_'+str(endidx)+'.pickle'\n",
    "with open(filename, 'wb') as handle:\n",
    "    pickle.dump(res, handle, protocol=pickle.HIGHEST_PROTOCOL)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "461a4ab0-3318-47e4-9542-675dbe1965c7",
   "metadata": {},
   "source": [
    "#### Load precomputed results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "ede88ba5-748c-4150-bd1e-2724e8f46912",
   "metadata": {},
   "outputs": [],
   "source": [
    "filenames = []\n",
    "\n",
    "filenames.append('./trained_model_cor_exp_MNIST/numerics_other_measures_MNIST_lenet_loss0.01_20220427_0_20.pickle')\n",
    "filenames.append('./trained_model_cor_exp_MNIST/numerics_other_measures_MNIST_lenet_loss0.01_20220415_0_20.pickle')\n",
    "filenames.append('./trained_model_cor_exp_MNIST/numerics_other_measures_MNIST_lenet_loss0.01_20220415_20_40.pickle')\n",
    "filenames.append('./trained_model_cor_exp_MNIST/numerics_other_measures_MNIST_lenet_loss0.01_20220415_40_60.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",
   "id": "929c0892-f887-48ae-8125-335978da76fe",
   "metadata": {},
   "source": [
    "#### Scatter plots for generalization gap vs. sharpness measures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a4bc6e9d-9272-44ec-b9c9-f02d5c8e9cd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "g_gap2 = np.array(test_loss_list) - np.array(train_loss_list)\n",
    "idx = np.array(lr_list) >= 0.002"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a170b745-a75e-4416-ab60-bf47121eb8f9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.3655831354001921\n",
      "0.5648010978905175\n",
      "0.5700091738807894\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": "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\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([0.0275,  0.0350,  0.0425], 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([0.0275,  0.0350,  0.0425], 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([0.0275,  0.0350,  0.0425], 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,
   "id": "0042b3f9-960f-48af-aea2-d679c62d8455",
   "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": 5
}
