{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import sys\n",
    "import os\n",
    "from itertools import product\n",
    "import math\n",
    "import numpy\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "from scipy.cluster.hierarchy import dendrogram, leaves_list\n",
    "from scipy.spatial.distance import pdist\n",
    "from sklearn.manifold import TSNE, MDS\n",
    "# import umap\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import cm\n",
    "from mpl_toolkits.axes_grid1 import make_axes_locatable\n",
    "import datetime\n",
    "\n",
    "sys.path.append(os.path.abspath(\"../\"))\n",
    "from distance_functions import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "start_time = datetime.datetime.now()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load representations and distance estimates with increasing n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "load_from_saved = True\n",
    "\n",
    "lambda_vals = [np.inf,3,2,1,0,-1]\n",
    "n_vals = np.arange(1200,10200,800)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['alexnet_pretrained_rep' 'convnext_small_pretrained_rep'\n",
      " 'efficientnet_b0_pretrained_rep' 'efficientnet_b3_pretrained_rep'\n",
      " 'efficientnet_b6_pretrained_rep' 'inception_pretrained_rep'\n",
      " 'mobilenet_v3_large_pretrained_rep' 'regnet_x_1_6gf_pretrained_rep'\n",
      " 'regnet_x_400mf_pretrained_rep' 'regnet_y_16gf_pretrained_rep'\n",
      " 'regnet_y_3_2gf_pretrained_rep' 'regnet_y_8gf_pretrained_rep'\n",
      " 'shufflenet_pretrained_rep' 'vit_b_16_pretrained_rep'\n",
      " 'vit_l_32_pretrained_rep']\n"
     ]
    }
   ],
   "source": [
    "stats = np.load(f\"distances/train/pretrained/stats.npz\")\n",
    "model_names = stats[\"model_names\"]\n",
    "old_model_names = model_names\n",
    "sub_index = np.where(np.asarray(range(len(old_model_names))) % 3 == 0)\n",
    "# print(sub_index)\n",
    "model_names = np.asarray([old_model_names[i] for i in sub_index])[0,:]\n",
    "print(model_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not load_from_saved:\n",
    "    folder = \"estimated_distances_increasing_n/pretrained\"\n",
    "    \n",
    "    # Load ImageNet representations\n",
    "    n1 = 10000\n",
    "    n2 = 10000\n",
    "    reps1 = {}\n",
    "    reps2 = {}\n",
    "    for model_name in model_names:\n",
    "        print(model_name)\n",
    "        rep = np.load(\"reps/train/20000_eval/\" + model_name + \".npy\")\n",
    "        rep1 = rep[:,0:n1]\n",
    "        rep2 = rep[:,n1:n1+n2]\n",
    "        # center and normalize\n",
    "        rep1 = rep1 - rep1.mean(axis=1, keepdims=True)\n",
    "        rep1 = rep1 / np.linalg.norm(rep1)\n",
    "        rep1 = rep1 * np.sqrt(rep1.shape[1])\n",
    "        reps1[model_name] = rep1\n",
    "\n",
    "        rep2 = rep2 - rep2.mean(axis=1, keepdims=True)\n",
    "        rep2 = rep2 / np.linalg.norm(rep2)\n",
    "        rep2 = rep2 * np.sqrt(rep2.shape[1])\n",
    "        reps2[model_name] = rep2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_dists(reps, lambda_vals, n_vals):\n",
    "    d_mat = {}\n",
    "    evals_evecs = {}\n",
    "    for model_name in model_names:\n",
    "        print(model_name)\n",
    "        for n_ind in range(len(n_vals)):\n",
    "            n = n_vals[n_ind]\n",
    "            A = reps[model_name][:,0:n]\n",
    "            evals_a, evecs_a = np.linalg.eigh(A @ A.T)\n",
    "            evals_evecs[(model_name, n)] = (evals_a, evecs_a)\n",
    "\n",
    "    for ind_1 in range(len(model_names)):\n",
    "        print(ind_1,'/',len(model_names))\n",
    "        model_name1 = model_names[ind_1]\n",
    "        for ind_2 in range(ind_1+1,len(model_names)):\n",
    "            model_name2 = model_names[ind_2]\n",
    "            print(model_name1, model_name2)\n",
    "            new_mat = np.zeros((len(lambda_vals),len(n_vals)))\n",
    "\n",
    "            for n_ind in range(len(n_vals)):\n",
    "                n = n_vals[n_ind]\n",
    "                A = reps[model_name1][:,0:n]\n",
    "                B = reps[model_name2][:,0:n]\n",
    "                evals_a, evecs_a = evals_evecs[(model_name1, n)]\n",
    "                evals_b, evecs_b = evals_evecs[(model_name2, n)]\n",
    "    #             print(n)\n",
    "                for i in range(len(lambda_vals)):\n",
    "                    if lambda_vals[i] == np.inf:\n",
    "                        curr_dist = predictor_dist(A, B, evals_a=evals_a, evecs_a = evecs_a, evals_b = evals_b, evecs_b = evecs_b, lmbda=0)\n",
    "    #                     print('0\\t',curr_dist)\n",
    "                        new_mat[i,n_ind] = curr_dist\n",
    "                    else:\n",
    "                        curr_dist = predictor_dist(A, B, evals_a=evals_a, evecs_a = evecs_a, evals_b = evals_b, evecs_b = evecs_b, lmbda=math.pow(10,-lambda_vals[i]))\n",
    "    #                     print('1e-' + str(lambda_vals[i]) + '\\t',curr_dist)\n",
    "                        new_mat[i,n_ind] = curr_dist\n",
    "\n",
    "            d_mat[(model_name1, model_name2)] = new_mat\n",
    "    return d_mat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not load_from_saved:\n",
    "    d_mat1 = load_dists(reps1, lambda_vals, n_vals)\n",
    "    pickle.dump(d_mat1, open(\"./estimated_distances_increasing_n/trained/imagenet_dists_10000_v1.pkl\", \"wb\"))\n",
    "else:\n",
    "    d_mat1 = pickle.load(open(\"./estimated_distances_increasing_n/trained/imagenet_dists_10000_v1.pkl\", \"rb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "if not load_from_saved:\n",
    "    d_mat2 = load_dists(reps2, lambda_vals, n_vals)\n",
    "    pickle.dump(d_mat2, open(\"estimated_distances_increasing_n/trained/imagenet_dists_10000_v2.pkl\", \"wb\"))\n",
    "    \n",
    "else:\n",
    "    d_mat2 = pickle.load(open(\"estimated_distances_increasing_n/trained/imagenet_dists_10000_v2.pkl\", \"rb\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plot relative error with respect to estimate with largest n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": true
   },
   "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"
    }
   ],
   "source": [
    "# Plot relative error of d_mat1 with respect to final value\n",
    "\n",
    "for i in range(len(lambda_vals)):\n",
    "    if lambda_vals[i] == np.inf:\n",
    "        currlabel = '$\\lambda = 0$'\n",
    "    elif lambda_vals[i] == 0:\n",
    "        currlabel = '$\\lambda = 1$'\n",
    "    elif lambda_vals[i] >= 0:\n",
    "        currlabel ='$\\lambda = 10^{-' + str(lambda_vals[i]) + '}$'\n",
    "    elif lambda_vals[i] < 0:\n",
    "        currlabel ='$\\lambda = 10^{' + str(-lambda_vals[i]) + '}$'\n",
    "    \n",
    "    curr_l = np.zeros(len(n_vals))\n",
    "    curr_err = np.zeros(len(n_vals))\n",
    "    for ind_1 in range(len(model_names)):\n",
    "        model_name1 = model_names[ind_1]\n",
    "        for ind_2 in range(ind_1+1, len(model_names)):\n",
    "            model_name2 = model_names[ind_2]\n",
    "            \n",
    "            curr_mat = d_mat1[(model_name1, model_name2)]\n",
    "            final_val = curr_mat[i,-1]\n",
    "            curr_l = curr_l + curr_mat[i,:] / final_val\n",
    "            curr_err = curr_err + np.abs((curr_mat[i,:] - final_val) / final_val)\n",
    "    avg_err = curr_err / (len(model_names) * (len(model_names) - 1) / 2)\n",
    "    avg_l = curr_l / (len(model_names) * (len(model_names) - 1) / 2)\n",
    "#     diff_l = avg_l[0:-2] - avg_l[1:-1]\n",
    "#     print(diff_l)\n",
    "#     plt.plot(n_vals, avg_l, label=currlabel)\n",
    "    plt.plot(n_vals, avg_err, label=currlabel)\n",
    "#     plt.ylim((0,2))\n",
    "#     plt.ylim((-0.2,0.2))\n",
    "plt.legend()\n",
    "plt.title('relative error of $\\hat{d}_{\\lambda,n}$ with respect to $\\hat{d}_{\\lambda,10000}$', fontsize=15)\n",
    "plt.xlabel('n', fontsize=15)\n",
    "plt.ylabel('average relative error', fontsize=15)\n",
    "plt.savefig('../paper_figures/convergence_relative_error.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compare estimates with independent samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING: Omitting some values from log10(lambda)=inf, due to numerical precision issues\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"
    }
   ],
   "source": [
    "# Compute the average relative error for two independent runs\n",
    "\n",
    "avg_errs = np.zeros((len(lambda_vals), len(n_vals)))\n",
    "for i in range(0,len(lambda_vals)):\n",
    "    if lambda_vals[i] == np.inf:\n",
    "        currlabel = '$\\\\lambda = 0$'\n",
    "    elif lambda_vals[i] == 0:\n",
    "        currlabel = '$\\\\lambda = 1$'\n",
    "    elif lambda_vals[i] >= 0:\n",
    "        currlabel ='$\\\\lambda = 10^{-' + str(lambda_vals[i]) + '}$'\n",
    "    elif lambda_vals[i] < 0:\n",
    "        currlabel ='$\\\\lambda = 10^{' + str(-lambda_vals[i]) + '}$'\n",
    "    \n",
    "    broken = np.zeros(len(n_vals))\n",
    "    avg_err = np.zeros(len(n_vals))\n",
    "    for ind_1 in range(len(model_names)):\n",
    "        model_name1 = model_names[ind_1]\n",
    "        for ind_2 in range(ind_1+1, len(model_names)):\n",
    "            model_name2 = model_names[ind_2]\n",
    "            \n",
    "            v0 = curr_mat1 = d_mat1[(model_name1, model_name2)][i,:]\n",
    "            v1 = curr_mat2 = d_mat2[(model_name1, model_name2)][i,:]\n",
    "\n",
    "            rel_err = np.abs(v0 - v1) / (v0 + v1)\n",
    "\n",
    "            broken = broken + (v0 <= 0)\n",
    "            broken = broken + (v1 <= 0)\n",
    "\n",
    "            avg_err += rel_err\n",
    "    avg_errs[i,:] = avg_err / ((len(model_names) * (len(model_names) - 1) / 2))\n",
    "#     print(broken)\n",
    "    if np.any(broken):\n",
    "        print(f'WARNING: Omitting some values from log10(lambda)={lambda_vals[i]}, due to numerical precision issues')\n",
    "    not_broken = np.ndarray.flatten(np.asarray(np.where(broken < 1)))\n",
    "\n",
    "    plt.plot(n_vals[not_broken], avg_errs[i,not_broken], label=currlabel)\n",
    "    plt.ylim((0,0.1))\n",
    "\n",
    "plt.title('Average relative error between two independent estimates')\n",
    "plt.xlabel('n')\n",
    "plt.ylabel('average relative error')\n",
    "plt.legend()\n",
    "plt.savefig('../paper_figures/convergence_relative_error_indep_trials.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Time elapsed: 0:00:00.817321\n"
     ]
    }
   ],
   "source": [
    "end_time = datetime.datetime.now()\n",
    "print('Time elapsed:',end_time - start_time)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:root] *",
   "language": "python",
   "name": "conda-root-py"
  },
  "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.8.5"
  },
  "latex_envs": {
   "LaTeX_envs_menu_present": true,
   "autoclose": false,
   "autocomplete": true,
   "bibliofile": "biblio.bib",
   "cite_by": "apalike",
   "current_citInitial": 1,
   "eqLabelWithNumbers": true,
   "eqNumInitial": 1,
   "hotkeys": {
    "equation": "Ctrl-E",
    "itemize": "Ctrl-I"
   },
   "labels_anchors": false,
   "latex_user_defs": false,
   "report_style_numbering": false,
   "user_envs_cfg": false
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  },
  "varInspector": {
   "cols": {
    "lenName": 16,
    "lenType": 16,
    "lenVar": 40
   },
   "kernels_config": {
    "python": {
     "delete_cmd_postfix": "",
     "delete_cmd_prefix": "del ",
     "library": "var_list.py",
     "varRefreshCmd": "print(var_dic_list())"
    },
    "r": {
     "delete_cmd_postfix": ") ",
     "delete_cmd_prefix": "rm(",
     "library": "var_list.r",
     "varRefreshCmd": "cat(var_dic_list()) "
    }
   },
   "types_to_exclude": [
    "module",
    "function",
    "builtin_function_or_method",
    "instance",
    "_Feature"
   ],
   "window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
